aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPaolo Bonzini <pbonzini@redhat.com>2012-01-12 10:01:27 -0500
committerHerton Ronaldo Krzesinski <herton.krzesinski@canonical.com>2012-02-13 15:14:56 -0500
commitd62410b9b208e15caca30e40c179a79f3ca8f96c (patch)
treee212caff427fd6882e1626024596cd18ddc27db8
parent554ca39e6694d4e3d0a70afc56efc3beca410fca (diff)
block: add and use scsi_blk_cmd_ioctl
BugLink: http://bugs.launchpad.net/bugs/922799 commit 577ebb374c78314ac4617242f509e2f5e7156649 upstream. Introduce a wrapper around scsi_cmd_ioctl that takes a block device. The function will then be enhanced to detect partition block devices and, in that case, subject the ioctls to whitelisting. Cc: linux-scsi@vger.kernel.org Cc: Jens Axboe <axboe@kernel.dk> Cc: James Bottomley <JBottomley@parallels.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-rw-r--r--block/scsi_ioctl.c7
-rw-r--r--drivers/block/cciss.c6
-rw-r--r--drivers/block/ub.c3
-rw-r--r--drivers/block/virtio_blk.c4
-rw-r--r--drivers/cdrom/cdrom.c3
-rw-r--r--drivers/ide/ide-floppy_ioctl.c3
-rw-r--r--drivers/scsi/sd.c2
-rw-r--r--include/linux/blkdev.h2
8 files changed, 18 insertions, 12 deletions
diff --git a/block/scsi_ioctl.c b/block/scsi_ioctl.c
index 4f4230b79bb..57ac9375484 100644
--- a/block/scsi_ioctl.c
+++ b/block/scsi_ioctl.c
@@ -691,6 +691,13 @@ int scsi_cmd_ioctl(struct request_queue *q, struct gendisk *bd_disk, fmode_t mod
691} 691}
692EXPORT_SYMBOL(scsi_cmd_ioctl); 692EXPORT_SYMBOL(scsi_cmd_ioctl);
693 693
694int scsi_cmd_blk_ioctl(struct block_device *bd, fmode_t mode,
695 unsigned int cmd, void __user *arg)
696{
697 return scsi_cmd_ioctl(bd->bd_disk->queue, bd->bd_disk, mode, cmd, arg);
698}
699EXPORT_SYMBOL(scsi_cmd_blk_ioctl);
700
694static int __init blk_scsi_ioctl_init(void) 701static int __init blk_scsi_ioctl_init(void)
695{ 702{
696 blk_set_cmd_filter_defaults(&blk_default_cmd_filter); 703 blk_set_cmd_filter_defaults(&blk_default_cmd_filter);
diff --git a/drivers/block/cciss.c b/drivers/block/cciss.c
index c2f9b3e3dec..1dab802d82b 100644
--- a/drivers/block/cciss.c
+++ b/drivers/block/cciss.c
@@ -1716,7 +1716,7 @@ static int cciss_ioctl(struct block_device *bdev, fmode_t mode,
1716 case CCISS_BIG_PASSTHRU: 1716 case CCISS_BIG_PASSTHRU:
1717 return cciss_bigpassthru(h, argp); 1717 return cciss_bigpassthru(h, argp);
1718 1718
1719 /* scsi_cmd_ioctl handles these, below, though some are not */ 1719 /* scsi_cmd_blk_ioctl handles these, below, though some are not */
1720 /* very meaningful for cciss. SG_IO is the main one people want. */ 1720 /* very meaningful for cciss. SG_IO is the main one people want. */
1721 1721
1722 case SG_GET_VERSION_NUM: 1722 case SG_GET_VERSION_NUM:
@@ -1727,9 +1727,9 @@ static int cciss_ioctl(struct block_device *bdev, fmode_t mode,
1727 case SG_EMULATED_HOST: 1727 case SG_EMULATED_HOST:
1728 case SG_IO: 1728 case SG_IO:
1729 case SCSI_IOCTL_SEND_COMMAND: 1729 case SCSI_IOCTL_SEND_COMMAND:
1730 return scsi_cmd_ioctl(disk->queue, disk, mode, cmd, argp); 1730 return scsi_cmd_blk_ioctl(bdev, mode, cmd, argp);
1731 1731
1732 /* scsi_cmd_ioctl would normally handle these, below, but */ 1732 /* scsi_cmd_blk_ioctl would normally handle these, below, but */
1733 /* they aren't a good fit for cciss, as CD-ROMs are */ 1733 /* they aren't a good fit for cciss, as CD-ROMs are */
1734 /* not supported, and we don't have any bus/target/lun */ 1734 /* not supported, and we don't have any bus/target/lun */
1735 /* which we present to the kernel. */ 1735 /* which we present to the kernel. */
diff --git a/drivers/block/ub.c b/drivers/block/ub.c
index 0e376d46bdd..7333b9e4441 100644
--- a/drivers/block/ub.c
+++ b/drivers/block/ub.c
@@ -1744,12 +1744,11 @@ static int ub_bd_release(struct gendisk *disk, fmode_t mode)
1744static int ub_bd_ioctl(struct block_device *bdev, fmode_t mode, 1744static int ub_bd_ioctl(struct block_device *bdev, fmode_t mode,
1745 unsigned int cmd, unsigned long arg) 1745 unsigned int cmd, unsigned long arg)
1746{ 1746{
1747 struct gendisk *disk = bdev->bd_disk;
1748 void __user *usermem = (void __user *) arg; 1747 void __user *usermem = (void __user *) arg;
1749 int ret; 1748 int ret;
1750 1749
1751 mutex_lock(&ub_mutex); 1750 mutex_lock(&ub_mutex);
1752 ret = scsi_cmd_ioctl(disk->queue, disk, mode, cmd, usermem); 1751 ret = scsi_cmd_blk_ioctl(bdev, mode, cmd, usermem);
1753 mutex_unlock(&ub_mutex); 1752 mutex_unlock(&ub_mutex);
1754 1753
1755 return ret; 1754 return ret;
diff --git a/drivers/block/virtio_blk.c b/drivers/block/virtio_blk.c
index 079c08808d8..5d7a9340363 100644
--- a/drivers/block/virtio_blk.c
+++ b/drivers/block/virtio_blk.c
@@ -236,8 +236,8 @@ static int virtblk_ioctl(struct block_device *bdev, fmode_t mode,
236 if (!virtio_has_feature(vblk->vdev, VIRTIO_BLK_F_SCSI)) 236 if (!virtio_has_feature(vblk->vdev, VIRTIO_BLK_F_SCSI))
237 return -ENOTTY; 237 return -ENOTTY;
238 238
239 return scsi_cmd_ioctl(disk->queue, disk, mode, cmd, 239 return scsi_cmd_blk_ioctl(bdev, mode, cmd,
240 (void __user *)data); 240 (void __user *)data);
241} 241}
242 242
243/* We provide getgeo only to please some old bootloader/partitioning tools */ 243/* We provide getgeo only to please some old bootloader/partitioning tools */
diff --git a/drivers/cdrom/cdrom.c b/drivers/cdrom/cdrom.c
index 79f9aea1d34..7dc70779229 100644
--- a/drivers/cdrom/cdrom.c
+++ b/drivers/cdrom/cdrom.c
@@ -2741,12 +2741,11 @@ int cdrom_ioctl(struct cdrom_device_info *cdi, struct block_device *bdev,
2741{ 2741{
2742 void __user *argp = (void __user *)arg; 2742 void __user *argp = (void __user *)arg;
2743 int ret; 2743 int ret;
2744 struct gendisk *disk = bdev->bd_disk;
2745 2744
2746 /* 2745 /*
2747 * Try the generic SCSI command ioctl's first. 2746 * Try the generic SCSI command ioctl's first.
2748 */ 2747 */
2749 ret = scsi_cmd_ioctl(disk->queue, disk, mode, cmd, argp); 2748 ret = scsi_cmd_blk_ioctl(bdev, mode, cmd, argp);
2750 if (ret != -ENOTTY) 2749 if (ret != -ENOTTY)
2751 return ret; 2750 return ret;
2752 2751
diff --git a/drivers/ide/ide-floppy_ioctl.c b/drivers/ide/ide-floppy_ioctl.c
index d267b7affad..a22ca846701 100644
--- a/drivers/ide/ide-floppy_ioctl.c
+++ b/drivers/ide/ide-floppy_ioctl.c
@@ -292,8 +292,7 @@ int ide_floppy_ioctl(ide_drive_t *drive, struct block_device *bdev,
292 * and CDROM_SEND_PACKET (legacy) ioctls 292 * and CDROM_SEND_PACKET (legacy) ioctls
293 */ 293 */
294 if (cmd != CDROM_SEND_PACKET && cmd != SCSI_IOCTL_SEND_COMMAND) 294 if (cmd != CDROM_SEND_PACKET && cmd != SCSI_IOCTL_SEND_COMMAND)
295 err = scsi_cmd_ioctl(bdev->bd_disk->queue, bdev->bd_disk, 295 err = scsi_cmd_blk_ioctl(bdev, mode, cmd, argp);
296 mode, cmd, argp);
297 296
298 if (err == -ENOTTY) 297 if (err == -ENOTTY)
299 err = generic_ide_ioctl(drive, bdev, cmd, arg); 298 err = generic_ide_ioctl(drive, bdev, cmd, arg);
diff --git a/drivers/scsi/sd.c b/drivers/scsi/sd.c
index 953773cb26d..c88885d9132 100644
--- a/drivers/scsi/sd.c
+++ b/drivers/scsi/sd.c
@@ -1095,7 +1095,7 @@ static int sd_ioctl(struct block_device *bdev, fmode_t mode,
1095 error = scsi_ioctl(sdp, cmd, p); 1095 error = scsi_ioctl(sdp, cmd, p);
1096 break; 1096 break;
1097 default: 1097 default:
1098 error = scsi_cmd_ioctl(disk->queue, disk, mode, cmd, p); 1098 error = scsi_cmd_blk_ioctl(bdev, mode, cmd, p);
1099 if (error != -ENOTTY) 1099 if (error != -ENOTTY)
1100 break; 1100 break;
1101 error = scsi_ioctl(sdp, cmd, p); 1101 error = scsi_ioctl(sdp, cmd, p);
diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h
index cd93f9994ad..0eca8080bb6 100644
--- a/include/linux/blkdev.h
+++ b/include/linux/blkdev.h
@@ -670,6 +670,8 @@ extern int blk_insert_cloned_request(struct request_queue *q,
670 struct request *rq); 670 struct request *rq);
671extern void blk_delay_queue(struct request_queue *, unsigned long); 671extern void blk_delay_queue(struct request_queue *, unsigned long);
672extern void blk_recount_segments(struct request_queue *, struct bio *); 672extern void blk_recount_segments(struct request_queue *, struct bio *);
673extern int scsi_cmd_blk_ioctl(struct block_device *, fmode_t,
674 unsigned int, void __user *);
673extern int scsi_cmd_ioctl(struct request_queue *, struct gendisk *, fmode_t, 675extern int scsi_cmd_ioctl(struct request_queue *, struct gendisk *, fmode_t,
674 unsigned int, void __user *); 676 unsigned int, void __user *);
675extern int sg_scsi_ioctl(struct request_queue *, struct gendisk *, fmode_t, 677extern int sg_scsi_ioctl(struct request_queue *, struct gendisk *, fmode_t,