aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorHao Xu <haoxu@linux.alibaba.com>2021-08-05 18:05:38 +0800
committerJens Axboe <axboe@kernel.dk>2021-08-06 08:28:18 -0600
commit21698274da5b6fc724b005bc7ec3e6b9fbcfaa06 (patch)
tree5d721629d54c549b8f4d3a5a0fb97c45be228108 /fs
parentio-wq: fix no lock protection of acct->nr_worker (diff)
downloadlinux-dev-21698274da5b6fc724b005bc7ec3e6b9fbcfaa06.tar.xz
linux-dev-21698274da5b6fc724b005bc7ec3e6b9fbcfaa06.zip
io-wq: fix lack of acct->nr_workers < acct->max_workers judgement
There should be this judgement before we create an io-worker Fixes: 685fe7feedb9 ("io-wq: eliminate the need for a manager thread") Signed-off-by: Hao Xu <haoxu@linux.alibaba.com> Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'fs')
-rw-r--r--fs/io-wq.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/fs/io-wq.c b/fs/io-wq.c
index 64d904ce4f2d..12fc19353bb0 100644
--- a/fs/io-wq.c
+++ b/fs/io-wq.c
@@ -280,9 +280,17 @@ static void create_worker_cb(struct callback_head *cb)
{
struct create_worker_data *cwd;
struct io_wq *wq;
+ struct io_wqe *wqe;
+ struct io_wqe_acct *acct;
cwd = container_of(cb, struct create_worker_data, work);
- wq = cwd->wqe->wq;
+ wqe = cwd->wqe;
+ wq = wqe->wq;
+ acct = &wqe->acct[cwd->index];
+ raw_spin_lock_irq(&wqe->lock);
+ if (acct->nr_workers < acct->max_workers)
+ acct->nr_workers++;
+ raw_spin_unlock_irq(&wqe->lock);
create_io_worker(wq, cwd->wqe, cwd->index);
kfree(cwd);
}