Lines Matching refs:dio

296 	struct blkdev_dio *dio = bio->bi_private;  in blkdev_bio_end_io()  local
297 bool should_dirty = dio->should_dirty; in blkdev_bio_end_io()
299 if (bio->bi_status && !dio->bio.bi_status) in blkdev_bio_end_io()
300 dio->bio.bi_status = bio->bi_status; in blkdev_bio_end_io()
302 if (!dio->multi_bio || atomic_dec_and_test(&dio->ref)) { in blkdev_bio_end_io()
303 if (!dio->is_sync) { in blkdev_bio_end_io()
304 struct kiocb *iocb = dio->iocb; in blkdev_bio_end_io()
307 if (likely(!dio->bio.bi_status)) { in blkdev_bio_end_io()
308 ret = dio->size; in blkdev_bio_end_io()
311 ret = blk_status_to_errno(dio->bio.bi_status); in blkdev_bio_end_io()
314 dio->iocb->ki_complete(iocb, ret, 0); in blkdev_bio_end_io()
315 bio_put(&dio->bio); in blkdev_bio_end_io()
317 struct task_struct *waiter = dio->waiter; in blkdev_bio_end_io()
319 WRITE_ONCE(dio->waiter, NULL); in blkdev_bio_end_io()
343 struct blkdev_dio *dio; in __blkdev_direct_IO() local
357 dio = container_of(bio, struct blkdev_dio, bio); in __blkdev_direct_IO()
358 dio->is_sync = is_sync = is_sync_kiocb(iocb); in __blkdev_direct_IO()
359 if (dio->is_sync) in __blkdev_direct_IO()
360 dio->waiter = current; in __blkdev_direct_IO()
362 dio->iocb = iocb; in __blkdev_direct_IO()
364 dio->size = 0; in __blkdev_direct_IO()
365 dio->multi_bio = false; in __blkdev_direct_IO()
366 dio->should_dirty = is_read && (iter->type == ITER_IOVEC); in __blkdev_direct_IO()
373 bio->bi_private = dio; in __blkdev_direct_IO()
386 if (dio->should_dirty) in __blkdev_direct_IO()
393 dio->size += bio->bi_iter.bi_size; in __blkdev_direct_IO()
402 if (!dio->multi_bio) { in __blkdev_direct_IO()
403 dio->multi_bio = true; in __blkdev_direct_IO()
404 atomic_set(&dio->ref, 2); in __blkdev_direct_IO()
406 atomic_inc(&dio->ref); in __blkdev_direct_IO()
419 if (!READ_ONCE(dio->waiter)) in __blkdev_direct_IO()
429 ret = blk_status_to_errno(dio->bio.bi_status); in __blkdev_direct_IO()
431 ret = dio->size; in __blkdev_direct_IO()
433 bio_put(&dio->bio); in __blkdev_direct_IO()