aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/md/dm-flakey.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/md/dm-flakey.c')
-rw-r--r--drivers/md/dm-flakey.c11
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,
368static int flakey_ioctl(struct dm_target *ti, unsigned int cmd, unsigned long arg) 368static 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
375static int flakey_merge(struct dm_target *ti, struct bvec_merge_data *bvm, 384static int flakey_merge(struct dm_target *ti, struct bvec_merge_data *bvm,