From: Christoph Hellwig <hch@lst.de>
To: Boaz Harrosh <openosd@gmail.com>
Cc: Christoph Hellwig <hch@lst.de>, Jens Axboe <axboe@kernel.dk>,
linux-scsi@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH 2/2] block: support > 16 byte CDBs for SG_IO
Date: Sun, 20 Jul 2014 15:27:25 +0200 [thread overview]
Message-ID: <20140720132725.GA7077@lst.de> (raw)
In-Reply-To: <53CBAC65.2040208@gmail.com>
On Sun, Jul 20, 2014 at 02:47:49PM +0300, Boaz Harrosh wrote:
>
> So two things here:
> - hdr->cmd_len is char so can be MAX of 255. I understand that 4 bytes alignment is a SCSI
> thing so you found no point of checking any max size?
I don't see any point to force the aligmnet - the devices need to reject
garbage commands, and if for some reason we'd see future commands
that are > 252 and < 255 we are prepared to handle them.
> - Why the zero alloc, if you are going to paste over it the exact same length. Now if like in scsi
> you need 4 bytes alignment and zero padding yes, but here you do not do this (and probably shouldn't).
> Hence why zero-alloc?
No good reason except that's what sg and bsg do.
> - Looking at sg.h where hdr->cmd_len is defined it stills has a comment of <= 16 you might want to
> remove the comment by now.
The sg changes to support > 16 byte CDs remove the comment, take a look at my
core-for-3.17 tree which has them applied.
> Inside here: blk_fill_sghdr_rq() calls blk_verify_command() which does:
> (Below cmd[] is the buffer copied from user)
>
> /* Anybody who can open the device can do a read-safe command */
> if (test_bit(cmd[0], filter->read_ok))
> return 0;
>
> /* Write-safe commands require a writable open */
> if (test_bit(cmd[0], filter->write_ok) && has_write_perm)
> return 0;
>
> Now I am not sure what type "Commands" you guys intend for these large commands
> but if they are say SCSI-VARLEN this test will not work. Also a user might fool
> the system with pretending to be "read" a device modifying command.
>
> I would pass len to this test function and only permit these above if command is
> <= 16. Any "special" large command is root only.
Honestly that whole filter crap should never have been merged to start with,
you'll just need proper CAP_SYS_RAWIO for variable length commands.
next prev parent reply other threads:[~2014-07-20 13:27 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-07-20 10:23 support > 16 byte CDBs for blocklayer SG_IO Christoph Hellwig
2014-07-20 10:23 ` [PATCH 1/2] block: cleanup error handling in sg_io Christoph Hellwig
2014-07-20 10:23 ` [PATCH 2/2] block: support > 16 byte CDBs for SG_IO Christoph Hellwig
2014-07-20 11:47 ` Boaz Harrosh
2014-07-20 13:27 ` Christoph Hellwig [this message]
2014-07-20 16:45 ` Boaz Harrosh
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20140720132725.GA7077@lst.de \
--to=hch@lst.de \
--cc=axboe@kernel.dk \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-scsi@vger.kernel.org \
--cc=openosd@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.