diff options
author | Vladimir Sementsov-Ogievskiy | 2020-03-11 11:29:59 +0100 |
---|---|---|
committer | Max Reitz | 2020-03-11 12:42:30 +0100 |
commit | 2d57511a88e71485f745ad3dc0afe03b87a8ad5e (patch) | |
tree | 5f0ff0f0907b1384ae79425e518d2934d6e860f4 /block/trace-events | |
parent | block/block-copy: specialcase first copy_range request (diff) | |
download | qemu-2d57511a88e71485f745ad3dc0afe03b87a8ad5e.tar.gz qemu-2d57511a88e71485f745ad3dc0afe03b87a8ad5e.tar.xz qemu-2d57511a88e71485f745ad3dc0afe03b87a8ad5e.zip |
block/block-copy: use block_status
Use bdrv_block_status_above to chose effective chunk size and to handle
zeroes effectively.
This substitutes checking for just being allocated or not, and drops
old code path for it. Assistance by backup job is dropped too, as
caching block-status information is more difficult than just caching
is-allocated information in our dirty bitmap, and backup job is not
good place for this caching anyway.
Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
Reviewed-by: Andrey Shinkevich <andrey.shinkevich@virtuozzo.com>
Reviewed-by: Max Reitz <mreitz@redhat.com>
Message-Id: <20200311103004.7649-5-vsementsov@virtuozzo.com>
Signed-off-by: Max Reitz <mreitz@redhat.com>
Diffstat (limited to 'block/trace-events')
-rw-r--r-- | block/trace-events | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/block/trace-events b/block/trace-events index 1a7329b736..29dff8881c 100644 --- a/block/trace-events +++ b/block/trace-events @@ -48,6 +48,7 @@ block_copy_process(void *bcs, int64_t start) "bcs %p start %"PRId64 block_copy_copy_range_fail(void *bcs, int64_t start, int ret) "bcs %p start %"PRId64" ret %d" block_copy_read_fail(void *bcs, int64_t start, int ret) "bcs %p start %"PRId64" ret %d" block_copy_write_fail(void *bcs, int64_t start, int ret) "bcs %p start %"PRId64" ret %d" +block_copy_write_zeroes_fail(void *bcs, int64_t start, int ret) "bcs %p start %"PRId64" ret %d" # ../blockdev.c qmp_block_job_cancel(void *job) "job %p" |