Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp641099img; Fri, 22 Mar 2019 05:44:26 -0700 (PDT) X-Google-Smtp-Source: APXvYqy2/OeCcJ3wxoocr2+R+Jzmf7VECocYDBK+s0hdf/eFTb23Ad2rWl1CZZMzq78BTrR190ud X-Received: by 2002:a63:9dc4:: with SMTP id i187mr135518pgd.259.1553258666146; Fri, 22 Mar 2019 05:44:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553258666; cv=none; d=google.com; s=arc-20160816; b=U+uZ7OYuTKYpBnongjAaK+5tlbiOpShfpHv7KS1HQ+RfWPUwuWbadtUa70bK3K5mzl //5Yv9OF8d7zSPYu6tQD8u9mZf2mCBPS6fRvqAieNn4c5F0xIQCSvdHacLXjiKwVhgcI AZqcUDjKzRclNNhDpLJBvHiN2pYaAlA0ae7givtaJ9tExQ0nMIg4gNBUBkwZNt3blDoU Nr7WGlGeEhh/7tyR7orm6PPpq7E4JgV79fkVUcY9IyqeMPeftAPWVuiZbKtwZjNpuPIX EQoBTS0jQAHBwDmvZoqhFCDsuagfW9QtRXBpH3rtLZAQn/ijFhlNwkSwtAgkinicUPiF wbmw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=MQGZ2h3vqOVv9DiOhkqWm0+llzzF541Jo+5m6jcvUMI=; b=fY65PsTncF9XfZ49IADJVI7thnopBMZQMn52qO+5yjtKbIhiw46bQrgm4wiP+RZCSy gW1zL9kxDCRnyPrQRMaJpjLHBo+kWnkKVXthbE/McLrkovVzQxFypPG9dS33SqPphlAY htLGgG9ovIY/Rl/seeRrsRDr3OgB41F+791Ep2bdDDwYqFMUpH69DOMbmH3BRAh3y4az fwetKHgSenwG5TC7jWr1+Dh/lt7FK+Xpan5wuLaRlJqhJeUqdz0P9ekuTIY0zIxLD4jp YTdtcmRcGbIEg0DOVxTwq/p7gFfGrY3+PRBvIrnP9sUF/LZ1o4kBh/ZIUNaA6pnyV76r rBzQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=CHcqEwBP; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n5si6423371pff.191.2019.03.22.05.44.08; Fri, 22 Mar 2019 05:44:26 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=CHcqEwBP; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388705AbfCVMEj (ORCPT + 99 others); Fri, 22 Mar 2019 08:04:39 -0400 Received: from mail.kernel.org ([198.145.29.99]:43022 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388685AbfCVMEg (ORCPT ); Fri, 22 Mar 2019 08:04:36 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id D91CE2195D; Fri, 22 Mar 2019 12:04:34 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1553256275; bh=vprQ4Uqu6DcR1uDbw/86Ts8/f93E3icdcF7atHaZCyY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=CHcqEwBPeLUBew5rv6iT/gz7CO6CUsjWTikb9rK5qLoMV6sBbfxf5VOlIOK4qFTFO bc3ZiPMrVgNTZK06rVLJ9bor97ef3tp6brs42V1w7nR8eXhT0viFFEyG+cd5CFtebv UErbJaUtsC/iOzhduNfq++fPHRdpXMJsXQoC6gz4= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Christoph Anton Mitterer , Christoph Hellwig , "Martin K. Petersen" Subject: [PATCH 4.19 160/280] scsi: sd: Optimal I/O size should be a multiple of physical block size Date: Fri, 22 Mar 2019 12:15:13 +0100 Message-Id: <20190322111322.300459318@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190322111306.356185024@linuxfoundation.org> References: <20190322111306.356185024@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ From: Martin K. Petersen commit a83da8a4509d3ebfe03bb7fffce022e4d5d4764f upstream. It was reported that some devices report an OPTIMAL TRANSFER LENGTH of 0xFFFF blocks. That looks bogus, especially for a device with a 4096-byte physical block size. Ignore OPTIMAL TRANSFER LENGTH if it is not a multiple of the device's reported physical block size. To make the sanity checking conditionals more readable--and to facilitate printing warnings--relocate the checking to a helper function. No functional change aside from the printks. Cc: Bugzilla: https://bugzilla.kernel.org/show_bug.cgi?id=199759 Reported-by: Christoph Anton Mitterer Reviewed-by: Christoph Hellwig Signed-off-by: Martin K. Petersen Signed-off-by: Greg Kroah-Hartman --- drivers/scsi/sd.c | 59 +++++++++++++++++++++++++++++++++++++++++++++--------- 1 file changed, 50 insertions(+), 9 deletions(-) --- a/drivers/scsi/sd.c +++ b/drivers/scsi/sd.c @@ -3066,6 +3066,55 @@ static void sd_read_security(struct scsi sdkp->security = 1; } +/* + * Determine the device's preferred I/O size for reads and writes + * unless the reported value is unreasonably small, large, not a + * multiple of the physical block size, or simply garbage. + */ +static bool sd_validate_opt_xfer_size(struct scsi_disk *sdkp, + unsigned int dev_max) +{ + struct scsi_device *sdp = sdkp->device; + unsigned int opt_xfer_bytes = + logical_to_bytes(sdp, sdkp->opt_xfer_blocks); + + if (sdkp->opt_xfer_blocks > dev_max) { + sd_first_printk(KERN_WARNING, sdkp, + "Optimal transfer size %u logical blocks " \ + "> dev_max (%u logical blocks)\n", + sdkp->opt_xfer_blocks, dev_max); + return false; + } + + if (sdkp->opt_xfer_blocks > SD_DEF_XFER_BLOCKS) { + sd_first_printk(KERN_WARNING, sdkp, + "Optimal transfer size %u logical blocks " \ + "> sd driver limit (%u logical blocks)\n", + sdkp->opt_xfer_blocks, SD_DEF_XFER_BLOCKS); + return false; + } + + if (opt_xfer_bytes < PAGE_SIZE) { + sd_first_printk(KERN_WARNING, sdkp, + "Optimal transfer size %u bytes < " \ + "PAGE_SIZE (%u bytes)\n", + opt_xfer_bytes, (unsigned int)PAGE_SIZE); + return false; + } + + if (opt_xfer_bytes & (sdkp->physical_block_size - 1)) { + sd_first_printk(KERN_WARNING, sdkp, + "Optimal transfer size %u bytes not a " \ + "multiple of physical block size (%u bytes)\n", + opt_xfer_bytes, sdkp->physical_block_size); + return false; + } + + sd_first_printk(KERN_INFO, sdkp, "Optimal transfer size %u bytes\n", + opt_xfer_bytes); + return true; +} + /** * sd_revalidate_disk - called the first time a new disk is seen, * performs disk spin up, read_capacity, etc. @@ -3144,15 +3193,7 @@ static int sd_revalidate_disk(struct gen dev_max = min_not_zero(dev_max, sdkp->max_xfer_blocks); q->limits.max_dev_sectors = logical_to_sectors(sdp, dev_max); - /* - * Determine the device's preferred I/O size for reads and writes - * unless the reported value is unreasonably small, large, or - * garbage. - */ - if (sdkp->opt_xfer_blocks && - sdkp->opt_xfer_blocks <= dev_max && - sdkp->opt_xfer_blocks <= SD_DEF_XFER_BLOCKS && - logical_to_bytes(sdp, sdkp->opt_xfer_blocks) >= PAGE_SIZE) { + if (sd_validate_opt_xfer_size(sdkp, dev_max)) { q->limits.io_opt = logical_to_bytes(sdp, sdkp->opt_xfer_blocks); rw_max = logical_to_sectors(sdp, sdkp->opt_xfer_blocks); } else