aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
Diffstat (limited to 'kernel')
-rw-r--r--kernel/workqueue.c21
1 files changed, 21 insertions, 0 deletions
diff --git a/kernel/workqueue.c b/kernel/workqueue.c
index 405282d30046..9c6ad974bb9e 100644
--- a/kernel/workqueue.c
+++ b/kernel/workqueue.c
@@ -124,6 +124,7 @@ enum {
124 124
125struct worker_pool { 125struct worker_pool {
126 struct global_cwq *gcwq; /* I: the owning gcwq */ 126 struct global_cwq *gcwq; /* I: the owning gcwq */
127 int id; /* I: pool ID */
127 unsigned int flags; /* X: flags */ 128 unsigned int flags; /* X: flags */
128 129
129 struct list_head worklist; /* L: list of pending works */ 130 struct list_head worklist; /* L: list of pending works */
@@ -445,6 +446,10 @@ static atomic_t unbound_pool_nr_running[NR_STD_WORKER_POOLS] = {
445 [0 ... NR_STD_WORKER_POOLS - 1] = ATOMIC_INIT(0), /* always 0 */ 446 [0 ... NR_STD_WORKER_POOLS - 1] = ATOMIC_INIT(0), /* always 0 */
446}; 447};
447 448
449/* idr of all pools */
450static DEFINE_MUTEX(worker_pool_idr_mutex);
451static DEFINE_IDR(worker_pool_idr);
452
448static int worker_thread(void *__worker); 453static int worker_thread(void *__worker);
449static unsigned int work_cpu(struct work_struct *work); 454static unsigned int work_cpu(struct work_struct *work);
450 455
@@ -461,6 +466,19 @@ static struct global_cwq *get_gcwq(unsigned int cpu)
461 return &unbound_global_cwq; 466 return &unbound_global_cwq;
462} 467}
463 468
469/* allocate ID and assign it to @pool */
470static int worker_pool_assign_id(struct worker_pool *pool)
471{
472 int ret;
473
474 mutex_lock(&worker_pool_idr_mutex);
475 idr_pre_get(&worker_pool_idr, GFP_KERNEL);
476 ret = idr_get_new(&worker_pool_idr, pool, &pool->id);
477 mutex_unlock(&worker_pool_idr_mutex);
478
479 return ret;
480}
481
464static atomic_t *get_pool_nr_running(struct worker_pool *pool) 482static atomic_t *get_pool_nr_running(struct worker_pool *pool)
465{ 483{
466 int cpu = pool->gcwq->cpu; 484 int cpu = pool->gcwq->cpu;
@@ -3830,6 +3848,9 @@ static int __init init_workqueues(void)
3830 3848
3831 mutex_init(&pool->assoc_mutex); 3849 mutex_init(&pool->assoc_mutex);
3832 ida_init(&pool->worker_ida); 3850 ida_init(&pool->worker_ida);
3851
3852 /* alloc pool ID */
3853 BUG_ON(worker_pool_assign_id(pool));
3833 } 3854 }
3834 } 3855 }
3835 3856