diff options
| author | Heinz Mauelshagen <[email protected]> | 2014-10-17 13:38:50 +0200 | 
|---|---|---|
| committer | Mike Snitzer <[email protected]> | 2014-10-21 09:32:15 -0400 | 
| commit | 40d43c4b4cac4c2647bf07110d7b07d35f399a84 (patch) | |
| tree | c26181aac74dff7571e4c444c957ca8a8ccca9ae /scripts/gdb/linux/device.py | |
| parent | 9d28eb12447ee08bb5d1e8bb3195cf20e1ecd1c0 (diff) | |
dm raid: ensure superblock's size matches device's logical block size
The dm-raid superblock (struct dm_raid_superblock) is padded to 512
bytes and that size is being used to read it in from the metadata
device into one preallocated page.
Reading or writing this on a 512-byte sector device works fine but on
a 4096-byte sector device this fails.
Set the dm-raid superblock's size to the logical block size of the
metadata device, because IO at that size is guaranteed too work.  Also
add a size check to avoid silent partial metadata loss in case the
superblock should ever grow past the logical block size or PAGE_SIZE.
[includes pointer math fix from Dan Carpenter]
Reported-by: "Liuhua Wang" <[email protected]>
Signed-off-by: Heinz Mauelshagen <[email protected]>
Signed-off-by: Dan Carpenter <[email protected]>
Signed-off-by: Mike Snitzer <[email protected]>
Cc: [email protected]
Diffstat (limited to 'scripts/gdb/linux/device.py')
0 files changed, 0 insertions, 0 deletions