summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHao Xu <haoxu@linux.alibaba.com>2021-08-08 15:54:33 +0200
committerJens Axboe <axboe@kernel.dk>2021-08-10 03:59:06 +0200
commit49e7f0c789add1330b111af0b7caeb0e87df063e (patch)
tree759616576ebaa3498952e4dd8d23746738d0bed1
parentio_uring: rsrc ref lock needs to be IRQ safe (diff)
downloadlinux-49e7f0c789add1330b111af0b7caeb0e87df063e.tar.xz
linux-49e7f0c789add1330b111af0b7caeb0e87df063e.zip
io-wq: fix bug of creating io-wokers unconditionally
The former patch to add check between nr_workers and max_workers has a bug, which will cause unconditionally creating io-workers. That's because the result of the check doesn't affect the call of create_io_worker(), fix it by bringing in a boolean value for it. Fixes: 21698274da5b ("io-wq: fix lack of acct->nr_workers < acct->max_workers judgement") Signed-off-by: Hao Xu <haoxu@linux.alibaba.com> Link: https://lore.kernel.org/r/20210808135434.68667-2-haoxu@linux.alibaba.com [axboe: drop hunk that isn't strictly needed] Signed-off-by: Jens Axboe <axboe@kernel.dk>
-rw-r--r--fs/io-wq.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/fs/io-wq.c b/fs/io-wq.c
index 12fc19353bb0..ac8604a35169 100644
--- a/fs/io-wq.c
+++ b/fs/io-wq.c
@@ -282,16 +282,24 @@ static void create_worker_cb(struct callback_head *cb)
struct io_wq *wq;
struct io_wqe *wqe;
struct io_wqe_acct *acct;
+ bool do_create = false;
cwd = container_of(cb, struct create_worker_data, work);
wqe = cwd->wqe;
wq = wqe->wq;
acct = &wqe->acct[cwd->index];
raw_spin_lock_irq(&wqe->lock);
- if (acct->nr_workers < acct->max_workers)
+ if (acct->nr_workers < acct->max_workers) {
acct->nr_workers++;
+ do_create = true;
+ }
raw_spin_unlock_irq(&wqe->lock);
- create_io_worker(wq, cwd->wqe, cwd->index);
+ if (do_create) {
+ create_io_worker(wq, cwd->wqe, cwd->index);
+ } else {
+ atomic_dec(&acct->nr_running);
+ io_worker_ref_put(wq);
+ }
kfree(cwd);
}