Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id DF7B3C433FE for ; Mon, 3 Jan 2022 08:23:44 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232155AbiACIXo (ORCPT ); Mon, 3 Jan 2022 03:23:44 -0500 Received: from verein.lst.de ([213.95.11.211]:45886 "EHLO verein.lst.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230488AbiACIXm (ORCPT ); Mon, 3 Jan 2022 03:23:42 -0500 Received: by verein.lst.de (Postfix, from userid 2407) id 7AA0C68AA6; Mon, 3 Jan 2022 09:23:38 +0100 (CET) Date: Mon, 3 Jan 2022 09:23:38 +0100 From: Christoph Hellwig To: "Maciej W. Rozycki" Cc: Khalid Aziz , "James E.J. Bottomley" , "Martin K. Petersen" , Christoph Hellwig , Nix , linux-scsi@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v3 1/3] scsi: Provide for avoiding trailing allocation length with VPD inquiries Message-ID: <20220103082338.GA28606@lst.de> References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.17 (2007-11-01) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Jan 02, 2022 at 11:23:45PM +0000, Maciej W. Rozycki wrote: > Allow SCSI hosts to request avoiding trailing allocation length with VPD > inquiries, and use the mechanism to work around an issue with at least > some BusLogic MultiMaster host bus adapters and observed with the BT-958 > model specifically where issuing commands that return less data than > provided for causes fatal failures: Wouldn't it make more sesnse to hide this quirk insde of scsi_vpd_inquiry to also handle the scsi_get_vpd_buf case? Something like: diff --git a/drivers/scsi/scsi.c b/drivers/scsi/scsi.c index 211aace69c22c..194a51f772aaa 100644 --- a/drivers/scsi/scsi.c +++ b/drivers/scsi/scsi.c @@ -289,8 +289,8 @@ EXPORT_SYMBOL(scsi_track_queue_full); * * Returns size of the vpd page on success or a negative error number. */ -static int scsi_vpd_inquiry(struct scsi_device *sdev, unsigned char *buffer, - u8 page, unsigned len) +static int __scsi_vpd_inquiry(struct scsi_device *sdev, unsigned char *buffer, + u8 page, unsigned len) { int result; unsigned char cmd[16]; @@ -321,6 +321,20 @@ static int scsi_vpd_inquiry(struct scsi_device *sdev, unsigned char *buffer, return get_unaligned_be16(&buffer[2]) + 4; } +static int scsi_vpd_inquiry(struct scsi_device *sdev, unsigned char *buffer, + u8 page, unsigned len) +{ + if (sdev->host->no_trailing_allocation_length) { + int ret = __scsi_vpd_inquiry(sdev, buffer, page, min(4U, len)); + + if (ret < 4) + return ret; + len = min_t(unsigned int, ret, len); + } + + return __scsi_vpd_inquiry(sdev, buffer, page, len); +} + /** * scsi_get_vpd_page - Get Vital Product Data from a SCSI device * @sdev: The device to ask