Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp1299706pxa; Sat, 15 Aug 2020 14:58:51 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyBx1Ge3X6j+GbYrOO0iAGXYhyog0B354X+FYlO5x+Mvz+dCX8nhic4R7iyOw277YlmTgsK X-Received: by 2002:a05:6402:12d7:: with SMTP id k23mr8563110edx.312.1597528731644; Sat, 15 Aug 2020 14:58:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1597528731; cv=none; d=google.com; s=arc-20160816; b=O+CvXbmFwDebaG96jMI0Tk7zAcYcgPtw51riYrUUKiCudu070E6AB+al3JMTSrGq5q RcEw1DEEgWZDgYvTXqimcVf3m93EYdPn78/AKcmfGdUMcUyFf8v+87xygod9r8XpGH5s P9uwuvAL0DNuoUJpK2tQWSHVjMTRdBvYfSOZPyiJYmnpg5N63/uPE7WZQ7jkSl0+DaaA GXDtCF44HdXODUa6Xh/aKWPUs3lk/D0L1m7X/U0l3+rux5W3tALF39bhyqcI5lmp6Jef 1CgDCzsM+hjeZsAhsbN31ITOjmI5fA0H6ogfdwxU/MW4kh1qSiNCSmZdzBJhBK+UEnyx 4T1g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=1UEjNo8FBjY3zOHNcMSpQLZ9ulspEjH4BS4O+4ISF0c=; b=lvyZeMTfh0Z1WgZ5ilD55wX1CHnd3YMXC6WssEGDKCissiXx/dMRlG134ire4x8IuM KfflyPv5atSwgGfA6iMRBQLVmcTUhp/Kj7oKFJpcowREqEw/lh+3XN6oTatCS/GR3tQW hjpw5WzTjJQZXNoY7IwEZ73rNXza8GdnNV7w7/CbFllpphTFH4ibgoB3bZwBY2/RdUUX lGQM5GYc/iqaD4MdKQ2zkNtXDmFawGa0ow6IOgf6pyeFyfJZBKP9+wn8MaJcM9oK+fp3 Jftzd7XWQFmLuIWBTKEmTgKMDovTGGG8/e7vhFTqVfHulJdsVlVDUenmWOzAkDcfDwSW +D2A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=l+20G6uG; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g6si724edw.30.2020.08.15.14.58.29; Sat, 15 Aug 2020 14:58:51 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=l+20G6uG; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729433AbgHOV4w (ORCPT + 99 others); Sat, 15 Aug 2020 17:56:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45642 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729015AbgHOVwL (ORCPT ); Sat, 15 Aug 2020 17:52:11 -0400 Received: from mail-pg1-x543.google.com (mail-pg1-x543.google.com [IPv6:2607:f8b0:4864:20::543]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7FEA8C06123B for ; Fri, 14 Aug 2020 23:48:18 -0700 (PDT) Received: by mail-pg1-x543.google.com with SMTP id i10so30969pgk.1 for ; Fri, 14 Aug 2020 23:48:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=1UEjNo8FBjY3zOHNcMSpQLZ9ulspEjH4BS4O+4ISF0c=; b=l+20G6uGynVVHrnnRdzNF3Fh3VpleLP+EkvjlzL6Ihoj8BrtDflhsxuQap/puPx9vx Y5DS9R5phbsGF046MkBSx2YiepDjw9cXOF41ylVI1jUOP9Gg6wtjkxmap+dGxLtSTXoW bmEG6PPHN43EPUmbdBQpw5+Ohgy0M2mJW1cuVjfS3MXYBWgczFmUGHkSiB9txA2jSAzB jfA8oIuwNkIvDNCKP8Etl56gvVk3ERPw4fNbiKCLdnwYGJ/x6Iq00/oKsT7H3LXD9ZHi xiHU5Dl3yqFQS6B+FTPHDWbGVcW8sNv6mt12xCXJzgC/oqKVvF1ImcBV5jj22cgf39hg 7+LQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=1UEjNo8FBjY3zOHNcMSpQLZ9ulspEjH4BS4O+4ISF0c=; b=CiEbJENEQ1uUJ00EVGoGRWgDH8jZrgGjOe/jLkmFyzY12PiTTSi76s0AM+KlfusfiE KpHDXSJLHbor6406Q1vH8drsl8Vgfe47/D/9rhCvZzwYlAqFHz30G53g8fdporbmj6eH 7tfKl5+aRar3tpYOEOHKiREd6I/ypXvrAa/a1VUxmf9xaNlFvIm4jnHDG94/t8XXBBiY R0QGbKtsQ670ldG/SFjL17/wa1AaayFJTiuX9jiEyGw5aq8FBrQoh2/n3zlYNPVmJSrq E64BvONt2zIMR9TH/k6k1EmPmrUpzR0X6eGSknUzCHCnFQFEIIrl6um7cGH+v5NqZq3Z +oAQ== X-Gm-Message-State: AOAM531uq2MAgIY8rteyvTPcLk2FcxxASqvocpYuJaRfbVvnsGrNxOwE LdiZBtoeD5Fk2i66hzAH1OI= X-Received: by 2002:a63:5515:: with SMTP id j21mr3870740pgb.31.1597474097506; Fri, 14 Aug 2020 23:48:17 -0700 (PDT) Received: from Asurada-Nvidia.nvidia.com (searspoint.nvidia.com. [216.228.112.21]) by smtp.gmail.com with ESMTPSA id f63sm10162940pjk.53.2020.08.14.23.48.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 14 Aug 2020 23:48:17 -0700 (PDT) From: Nicolin Chen To: hch@lst.de, m.szyprowski@samsung.com, robin.murphy@arm.com Cc: iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org Subject: [PATCH v3] dma-mapping: set default segment_boundary_mask to ULONG_MAX Date: Fri, 14 Aug 2020 23:47:26 -0700 Message-Id: <20200815064726.20459-1-nicoleotsuka@gmail.com> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The default segment_boundary_mask was set to DMA_BIT_MAKS(32) a decade ago by referencing SCSI/block subsystem, as a 32-bit mask was good enough for most of the devices. Now more and more drivers set dma_masks above DMA_BIT_MAKS(32) while only a handful of them call dma_set_seg_boundary(). This means that most drivers have a 4GB segmention boundary because DMA API returns a 32-bit default value, though they might not really have such a limit. The default segment_boundary_mask should mean "no limit" since the device doesn't explicitly set the mask. But a 32-bit mask certainly limits those devices capable of 32+ bits addressing. So this patch sets default segment_boundary_mask to ULONG_MAX. Signed-off-by: Nicolin Chen --- Changelog: v2->v3 * Resent -- no change v2 was sent 4 months ago https://lkml.org/lkml/2020/4/6/881 but it has not got replied yet v1->v2 * Followed Robin's comments to revise the commit message by dropping one paragraph of not-entirely-true justification (no git-diff level change, so please ack if you tested v1) include/linux/dma-mapping.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/include/linux/dma-mapping.h b/include/linux/dma-mapping.h index 016b96b384bd..27df499aa041 100644 --- a/include/linux/dma-mapping.h +++ b/include/linux/dma-mapping.h @@ -628,7 +628,7 @@ static inline unsigned long dma_get_seg_boundary(struct device *dev) { if (dev->dma_parms && dev->dma_parms->segment_boundary_mask) return dev->dma_parms->segment_boundary_mask; - return DMA_BIT_MASK(32); + return ULONG_MAX; } static inline int dma_set_seg_boundary(struct device *dev, unsigned long mask) -- 2.17.1