OSDN Git Service

io-wq: handle hashed writes in chains
authorPavel Begunkov <asml.silence@gmail.com>
Mon, 23 Mar 2020 19:57:22 +0000 (22:57 +0300)
committerJens Axboe <axboe@kernel.dk>
Mon, 23 Mar 2020 20:58:07 +0000 (14:58 -0600)
commit86f3cd1b589a10dbdca98c52cc0cd0f56523c9b3
treec615dbf8ddd14c1770a082be365483be975c0a39
parenta5318d3cdffbecf075928363d7e4becfeddabfcb
io-wq: handle hashed writes in chains

We always punt async buffered writes to an io-wq helper, as the core
kernel does not have IOCB_NOWAIT support for that. Most buffered async
writes complete very quickly, as it's just a copy operation. This means
that doing multiple locking roundtrips on the shared wqe lock for each
buffered write is wasteful. Additionally, buffered writes are hashed
work items, which means that any buffered write to a given file is
serialized.

Keep identicaly hashed work items contiguously in @wqe->work_list, and
track a tail for each hash bucket. On dequeue of a hashed item, splice
all of the same hash in one go using the tracked tail. Until the batch
is done, the caller doesn't have to synchronize with the wqe or worker
locks again.

Signed-off-by: Pavel Begunkov <asml.silence@gmail.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
fs/io-wq.c
fs/io-wq.h