summary refs log tree commit diff stats
path: root/results/classifier/accel-gemma3:12b/kvm/1460
blob: dcf6aea3f1c7437cbb48d49b8a592e56411d26bf (plain) (blame)
1
2
3
4
5
6
block_load fails if last block is included in snapshot and block device isn't multiple of BLK_MIG_BLOCK_SIZE
Description of problem:
The `block_load` function in `migration/block.c` has a bug where `blk_pwrite` or `blk_pwrite_zeroes` always write `cluster_size` bytes. If the underlying device is not a multiple of `BLK_MIG_BLOCK_SIZE`, the write will fail with -EIO when trying to write past the end of the device, as `blk_check_byte_request` checks the length of the device.

This can be fixed by ensuring that `cur_addr` + write length passed to `blk_pwrite`/`blk_pwrite_zeroes` never exceeds the total length of the block device.