From mboxrd@z Thu Jan 1 00:00:00 1970 From: "J . Bruce Fields" Subject: Re: [PATCH 05/18] nfsd: Check private request size before submitting a SCSI request Date: Fri, 19 May 2017 15:03:14 -0400 Message-ID: <20170519190314.GA25811@fieldses.org> References: <20170519183016.12646-1-bart.vanassche@sandisk.com> <20170519183016.12646-6-bart.vanassche@sandisk.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Return-path: Content-Disposition: inline In-Reply-To: <20170519183016.12646-6-bart.vanassche@sandisk.com> Sender: linux-block-owner@vger.kernel.org To: Bart Van Assche Cc: "Martin K . Petersen" , James Bottomley , linux-scsi@vger.kernel.org, Jeff Layton , Jens Axboe , Christoph Hellwig , Omar Sandoval , Hannes Reinecke , linux-nfs@vger.kernel.org, linux-block@vger.kernel.org List-Id: linux-scsi@vger.kernel.org ACK as far as I'm concerned.--b. On Fri, May 19, 2017 at 11:30:03AM -0700, Bart Van Assche wrote: > Since using scsi_req() is only allowed against request queues for which > struct scsi_request is the first member of their private request > data, refuse to register block layer queues for which the private > data is smaller than struct scsi_request. > > References: commit 82ed4db499b8 ("block: split scsi_request out of struct request") > Signed-off-by: Bart Van Assche > Cc: J. Bruce Fields > Cc: Jeff Layton > Cc: Jens Axboe > Cc: Christoph Hellwig > Cc: Omar Sandoval > Cc: Hannes Reinecke > Cc: linux-nfs@vger.kernel.org > Cc: linux-block@vger.kernel.org > --- > fs/nfsd/blocklayout.c | 3 +++ > 1 file changed, 3 insertions(+) > > diff --git a/fs/nfsd/blocklayout.c b/fs/nfsd/blocklayout.c > index fb5213afc854..90d1df31491b 100644 > --- a/fs/nfsd/blocklayout.c > +++ b/fs/nfsd/blocklayout.c > @@ -219,6 +219,9 @@ static int nfsd4_scsi_identify_device(struct block_device *bdev, > u8 *buf, *d, type, assoc; > int error; > > + if (WARN_ON_ONCE(blk_queue_cmd_size(q) < sizeof(struct scsi_request))) > + return -EINVAL; > + > buf = kzalloc(bufflen, GFP_KERNEL); > if (!buf) > return -ENOMEM; > -- > 2.12.2