Received: by 2002:a05:7412:1492:b0:e2:908c:2ebd with SMTP id s18csp720284rdh; Tue, 22 Aug 2023 08:46:01 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEJz5H3dzYQIR5dXJ7ni9DWI0hfIvqbZB4x8/5uB/4MLQmwN7MB6BX54xJnFxF+jYEvtyKv X-Received: by 2002:a17:902:f547:b0:1b7:f443:c7f8 with SMTP id h7-20020a170902f54700b001b7f443c7f8mr7546869plf.15.1692719160665; Tue, 22 Aug 2023 08:46:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1692719160; cv=none; d=google.com; s=arc-20160816; b=Iy5WumkE2FKpum9usiSl2P4iaSsyOf+jb3JfSRS09I5NuWChOS2FBX/9YqHQmiWBNO L27oOmNaymFo+L3wYjKQf1OMcz1KucVHxzZxNrUZfKSFJjYVuVxeL+5zUcuDDV9YxE2R U9PU4PAmlL3sD3rf3nbEFuWf4D2U+XIy/jNq830w7rEDSXTuz50Qx93NMONeuB6geWOE 34Yu0tlkFxcohC1/CkC0zY8Vsojzic9gW5qKfFABDEWbTMeRBnxczTpB67PkL4QNZqhv CM5Y7wZ/Wa5mVfLPOPiDL5sdts/uwyBpKbwjhtWmj2O0UXyqAwWVKkHnlZyJQVCj0rIT bEEQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=LifN5Et/s6S/+7W6AGwYf2ajFKOTUapL7MI2+bW/6lA=; fh=aatEoF7JFvzn9rgK2HIATwBYyDON9Nr3OSj+zOcKEzA=; b=p1tlpcXzRV6iFnEW6MeUDad/pAvSCNhxJGmSGjKRCwFiLamRJiFvrHk1YEEfmNRXGg 7hXCCbnmmwbrXaiCa0X59792pJqizwFfg+4paxouX6eWzBkiJnlF8FhcumkIuAAXSQWc zOyce9y9lBVp6YIQ7iNmpUkieXmLVL56OzM4TEhglygKPuw5lZTDeRtgst+LvVxhlzIx K11ccYiFERhAb8fB7Pz0dz4uTDcaBfbIVCkOi78UJpGLpJsh0wRIuzTjzaw2dnZDW+65 5bX3cvNj3nJeU3pes36/BhUictvo5m4WKvaS72KH44K0bh33hcS7YVoY26sXr1p4P5Aw U+vw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id y11-20020a170902cacb00b001b8698149fbsi8603121pld.477.2023.08.22.08.45.47; Tue, 22 Aug 2023 08:46:00 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234253AbjHVJTe (ORCPT + 99 others); Tue, 22 Aug 2023 05:19:34 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57482 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234249AbjHVJTa (ORCPT ); Tue, 22 Aug 2023 05:19:30 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 93908113 for ; Tue, 22 Aug 2023 02:19:28 -0700 (PDT) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 031D911FB; Tue, 22 Aug 2023 02:20:09 -0700 (PDT) Received: from [10.57.5.95] (unknown [10.57.5.95]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id BF3EC3F64C; Tue, 22 Aug 2023 02:19:26 -0700 (PDT) Message-ID: Date: Tue, 22 Aug 2023 10:19:21 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; rv:102.0) Gecko/20100101 Thunderbird/102.14.0 Subject: Re: [PATCH 1/3] iommu/io-pgtable-arm: Add nents_per_pgtable in struct io_pgtable_cfg Content-Language: en-GB To: Nicolin Chen , will@kernel.org, jgg@nvidia.com Cc: joro@8bytes.org, jean-philippe@linaro.org, apopple@nvidia.com, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, iommu@lists.linux.dev References: <0fe68babdb3a07adf024ed471fead4e3eb7e703f.1692693557.git.nicolinc@nvidia.com> From: Robin Murphy In-Reply-To: <0fe68babdb3a07adf024ed471fead4e3eb7e703f.1692693557.git.nicolinc@nvidia.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-3.7 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE,SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2023-08-22 09:45, Nicolin Chen wrote: > Add a new nents_per_pgtable in struct io_pgtable_cfg to store the number > of entries per IO pagetable, so it can be passed back to an IOMMU driver. > It will be used by one of the following changes to set the maximum number > of TLBI operations in the arm-smmu-v3 driver. > > Signed-off-by: Nicolin Chen > --- > drivers/iommu/io-pgtable-arm.c | 3 +++ > include/linux/io-pgtable.h | 2 ++ > 2 files changed, 5 insertions(+) > > diff --git a/drivers/iommu/io-pgtable-arm.c b/drivers/iommu/io-pgtable-arm.c > index 72dcdd468cf3..7583d9ecca2b 100644 > --- a/drivers/iommu/io-pgtable-arm.c > +++ b/drivers/iommu/io-pgtable-arm.c > @@ -891,6 +891,7 @@ arm_64_lpae_alloc_pgtable_s1(struct io_pgtable_cfg *cfg, void *cookie) > > /* TTBR */ > cfg->arm_lpae_s1_cfg.ttbr = virt_to_phys(data->pgd); > + cfg->nents_per_pgtable = 1 << data->bits_per_level; > return &data->iop; > > out_free_data: > @@ -993,6 +994,7 @@ arm_64_lpae_alloc_pgtable_s2(struct io_pgtable_cfg *cfg, void *cookie) > > /* VTTBR */ > cfg->arm_lpae_s2_cfg.vttbr = virt_to_phys(data->pgd); > + cfg->nents_per_pgtable = 1 << data->bits_per_level; > return &data->iop; > > out_free_data: > @@ -1071,6 +1073,7 @@ arm_mali_lpae_alloc_pgtable(struct io_pgtable_cfg *cfg, void *cookie) > ARM_MALI_LPAE_TTBR_ADRMODE_TABLE; > if (cfg->coherent_walk) > cfg->arm_mali_lpae_cfg.transtab |= ARM_MALI_LPAE_TTBR_SHARE_OUTER; > + cfg->nents_per_pgtable = 1 << data->bits_per_level; The result of this highly complex and expensive calculation is clearly redundant with the existing bits_per_level field, so why do we need to waste space storing when the driver could simply use bits_per_level? Thanks, Robin. > return &data->iop; > > diff --git a/include/linux/io-pgtable.h b/include/linux/io-pgtable.h > index 1b7a44b35616..4b55a327abc1 100644 > --- a/include/linux/io-pgtable.h > +++ b/include/linux/io-pgtable.h > @@ -55,6 +55,7 @@ struct iommu_flush_ops { > * tables. > * @ias: Input address (iova) size, in bits. > * @oas: Output address (paddr) size, in bits. > + * @nents_per_pgtable: Number of entries per page table. > * @coherent_walk A flag to indicate whether or not page table walks made > * by the IOMMU are coherent with the CPU caches. > * @tlb: TLB management callbacks for this set of tables. > @@ -96,6 +97,7 @@ struct io_pgtable_cfg { > unsigned long pgsize_bitmap; > unsigned int ias; > unsigned int oas; > + unsigned int nents_per_pgtable; > bool coherent_walk; > const struct iommu_flush_ops *tlb; > struct device *iommu_dev;