Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp4305416yba; Mon, 29 Apr 2019 17:48:08 -0700 (PDT) X-Google-Smtp-Source: APXvYqzq5MYJJ41SJX+L8ybhBiJLyzZ+srRO1HF0t+lwdUyL8v6SJ/mSrYMXnUGwa5I5xsdvpwMO X-Received: by 2002:a17:902:b614:: with SMTP id b20mr29223106pls.200.1556585288879; Mon, 29 Apr 2019 17:48:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556585288; cv=none; d=google.com; s=arc-20160816; b=IyW6k+6bsbmbt5NE4PV9Jj23Xn5NBrdKQLMfz7bq4V/YmsjMFGFZXWAYBCSWYrbqZG jSeZrnD7OtNl2a0pivK2yue+a+qazYx36Nl9sWvj8ttwf1sQayJAVZ563unzBx9pl8yw HRjtI78HIWpOeiokY19Zh3kKhQD0Xt3RtPxAmSoeAXoS7vIbh0vdJYQeqBrGdGfVoEDy qArEXP5+K8M0HCKSve8wqi8gOuJPucjw9wTk6mgp2X+gehmWO0eacX4VHKeQ29+e1Vtn SY3lmtrySut9DZ/cu5aLDrrWgt3RrCi0RGxGAgIYjQGlf6jh6mzW6GjzGLsmoUsmZAS6 TdDA== 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:to:subject:cc; bh=ZoMT9aKpa5q8+vaxyuZbyVMHJZzx1nPEy2FMw3ullVM=; b=RAcWECJHSY2ujkIs2qTaRGtLWBYb4icPq9O1j62dgAlPQK907XuOX7aJfJvMtzxGOY 6xu0N1oqWv0Vb44tD6cxFyRFAEFX1EYmxls9vFZC/ISXXoT18A3qWG3+z+0Td6vEmCKO JTcWRMdYWt57QIepn3ukXIZmqolu/rGIk7MRacf5qn2RcKPH6uaoljWo2SAAJOJVsxmW uZY1R305q0OosAztGugK0nzeVqwkV+5M6uvqgYOE5iM3YtuTWxSMXEvkXTTnvwgbpaGm P0E9n03d0Ioe9j+4hFU9wFj/nfI58NKcHsQ1GNmhrLSux+VeIdy5uzA8H5TdpWbCearK hU5Q== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p8si34001192pgb.77.2019.04.29.17.47.52; Mon, 29 Apr 2019 17:48:08 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729678AbfD3Aql (ORCPT + 99 others); Mon, 29 Apr 2019 20:46:41 -0400 Received: from mga06.intel.com ([134.134.136.31]:44888 "EHLO mga06.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729238AbfD3Aqk (ORCPT ); Mon, 29 Apr 2019 20:46:40 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga004.jf.intel.com ([10.7.209.38]) by orsmga104.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 29 Apr 2019 17:46:40 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.60,411,1549958400"; d="scan'208";a="295632067" Received: from allen-box.sh.intel.com (HELO [10.239.159.136]) ([10.239.159.136]) by orsmga004.jf.intel.com with ESMTP; 29 Apr 2019 17:46:37 -0700 Cc: baolu.lu@linux.intel.com, 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 Subject: Re: [PATCH v3 01/10] iommu: Add helper to get minimal page size of domain To: Robin Murphy , David Woodhouse , Joerg Roedel References: <20190421011719.14909-1-baolu.lu@linux.intel.com> <20190421011719.14909-2-baolu.lu@linux.intel.com> <05eca601-0264-8141-ceeb-7ef7ad5d5650@arm.com> From: Lu Baolu Message-ID: <48ac694e-4551-40e2-f914-6942da810489@linux.intel.com> Date: Tue, 30 Apr 2019 08:40:20 +0800 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: <05eca601-0264-8141-ceeb-7ef7ad5d5650@arm.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Robin, On 4/29/19 6:55 PM, Robin Murphy wrote: > 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; > It looks reasonable to me. > > 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. Okay, I will change the name to domain_min_pgsize(). > > Robin. > Best regards, Lu Baolu >> + >> +    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 >> >