Received: by 10.192.165.148 with SMTP id m20csp4967734imm; Tue, 24 Apr 2018 11:20:48 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/uar7zaH3W9rv609QCf8i+/iYL+Co+JRr1pg1bKXOzgsqSKTPuNUjqvj0ugiYcI/OA6P5k X-Received: by 10.99.189.26 with SMTP id a26mr21343050pgf.157.1524594048112; Tue, 24 Apr 2018 11:20:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524594048; cv=none; d=google.com; s=arc-20160816; b=asabiDczNU3+mmAEe66qmzIUaR0gFHWkcoFOsJoqWjeVpC0a9fe/1embnnmzazEgV2 V1Bo3nUrlioJbwZDn68558DH6JEP+oQnPMM+OiQucoIoki/7OCdtk9JU2wGJygDAvkuz 9kAyFou0a+UtyOSa1Iea3DQYG/wiArybLcGDhoeb5DyjvOBVXXaAxj88GeL6XnCdKmQh QKqXvWTpsi01IhzAKY+l88A2ux99GWXhfoVgl+7vXqDazErvweSQav+5H306w3o0cvo+ nMqprUNX9lbmxa0IPwrbtWsxCL6voq33PrPg0bpOv3eBaGhktZImRSdC9YHtlp63h5lM N3tw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=rxsemD1F/nYDZRh5K+VqZi2DxoxapsZOsZMsHWxfKGs=; b=qsCEhtiqiR4dwNEvr14rwbhVDIcq42DTPtlPfhU7kY37kw41hUKhwRERPuJCmtt6n9 GDAWpaLgfdJfDT7gDcVRPYWYRyfDY30zBTcvEA7VbBML9aARoHrQoxL8lTnA9O9DdXGk dnGhzuENpfvifAqNV2LzvPA4Zxe2U1ogE2Q0ET6E7wnZBC7kZGejJVpLlCwQH9kYbOyI bDlir+MrHbwSEqejHdZb1NGZTQHyT0REUtlwmXqLDRtCYWfcEhCUl58y7YvCFm+69fBX JEBBf0/CqUWkIrg1ARR/HxbJIUmYCODH0Q6ojUrYtPOsYctEGVQYkXomje2pg7Bho8Jm /MBA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=uK3txsOk; 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 k72si12258531pfa.53.2018.04.24.11.20.34; Tue, 24 Apr 2018 11:20:48 -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=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=uK3txsOk; 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 S1752532AbeDXSQk (ORCPT + 99 others); Tue, 24 Apr 2018 14:16:40 -0400 Received: from bombadil.infradead.org ([198.137.202.133]:54468 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751483AbeDXSQe (ORCPT ); Tue, 24 Apr 2018 14:16:34 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=References:In-Reply-To:Message-Id: Date:Subject:Cc:To:From:Sender:Reply-To:MIME-Version:Content-Type: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=rxsemD1F/nYDZRh5K+VqZi2DxoxapsZOsZMsHWxfKGs=; b=uK3txsOkUJbVztbf6PXpJ1ZYx Vibm9h4dKh0a4b266U+UHRwmH/EyHVSURMJFFf1chZzfb03ONQe73TwEL8bZ9dMYJay7ymREaQjiv S8v8vozDSSyzlkjbdaa09jy4lcvljbG8xWDSyGcj7it305XYeHBgFe71MVoWnWXgPvh063Eca0JZb t1hHzy/o9mOCMSKCjuRQUncew0fajMSLoH2FhpMcgqdZUYZqIeST+P/87XDCTQf5JaFEb+PdoCtVH CYBhDeNcfyXU6FcuVOZxUXmpDkcLphzB+/stt8GYCIHtZ50DQgPuRucw6r5zGXAY+3PEe5c/ziKy4 msZUxmmXg==; Received: from 213-225-11-78.nat.highway.a1.net ([213.225.11.78] helo=localhost) by bombadil.infradead.org with esmtpsa (Exim 4.90_1 #2 (Red Hat Linux)) id 1fB2UT-0007tV-Fr; Tue, 24 Apr 2018 18:16:33 +0000 From: Christoph Hellwig To: iommu@lists.linux-foundation.org, linux-arch@vger.kernel.org, linux-block@vger.kernel.org, linux-ide@vger.kernel.org, linux-scsi@vger.kernel.org, netdev@vger.kernel.org Cc: "David S. Miller" , linux-kernel@vger.kernel.org Subject: [PATCH 1/5] scsi: reduce use of block bounce buffers Date: Tue, 24 Apr 2018 20:16:21 +0200 Message-Id: <20180424181625.22410-2-hch@lst.de> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180424181625.22410-1-hch@lst.de> References: <20180424181625.22410-1-hch@lst.de> X-SRS-Rewrite: SMTP reverse-path rewritten from by bombadil.infradead.org. See http://www.infradead.org/rpr.html Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org We can rely on the dma-mapping code to handle any DMA limits that is bigger than the ISA DMA mask for us (either using an iommu or swiotlb), so remove setting the block layer bounce limit for anything but the unchecked_isa_dma case, or the bouncing for highmem pages. Signed-off-by: Christoph Hellwig --- drivers/scsi/scsi_lib.c | 24 ++---------------------- 1 file changed, 2 insertions(+), 22 deletions(-) diff --git a/drivers/scsi/scsi_lib.c b/drivers/scsi/scsi_lib.c index e9b4f279d29c..e0b614c0b1e6 100644 --- a/drivers/scsi/scsi_lib.c +++ b/drivers/scsi/scsi_lib.c @@ -2149,27 +2149,6 @@ static int scsi_map_queues(struct blk_mq_tag_set *set) return blk_mq_map_queues(set); } -static u64 scsi_calculate_bounce_limit(struct Scsi_Host *shost) -{ - struct device *host_dev; - u64 bounce_limit = 0xffffffff; - - if (shost->unchecked_isa_dma) - return BLK_BOUNCE_ISA; - /* - * Platforms with virtual-DMA translation - * hardware have no practical limit. - */ - if (!PCI_DMA_BUS_IS_PHYS) - return BLK_BOUNCE_ANY; - - host_dev = scsi_get_device(shost); - if (host_dev && host_dev->dma_mask) - bounce_limit = (u64)dma_max_pfn(host_dev) << PAGE_SHIFT; - - return bounce_limit; -} - void __scsi_init_queue(struct Scsi_Host *shost, struct request_queue *q) { struct device *dev = shost->dma_dev; @@ -2189,7 +2168,8 @@ void __scsi_init_queue(struct Scsi_Host *shost, struct request_queue *q) } blk_queue_max_hw_sectors(q, shost->max_sectors); - blk_queue_bounce_limit(q, scsi_calculate_bounce_limit(shost)); + if (shost->unchecked_isa_dma) + blk_queue_bounce_limit(q, BLK_BOUNCE_ISA); blk_queue_segment_boundary(q, shost->dma_boundary); dma_set_seg_boundary(dev, shost->dma_boundary); -- 2.17.0