[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PULL 22/24] block: Use common req handling in copy offload
From: |
Kevin Wolf |
Subject: |
[Qemu-devel] [PULL 22/24] block: Use common req handling in copy offloading |
Date: |
Tue, 10 Jul 2018 17:43:02 +0200 |
From: Fam Zheng <address@hidden>
This brings the request handling logic inline with write and discard,
fixing write_gen, resize_cb, dirty bitmaps and image size refreshing.
The last of these issues broke iotest case 222, which is now fixed.
Signed-off-by: Fam Zheng <address@hidden>
Signed-off-by: Kevin Wolf <address@hidden>
---
block/io.c | 24 ++++++++++--------------
1 file changed, 10 insertions(+), 14 deletions(-)
diff --git a/block/io.c b/block/io.c
index 72cfd9bd16..2832214db4 100644
--- a/block/io.c
+++ b/block/io.c
@@ -3030,20 +3030,16 @@ static int coroutine_fn bdrv_co_copy_range_internal(
bdrv_inc_in_flight(dst->bs);
tracked_request_begin(&req, dst->bs, dst_offset, bytes,
BDRV_TRACKED_WRITE);
-
- /* BDRV_REQ_NO_SERIALISING is only for read operation */
- assert(!(write_flags & BDRV_REQ_NO_SERIALISING));
- if (write_flags & BDRV_REQ_SERIALISING) {
- mark_request_serialising(&req, bdrv_get_cluster_size(dst->bs));
- }
- wait_serialising_requests(&req);
-
- ret = dst->bs->drv->bdrv_co_copy_range_to(dst->bs,
- src, src_offset,
- dst, dst_offset,
- bytes,
- read_flags, write_flags);
-
+ ret = bdrv_co_write_req_prepare(dst, dst_offset, bytes, &req,
+ write_flags);
+ if (!ret) {
+ ret = dst->bs->drv->bdrv_co_copy_range_to(dst->bs,
+ src, src_offset,
+ dst, dst_offset,
+ bytes,
+ read_flags, write_flags);
+ }
+ bdrv_co_write_req_finish(dst, dst_offset, bytes, &req, ret);
tracked_request_end(&req);
bdrv_dec_in_flight(dst->bs);
}
--
2.13.6
- [Qemu-devel] [PULL 10/24] block/blklogwrites: Make sure the log sector size is not too small, (continued)
- [Qemu-devel] [PULL 10/24] block/blklogwrites: Make sure the log sector size is not too small, Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 06/24] block: split flags in copy_range, Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 09/24] qapi/block-core.json: Add missing documentation for blklogwrites log-append option, Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 11/24] Revert "block: Remove dead deprecation warning code", Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 15/24] block: Prefix file driver trace points with "file_", Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 13/24] Revert "block: Remove deprecated -drive option addr", Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 12/24] Revert "block: Remove deprecated -drive option serial", Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 16/24] block: Add copy offloading trace points, Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 14/24] Revert "block: Remove deprecated -drive geometry options", Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 18/24] block: Use uint64_t for BdrvTrackedRequest byte fields, Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 22/24] block: Use common req handling in copy offloading,
Kevin Wolf <=
- [Qemu-devel] [PULL 21/24] block: Use common req handling for discard, Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 19/24] block: Extract common write req handling, Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 20/24] block: Fix handling of image enlarging write, Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 23/24] block: Fix bdrv_co_truncate overlap check, Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 17/24] block: Use BdrvChild to discard, Kevin Wolf, 2018/07/10
- [Qemu-devel] [PULL 24/24] block: Use common write req handling in truncate, Kevin Wolf, 2018/07/10
- Re: [Qemu-devel] [PULL 00/24] Block layer patches, Peter Maydell, 2018/07/10