diff options
author | Bhaktipriya Shridhar <bhaktipriya96@gmail.com> | 2016-07-16 04:48:34 -0400 |
---|---|---|
committer | Martin Schwidefsky <schwidefsky@de.ibm.com> | 2016-07-18 04:17:21 -0400 |
commit | 7b1058bc59ac24eb01e259749e8655fb884aa711 (patch) | |
tree | 3606d57eb01a0c82004d3faf86a4c6e898fe7d46 /drivers/s390 | |
parent | 687cb7f21695469626f683d709d931ad41b2ca68 (diff) |
s390/cio/chp : Remove deprecated create_singlethread_workqueue
The workqueue "chp_wq" is involved in performing pending
configure tasks for channel paths.
It has a single work item(&cfg_work) and hence doesn't require
ordering. Also, it is not being used on a memory reclaim path.
Hence, the singlethreaded workqueue has been replaced with the use of
system_wq.
System workqueues have been able to handle high level of concurrency
for a long time now and hence it's not required to have a singlethreaded
workqueue just to gain concurrency. Unlike a dedicated per-cpu workqueue
created with create_singlethread_workqueue(), system_wq allows multiple
work items to overlap executions even on the same CPU; however, a
per-cpu workqueue doesn't have any CPU locality or global ordering
guarantee unless the target CPU is explicitly specified and thus the
increase of local concurrency shouldn't make any difference.
Signed-off-by: Bhaktipriya Shridhar <bhaktipriya96@gmail.com>
Signed-off-by: Sebastian Ott <sebott@linux.vnet.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'drivers/s390')
-rw-r--r-- | drivers/s390/cio/chp.c | 11 |
1 files changed, 2 insertions, 9 deletions
diff --git a/drivers/s390/cio/chp.c b/drivers/s390/cio/chp.c index d3b72eab2b8f..e96aced58627 100644 --- a/drivers/s390/cio/chp.c +++ b/drivers/s390/cio/chp.c | |||
@@ -47,8 +47,6 @@ static DEFINE_MUTEX(info_lock); | |||
47 | /* Time after which channel-path status may be outdated. */ | 47 | /* Time after which channel-path status may be outdated. */ |
48 | static unsigned long chp_info_expires; | 48 | static unsigned long chp_info_expires; |
49 | 49 | ||
50 | /* Workqueue to perform pending configure tasks. */ | ||
51 | static struct workqueue_struct *chp_wq; | ||
52 | static struct work_struct cfg_work; | 50 | static struct work_struct cfg_work; |
53 | 51 | ||
54 | /* Wait queue for configure completion events. */ | 52 | /* Wait queue for configure completion events. */ |
@@ -717,7 +715,7 @@ static void cfg_func(struct work_struct *work) | |||
717 | wake_up_interruptible(&cfg_wait_queue); | 715 | wake_up_interruptible(&cfg_wait_queue); |
718 | return; | 716 | return; |
719 | } | 717 | } |
720 | queue_work(chp_wq, &cfg_work); | 718 | schedule_work(&cfg_work); |
721 | } | 719 | } |
722 | 720 | ||
723 | /** | 721 | /** |
@@ -735,7 +733,7 @@ void chp_cfg_schedule(struct chp_id chpid, int configure) | |||
735 | cfg_set_task(chpid, configure ? cfg_configure : cfg_deconfigure); | 733 | cfg_set_task(chpid, configure ? cfg_configure : cfg_deconfigure); |
736 | cfg_busy = 1; | 734 | cfg_busy = 1; |
737 | mutex_unlock(&cfg_lock); | 735 | mutex_unlock(&cfg_lock); |
738 | queue_work(chp_wq, &cfg_work); | 736 | schedule_work(&cfg_work); |
739 | } | 737 | } |
740 | 738 | ||
741 | /** | 739 | /** |
@@ -769,11 +767,6 @@ static int __init chp_init(void) | |||
769 | ret = crw_register_handler(CRW_RSC_CPATH, chp_process_crw); | 767 | ret = crw_register_handler(CRW_RSC_CPATH, chp_process_crw); |
770 | if (ret) | 768 | if (ret) |
771 | return ret; | 769 | return ret; |
772 | chp_wq = create_singlethread_workqueue("cio_chp"); | ||
773 | if (!chp_wq) { | ||
774 | crw_unregister_handler(CRW_RSC_CPATH); | ||
775 | return -ENOMEM; | ||
776 | } | ||
777 | INIT_WORK(&cfg_work, cfg_func); | 770 | INIT_WORK(&cfg_work, cfg_func); |
778 | init_waitqueue_head(&cfg_wait_queue); | 771 | init_waitqueue_head(&cfg_wait_queue); |
779 | if (info_update()) | 772 | if (info_update()) |