summary refs log tree commit diff stats
path: root/results/scraper/gitlab/issues_text/target_missing/host_missing/accel_missing/1460
blob: fe07e0d508a879cfd89422ee2ed6e4df6a2a5e8d (plain) (blame)
1
2
3
4
5
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.