|
@@ -589,6 +589,14 @@ static int mmc_blk_ioctl_cmd(struct block_device *bdev,
|
|
|
struct mmc_card *card;
|
|
|
int err = 0, ioc_err = 0;
|
|
|
|
|
|
+ /*
|
|
|
+ * The caller must have CAP_SYS_RAWIO, and must be calling this on the
|
|
|
+ * whole block device, not on a partition. This prevents overspray
|
|
|
+ * between sibling partitions.
|
|
|
+ */
|
|
|
+ if ((!capable(CAP_SYS_RAWIO)) || (bdev != bdev->bd_contains))
|
|
|
+ return -EPERM;
|
|
|
+
|
|
|
idata = mmc_blk_ioctl_copy_from_user(ic_ptr);
|
|
|
if (IS_ERR(idata))
|
|
|
return PTR_ERR(idata);
|
|
@@ -631,6 +639,14 @@ static int mmc_blk_ioctl_multi_cmd(struct block_device *bdev,
|
|
|
int i, err = 0, ioc_err = 0;
|
|
|
__u64 num_of_cmds;
|
|
|
|
|
|
+ /*
|
|
|
+ * The caller must have CAP_SYS_RAWIO, and must be calling this on the
|
|
|
+ * whole block device, not on a partition. This prevents overspray
|
|
|
+ * between sibling partitions.
|
|
|
+ */
|
|
|
+ if ((!capable(CAP_SYS_RAWIO)) || (bdev != bdev->bd_contains))
|
|
|
+ return -EPERM;
|
|
|
+
|
|
|
if (copy_from_user(&num_of_cmds, &user->num_of_cmds,
|
|
|
sizeof(num_of_cmds)))
|
|
|
return -EFAULT;
|
|
@@ -688,14 +704,6 @@ cmd_err:
|
|
|
static int mmc_blk_ioctl(struct block_device *bdev, fmode_t mode,
|
|
|
unsigned int cmd, unsigned long arg)
|
|
|
{
|
|
|
- /*
|
|
|
- * The caller must have CAP_SYS_RAWIO, and must be calling this on the
|
|
|
- * whole block device, not on a partition. This prevents overspray
|
|
|
- * between sibling partitions.
|
|
|
- */
|
|
|
- if ((!capable(CAP_SYS_RAWIO)) || (bdev != bdev->bd_contains))
|
|
|
- return -EPERM;
|
|
|
-
|
|
|
switch (cmd) {
|
|
|
case MMC_IOC_CMD:
|
|
|
return mmc_blk_ioctl_cmd(bdev,
|