Commit 6a81749e authored by Jeff Layton's avatar Jeff Layton Committed by Ilya Dryomov

ceph: increment/decrement dio counter on async requests

Ceph can in some cases issue an async DIO request, in which case we can
end up calling ceph_end_io_direct before the I/O is actually complete.
That may allow buffered operations to proceed while DIO requests are
still in flight.

Fix this by incrementing the i_dio_count when issuing an async DIO
request, and decrement it when tearing down the aio_req.

Fixes: 321fe13c ("ceph: add buffered/direct exclusionary locking for reads and writes")
Signed-off-by: default avatarJeff Layton <jlayton@kernel.org>
Signed-off-by: default avatarIlya Dryomov <idryomov@gmail.com>
parent a81bc310
...@@ -753,6 +753,9 @@ static void ceph_aio_complete(struct inode *inode, ...@@ -753,6 +753,9 @@ static void ceph_aio_complete(struct inode *inode,
if (!atomic_dec_and_test(&aio_req->pending_reqs)) if (!atomic_dec_and_test(&aio_req->pending_reqs))
return; return;
if (aio_req->iocb->ki_flags & IOCB_DIRECT)
inode_dio_end(inode);
ret = aio_req->error; ret = aio_req->error;
if (!ret) if (!ret)
ret = aio_req->total_len; ret = aio_req->total_len;
...@@ -1091,6 +1094,7 @@ ceph_direct_read_write(struct kiocb *iocb, struct iov_iter *iter, ...@@ -1091,6 +1094,7 @@ ceph_direct_read_write(struct kiocb *iocb, struct iov_iter *iter,
CEPH_CAP_FILE_RD); CEPH_CAP_FILE_RD);
list_splice(&aio_req->osd_reqs, &osd_reqs); list_splice(&aio_req->osd_reqs, &osd_reqs);
inode_dio_begin(inode);
while (!list_empty(&osd_reqs)) { while (!list_empty(&osd_reqs)) {
req = list_first_entry(&osd_reqs, req = list_first_entry(&osd_reqs,
struct ceph_osd_request, struct ceph_osd_request,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment