OSDN Git Service

dm: make sure to obey max_io_len_target_boundary
authorMichael Lass <bevan@bi-co.net>
Tue, 21 May 2019 19:58:07 +0000 (21:58 +0200)
committerMike Snitzer <snitzer@redhat.com>
Tue, 21 May 2019 23:15:20 +0000 (19:15 -0400)
commit51b86f9a8d1c4bb4e3862ee4b4c5f46072f7520d
tree3a37a21670c6d37acacda2de65022d4671dd35d6
parent8454fca4f53bbe5e0a71613192674c8ce5c52318
dm: make sure to obey max_io_len_target_boundary

Commit 61697a6abd24 ("dm: eliminate 'split_discard_bios' flag from DM
target interface") incorrectly removed code from
__send_changing_extent_only() that is required to impose a per-target IO
boundary on IO that exceeds max_io_len_target_boundary().  Otherwise
"special" IO (e.g. DISCARD, WRITE SAME, WRITE ZEROES) can write beyond
where allowed.

Fix this by restoring the max_io_len_target_boundary() limit in
__send_changing_extent_only()

Fixes: 61697a6abd24 ("dm: eliminate 'split_discard_bios' flag from DM target interface")
Cc: stable@vger.kernel.org # 5.1+
Signed-off-by: Michael Lass <bevan@bi-co.net>
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
drivers/md/dm.c