|
@@ -2196,7 +2196,8 @@ static int narrow_write_error(struct r1bio *r1_bio, int i)
|
|
if (rdev->badblocks.shift < 0)
|
|
if (rdev->badblocks.shift < 0)
|
|
return 0;
|
|
return 0;
|
|
|
|
|
|
- block_sectors = 1 << rdev->badblocks.shift;
|
|
|
|
|
|
+ block_sectors = roundup(1 << rdev->badblocks.shift,
|
|
|
|
+ bdev_logical_block_size(rdev->bdev) >> 9);
|
|
sector = r1_bio->sector;
|
|
sector = r1_bio->sector;
|
|
sectors = ((sector + block_sectors)
|
|
sectors = ((sector + block_sectors)
|
|
& ~(sector_t)(block_sectors - 1))
|
|
& ~(sector_t)(block_sectors - 1))
|