diff options
author | Eric Blake <eblake@redhat.com> | 2018-06-11 16:39:26 -0500 |
---|---|---|
committer | Kevin Wolf <kwolf@redhat.com> | 2018-06-15 14:49:44 +0200 |
commit | e0b371ed5e2db079051139136fd0478728b6a58f (patch) | |
tree | 6ce6bc328bbd0222525d2ac7ad2b483aabada360 /tests | |
parent | 91fe7a376ad46e3cc5e82d418aad22173c948a3c (diff) | |
download | qemu-e0b371ed5e2db079051139136fd0478728b6a58f.zip qemu-e0b371ed5e2db079051139136fd0478728b6a58f.tar.gz qemu-e0b371ed5e2db079051139136fd0478728b6a58f.tar.bz2 |
qemu-img: Fix assert when mapping unaligned raw file
Commit a290f085 exposed a latent bug in qemu-img map introduced
during the conversion of block status to be byte-based. Earlier in
commit 5e344dd8, the internal interface get_block_status() switched
to take byte-based parameters, but still called a sector-based
block layer function; as such, rounding was added in the lone
caller to obey the contract. However, commit 237d78f8 changed
get_block_status() to truly be byte-based, at which point rounding
to sector boundaries can result in calling bdrv_block_status() with
'bytes == 0' (a coding error) when the boundary between data and a
hole falls mid-sector (true for the past-EOF implicit hole present
in POSIX files). Fix things by removing the rounding that is now
no longer necessary.
See also https://bugzilla.redhat.com/1589738
Fixes: 237d78f8
Reported-by: Dan Kenigsberg <danken@redhat.com>
Reported-by: Nir Soffer <nsoffer@redhat.com>
Reported-by: Maor Lipchuk <mlipchuk@redhat.com>
CC: qemu-stable@nongnu.org
Signed-off-by: Eric Blake <eblake@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
Diffstat (limited to 'tests')
0 files changed, 0 insertions, 0 deletions