dm integrity: allow unaligned bv_offset
authorMikulas Patocka <[email protected]>
Tue, 7 Nov 2017 15:40:40 +0000 (10:40 -0500)
committerMike Snitzer <[email protected]>
Fri, 10 Nov 2017 20:44:59 +0000 (15:44 -0500)
commit95b1369a9638cfa322ad1c0cde8efbe524059884
tree2a2e8cc8d4add04b7ffefa615e6d9c2ad4b6a2c5
parent0440d5c0ca9744b92a07aeb6df0a9a75db6f4280
dm integrity: allow unaligned bv_offset

When slub_debug is enabled kmalloc returns unaligned memory. XFS uses
this unaligned memory for its buffers (if an unaligned buffer crosses a
page, XFS frees it and allocates a full page instead - see the function
xfs_buf_allocate_memory).

dm-integrity checks if bv_offset is aligned on page size and this check
fail with slub_debug and XFS.

Fix this bug by removing the bv_offset check, leaving only the check for
bv_len.

Fixes: 7eada909bfd7 ("dm: add integrity target")
Cc: [email protected] # v4.12+
Reported-by: Bruno PrĂ©mont <[email protected]>
Reviewed-by: Milan Broz <[email protected]>
Signed-off-by: Mikulas Patocka <[email protected]>
Signed-off-by: Mike Snitzer <[email protected]>
drivers/md/dm-integrity.c