summaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2015-02-16 14:51:54 +1100
committerNeilBrown <neilb@suse.de>2015-02-16 14:51:54 +1100
commitf04ebb0be74283b32f539c7f6b84d5cfcaa0ead3 (patch)
treeb8eff05bdce7486f714d871436a419e68739dacf /drivers
parentab713cdc6f70da62c254c4acf77a0cfcda87b7f5 (diff)
downloadlinux-f04ebb0be74283b32f539c7f6b84d5cfcaa0ead3.tar.gz
linux-f04ebb0be74283b32f539c7f6b84d5cfcaa0ead3.tar.bz2
linux-f04ebb0be74283b32f539c7f6b84d5cfcaa0ead3.zip
md/raid10: round up to bdev_logical_block_size in narrow_write_error.
RAID10 version of earlier fix for RAID1. We must never initiate IO with sizes less that logical_block_size. Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/md/raid10.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/md/raid10.c b/drivers/md/raid10.c
index b8d76b1fba64..a7196c49d15d 100644
--- a/drivers/md/raid10.c
+++ b/drivers/md/raid10.c
@@ -2572,7 +2572,8 @@ static int narrow_write_error(struct r10bio *r10_bio, int i)
if (rdev->badblocks.shift < 0)
return 0;
- block_sectors = 1 << rdev->badblocks.shift;
+ block_sectors = roundup(1 << rdev->badblocks.shift,
+ bdev_logical_block_size(rdev->bdev) >> 9);
sector = r10_bio->sector;
sectors = ((r10_bio->sector + block_sectors)
& ~(sector_t)(block_sectors - 1))