* [PATCH v2] block: silently forbid sending any ioctl to a partition
@ 2018-01-10 15:54 Paolo Bonzini
2018-01-10 16:54 ` Christoph Hellwig
2018-01-10 19:30 ` Jens Axboe
0 siblings, 2 replies; 3+ messages in thread
From: Paolo Bonzini @ 2018-01-10 15:54 UTC (permalink / raw)
To: linux-kernel, linux-block; +Cc: Jens Axboe, hch
After the first few months, the message has not led to many bug reports.
It's been almost five years now, and in practice the main source of
it seems to be MTIOCGET that someone is using to detect tape devices.
While we could whitelist it just like CDROM_GET_CAPABILITY, this patch
just removes the message altogether.
The patch also removes the "safe but not very useful" ioctl whitelist,
as suggested by Christoph. I doubt anything is using most of those
ioctls _in general_, let alone on a partition.
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
---
v1->v2: disable the legacy ioctls too, hence changing the patch subject
block/scsi_ioctl.c | 29 -----------------------------
1 file changed, 29 deletions(-)
diff --git a/block/scsi_ioctl.c b/block/scsi_ioctl.c
index edcfff974527..07988eebb66a 100644
--- a/block/scsi_ioctl.c
+++ b/block/scsi_ioctl.c
@@ -692,38 +692,9 @@ int scsi_verify_blk_ioctl(struct block_device *bd, unsigned int cmd)
if (bd && bd == bd->bd_contains)
return 0;
- /* Actually none of these is particularly useful on a partition,
- * but they are safe.
- */
- switch (cmd) {
- case SCSI_IOCTL_GET_IDLUN:
- case SCSI_IOCTL_GET_BUS_NUMBER:
- case SCSI_IOCTL_GET_PCI:
- case SCSI_IOCTL_PROBE_HOST:
- case SG_GET_VERSION_NUM:
- case SG_SET_TIMEOUT:
- case SG_GET_TIMEOUT:
- case SG_GET_RESERVED_SIZE:
- case SG_SET_RESERVED_SIZE:
- case SG_EMULATED_HOST:
- return 0;
- case CDROM_GET_CAPABILITY:
- /* Keep this until we remove the printk below. udev sends it
- * and we do not want to spam dmesg about it. CD-ROMs do
- * not have partitions, so we get here only for disks.
- */
- return -ENOIOCTLCMD;
- default:
- break;
- }
-
if (capable(CAP_SYS_RAWIO))
return 0;
- /* In particular, rule out all resets and host-specific ioctls. */
- printk_ratelimited(KERN_WARNING
- "%s: sending ioctl %x to a partition!\n", current->comm, cmd);
-
return -ENOIOCTLCMD;
}
EXPORT_SYMBOL(scsi_verify_blk_ioctl);
--
2.14.3
^ permalink raw reply related [flat|nested] 3+ messages in thread* Re: [PATCH v2] block: silently forbid sending any ioctl to a partition
2018-01-10 15:54 [PATCH v2] block: silently forbid sending any ioctl to a partition Paolo Bonzini
@ 2018-01-10 16:54 ` Christoph Hellwig
2018-01-10 19:30 ` Jens Axboe
1 sibling, 0 replies; 3+ messages in thread
From: Christoph Hellwig @ 2018-01-10 16:54 UTC (permalink / raw)
To: Paolo Bonzini; +Cc: linux-kernel, linux-block, Jens Axboe, hch
On Wed, Jan 10, 2018 at 04:54:52PM +0100, Paolo Bonzini wrote:
> After the first few months, the message has not led to many bug reports.
> It's been almost five years now, and in practice the main source of
> it seems to be MTIOCGET that someone is using to detect tape devices.
> While we could whitelist it just like CDROM_GET_CAPABILITY, this patch
> just removes the message altogether.
>
> The patch also removes the "safe but not very useful" ioctl whitelist,
> as suggested by Christoph. I doubt anything is using most of those
> ioctls _in general_, let alone on a partition.
>
> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Nice, thanks!
Reviewed-by: Christoph Hellwig <hch@lst.de>
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH v2] block: silently forbid sending any ioctl to a partition
2018-01-10 15:54 [PATCH v2] block: silently forbid sending any ioctl to a partition Paolo Bonzini
2018-01-10 16:54 ` Christoph Hellwig
@ 2018-01-10 19:30 ` Jens Axboe
1 sibling, 0 replies; 3+ messages in thread
From: Jens Axboe @ 2018-01-10 19:30 UTC (permalink / raw)
To: Paolo Bonzini, linux-kernel, linux-block; +Cc: hch
On 1/10/18 8:54 AM, Paolo Bonzini wrote:
> After the first few months, the message has not led to many bug reports.
> It's been almost five years now, and in practice the main source of
> it seems to be MTIOCGET that someone is using to detect tape devices.
> While we could whitelist it just like CDROM_GET_CAPABILITY, this patch
> just removes the message altogether.
>
> The patch also removes the "safe but not very useful" ioctl whitelist,
> as suggested by Christoph. I doubt anything is using most of those
> ioctls _in general_, let alone on a partition.
Applied, thanks.
--
Jens Axboe
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2018-01-10 19:30 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-01-10 15:54 [PATCH v2] block: silently forbid sending any ioctl to a partition Paolo Bonzini
2018-01-10 16:54 ` Christoph Hellwig
2018-01-10 19:30 ` Jens Axboe
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).