Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3517900yba; Mon, 29 Apr 2019 03:58:40 -0700 (PDT) X-Google-Smtp-Source: APXvYqw2Zn2MIx0v8J0MrnOv0lytSuoUyn1A/BLxFVSHf36YfkhG1eqyA9Qqwz1oBOxswvIUqM1u X-Received: by 2002:aa7:9294:: with SMTP id j20mr64177453pfa.64.1556535520841; Mon, 29 Apr 2019 03:58:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556535520; cv=none; d=google.com; s=arc-20160816; b=v1j7wSsSegwrVDHGS9gJeOgOveq+7UtsQxmikGuiG3TbUIQgZz00s4Q/SdEDPym/AM Lqx68j439iA+UeBWnde9uamaCOq+GCrC5FyI9EmLU0sC+YNz9ANdKJQ2a+kfr3XbrZoC UoTAvudbw1UkaTOuAjuYWLjAfHobEILszTlzz0Mnuc38IqylssU/c9UrtNOdzQYXV63G WmHValjiBwq1rX9EArkBmsdpKz2i1zxyo0/qCLIwCLwwyzwUwwCKQPUcyREmPvJzXKKC cO76hkXHtiNLTzvB6jB8JPVcgc4+ESs+HpQhd8ed1laXubg6qA0DYMPzhy1TWm8PzkCV xsbA== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=JmR8KeA7gSwbOiZw9lTioEyirS2Vu3oGPIIYbAHUKK8=; b=vcbhGZ9dCZ9zvestKldXWcpYIGjKFmo/lhHJM2kyUhYg1ZlzFKYeuVT4W8uGmoOQbY LxGsZUAyKxFy7U0qJeZrAhjXG3WdbAuCIYOCqEcePL7NGzqiDKgOaHN9yz3ffwEk0p1e su9e4J+ANKBv7x4V9zCS+jMjHTJrgOvj9neq3H1jsd91nK2BeibJUeKD+dzAOfjVv2aE HTxryJtz6X0Ywk4w8FyqbC301b9Is+rPyFsMp6RwipWwkqetUoxgoHMcrk5rnx6xfLGo n5rimszoTOH7eR0Uxhc47Gd4LOU+TzTIUPjSus8ZuugUw3S1rkrX81hwpjUFCnoVPmKk G8gw== ARC-Authentication-Results: i=1; mx.google.com; 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 f9si30391627pgq.347.2019.04.29.03.58.24; Mon, 29 Apr 2019 03:58:40 -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; 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 S1727878AbfD2K4C (ORCPT + 99 others); Mon, 29 Apr 2019 06:56:02 -0400 Received: from foss.arm.com ([217.140.101.70]:53370 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727775AbfD2K4C (ORCPT ); Mon, 29 Apr 2019 06:56:02 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 5756380D; Mon, 29 Apr 2019 03:56:01 -0700 (PDT) Received: from [10.1.196.75] (e110467-lin.cambridge.arm.com [10.1.196.75]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 068C83F5AF; Mon, 29 Apr 2019 03:55:58 -0700 (PDT) Subject: Re: [PATCH v3 01/10] iommu: Add helper to get minimal page size of domain To: Lu Baolu , David Woodhouse , Joerg Roedel Cc: ashok.raj@intel.com, jacob.jun.pan@intel.com, alan.cox@intel.com, kevin.tian@intel.com, mika.westerberg@linux.intel.com, pengfei.xu@intel.com, Konrad Rzeszutek Wilk , Christoph Hellwig , Marek Szyprowski , iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org References: <20190421011719.14909-1-baolu.lu@linux.intel.com> <20190421011719.14909-2-baolu.lu@linux.intel.com> From: Robin Murphy Message-ID: <05eca601-0264-8141-ceeb-7ef7ad5d5650@arm.com> Date: Mon, 29 Apr 2019 11:55:54 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.6.1 MIME-Version: 1.0 In-Reply-To: <20190421011719.14909-2-baolu.lu@linux.intel.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-GB Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 21/04/2019 02:17, Lu Baolu wrote: > This makes it possible for other modules to know the minimal > page size supported by a domain without the knowledge of the > structure details. > > Signed-off-by: Lu Baolu > --- > include/linux/iommu.h | 13 +++++++++++++ > 1 file changed, 13 insertions(+) > > diff --git a/include/linux/iommu.h b/include/linux/iommu.h > index a5007d035218..46679ef19b7e 100644 > --- a/include/linux/iommu.h > +++ b/include/linux/iommu.h > @@ -377,6 +377,14 @@ static inline void iommu_tlb_sync(struct iommu_domain *domain) > domain->ops->iotlb_sync(domain); > } > > +static inline unsigned long domain_minimal_pgsize(struct iommu_domain *domain) > +{ > + if (domain && domain->pgsize_bitmap) > + return 1 << __ffs(domain->pgsize_bitmap); Nit: this would probably be more efficient on most architectures as: if (domain) return domain->pgsize_bitmap & -domain->pgsize_bitmap; I'd also suggest s/minimal/min/ in the name, just to stop it getting too long. Otherwise, though, I like the idea, and there's at least one other place (in iommu-dma) that can make use of it straight away. Robin. > + > + return 0; > +} > + > /* PCI device grouping function */ > extern struct iommu_group *pci_device_group(struct device *dev); > /* Generic device grouping function */ > @@ -704,6 +712,11 @@ const struct iommu_ops *iommu_ops_from_fwnode(struct fwnode_handle *fwnode) > return NULL; > } > > +static inline unsigned long domain_minimal_pgsize(struct iommu_domain *domain) > +{ > + return 0; > +} > + > #endif /* CONFIG_IOMMU_API */ > > #ifdef CONFIG_IOMMU_DEBUGFS >