forked from luck/tmp_suning_uos_patched
7bb8b77779
Replace the deprecated create_singlethread_workqueue() with alloc_ordered_workqueue() with WQ_MEM_RECLAIM. This is the identity conversion. It's not recommended to stall it from memory pressure. Hence, WQ_MEM_RECLAIM has been set to ensure forward progress under memory pressure. Signed-off-by: Bhaktipriya Shridhar <bhaktipriya96@gmail.com> Cc: Tejun Heo <tj@kernel.org> Cc: linux-edac <linux-edac@vger.kernel.org> Link: http://lkml.kernel.org/r/20160813164124.GA9077@Karyakshetra Signed-off-by: Borislav Petkov <bp@suse.de>
43 lines
782 B
C
43 lines
782 B
C
#include "edac_module.h"
|
|
|
|
static struct workqueue_struct *wq;
|
|
|
|
bool edac_queue_work(struct delayed_work *work, unsigned long delay)
|
|
{
|
|
return queue_delayed_work(wq, work, delay);
|
|
}
|
|
EXPORT_SYMBOL_GPL(edac_queue_work);
|
|
|
|
bool edac_mod_work(struct delayed_work *work, unsigned long delay)
|
|
{
|
|
return mod_delayed_work(wq, work, delay);
|
|
}
|
|
EXPORT_SYMBOL_GPL(edac_mod_work);
|
|
|
|
bool edac_stop_work(struct delayed_work *work)
|
|
{
|
|
bool ret;
|
|
|
|
ret = cancel_delayed_work_sync(work);
|
|
flush_workqueue(wq);
|
|
|
|
return ret;
|
|
}
|
|
EXPORT_SYMBOL_GPL(edac_stop_work);
|
|
|
|
int edac_workqueue_setup(void)
|
|
{
|
|
wq = alloc_ordered_workqueue("edac-poller", WQ_MEM_RECLAIM);
|
|
if (!wq)
|
|
return -ENODEV;
|
|
else
|
|
return 0;
|
|
}
|
|
|
|
void edac_workqueue_teardown(void)
|
|
{
|
|
flush_workqueue(wq);
|
|
destroy_workqueue(wq);
|
|
wq = NULL;
|
|
}
|