diff options
Diffstat (limited to 'drivers/md/dm-flakey.c')
-rw-r--r-- | drivers/md/dm-flakey.c | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/drivers/md/dm-flakey.c b/drivers/md/dm-flakey.c index f84c08029b21..9fb18c147825 100644 --- a/drivers/md/dm-flakey.c +++ b/drivers/md/dm-flakey.c | |||
@@ -368,8 +368,17 @@ static int flakey_status(struct dm_target *ti, status_type_t type, | |||
368 | static int flakey_ioctl(struct dm_target *ti, unsigned int cmd, unsigned long arg) | 368 | static int flakey_ioctl(struct dm_target *ti, unsigned int cmd, unsigned long arg) |
369 | { | 369 | { |
370 | struct flakey_c *fc = ti->private; | 370 | struct flakey_c *fc = ti->private; |
371 | struct dm_dev *dev = fc->dev; | ||
372 | int r = 0; | ||
371 | 373 | ||
372 | return __blkdev_driver_ioctl(fc->dev->bdev, fc->dev->mode, cmd, arg); | 374 | /* |
375 | * Only pass ioctls through if the device sizes match exactly. | ||
376 | */ | ||
377 | if (fc->start || | ||
378 | ti->len != i_size_read(dev->bdev->bd_inode) >> SECTOR_SHIFT) | ||
379 | r = scsi_verify_blk_ioctl(NULL, cmd); | ||
380 | |||
381 | return r ? : __blkdev_driver_ioctl(dev->bdev, dev->mode, cmd, arg); | ||
373 | } | 382 | } |
374 | 383 | ||
375 | static int flakey_merge(struct dm_target *ti, struct bvec_merge_data *bvm, | 384 | static int flakey_merge(struct dm_target *ti, struct bvec_merge_data *bvm, |