diff options
author | Kai Krakow <kai@kaishome.de> | 2021-02-10 13:07:26 +0800 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2021-02-10 08:06:00 -0700 |
commit | d797bd9897e3559eb48d68368550d637d32e468c (patch) | |
tree | df5199bc36b52f447d6677b3cb3796c1a2c91d79 /drivers/md/bcache/btree.c | |
parent | 9f233ffe02e5cef611100cd8c5bcf4de26ca7bef (diff) | |
download | lwn-d797bd9897e3559eb48d68368550d637d32e468c.tar.gz lwn-d797bd9897e3559eb48d68368550d637d32e468c.zip |
bcache: Give btree_io_wq correct semantics again
Before killing `btree_io_wq`, the queue was allocated using
`create_singlethread_workqueue()` which has `WQ_MEM_RECLAIM`. After
killing it, it no longer had this property but `system_wq` is not
single threaded.
Let's combine both worlds and make it multi threaded but able to
reclaim memory.
Cc: Coly Li <colyli@suse.de>
Cc: stable@vger.kernel.org # 5.4+
Signed-off-by: Kai Krakow <kai@kaishome.de>
Signed-off-by: Coly Li <colyli@suse.de>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'drivers/md/bcache/btree.c')
-rw-r--r-- | drivers/md/bcache/btree.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/md/bcache/btree.c b/drivers/md/bcache/btree.c index 952f022db5a5..fe6dce125aba 100644 --- a/drivers/md/bcache/btree.c +++ b/drivers/md/bcache/btree.c @@ -2775,7 +2775,7 @@ void bch_btree_exit(void) int __init bch_btree_init(void) { - btree_io_wq = create_singlethread_workqueue("bch_btree_io"); + btree_io_wq = alloc_workqueue("bch_btree_io", WQ_MEM_RECLAIM, 0); if (!btree_io_wq) return -ENOMEM; |