From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id D7D90C54E58 for ; Sat, 23 Mar 2024 13:20:55 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:References: Message-ID:Subject:Cc:To:From:Date:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=qLmGzLqnAi3vJX8eEMSYgVqc66bVS9IkQtaeFhNmsiY=; b=dijWbevTcch2o1 WuS32iBXr4fwo3Mx6F+LDcuBb0urXLTKadP+IP7xWmp55Z5roS2jiL7EGdoGpJrcJORN6j0KFyZUS DXhQcPw4MeG7jG83QJs788JlY+XBLiBjOobsv9QjbYxyfDyIy4GGhayWvHm+j/tsVccukVOsG2d8k Zgq9A4KWnMInCg6GED3kxTvBb9vTVSQ+AoKHVz2O7lk+240WPYVItEDJHnU/4b8Mg1v986vYxkmGc Ho9NYnyZrK/x5xIIblKBj7ckL/3a5JK0L5D8KGJKXdq0qctyeTylzGM5DjVCamq3bNFP9e7HjYakJ Oz9tAo8j9zhqWv+FEF5Q==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.97.1 #2 (Red Hat Linux)) id 1ro1Id-0000000ARVp-2CNT; Sat, 23 Mar 2024 13:20:39 +0000 Received: from mail-wm1-x333.google.com ([2a00:1450:4864:20::333]) by bombadil.infradead.org with esmtps (Exim 4.97.1 #2 (Red Hat Linux)) id 1ro1Ia-0000000ARUy-3s1x for linux-arm-kernel@lists.infradead.org; Sat, 23 Mar 2024 13:20:38 +0000 Received: by mail-wm1-x333.google.com with SMTP id 5b1f17b1804b1-4140eed8a4fso31575e9.0 for ; Sat, 23 Mar 2024 06:20:32 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20230601; t=1711200031; x=1711804831; darn=lists.infradead.org; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:from:to:cc:subject:date:message-id:reply-to; bh=CfQtnxAwOWYfo0w6j630z7lwupN1BOC7EGLxCw7HttQ=; b=p5Sf3Aef44LTx1Uvwv0KfyBJcnCAi6DppnsRoAULKPWI3pVo2kWPd2K86m47p6tm0J SBIguohYytQsGfrmV4TnqWPfV4+JIFZdUJ3Fy9UkF0rRmJ28xDFmAhelzv0eKgc7/U1y va1XXaJXf9sYiPYor7VUxK19U5OSl68gICXcsYaM9WyFzmnhYEX/cfm8k/OrQrUq0WFw 0OunyNoZV8rUyAMllDyHmvNSv0vmaSZJKpK580QuSe3tgFDLSABgR4c7MI8SL4wuUJZa as4r41c/jjJ//W2BpSOXydfRv5IhVtWsX3S6PDRWgZTmx0xmPJ90hX2YqIpti7lyuEIU DmZA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1711200031; x=1711804831; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=CfQtnxAwOWYfo0w6j630z7lwupN1BOC7EGLxCw7HttQ=; b=SuOzzT1oXBCgk/njlK7uuT28gIm5m8lJjBZ3JQamUP7o9ZQA5jxBteyAikDnoAacxD VFnfF9QGZhqv90Jao6nFvKm9UDWIDf3/hARfl8cGn3Pkq94Z0P5UFhTEJeeWTohhnfR6 isxasZ0g5/HsXQvsDFAehqlJ4O3F+0sXkyxB5mP4UKcIo6W/sIAs7GE2MspI2xW1ivlv zsIBbvr72YJgcq8ykAPBklzVbqRQBrEXruHdcQLlT45NjxCj10Y5HM6f2cDJJ4jw2pha HVfhWNDdIbCYh1TZ8bbAbop/CTCDjhIYCqZ+C2QbS6brYN2QDQ3Ybb8LZOTTrjSCq/MC Cb7A== X-Forwarded-Encrypted: i=1; AJvYcCUO0ABrNxIDDfolkQ1/mMmcETwEpbVyhC76dThqQAFUxl/k6385xn5o0CT03LkDSjtp5byUcXJXPA7uH/FPQTsllvdvckohaVJLds1Ccjj+70td8Sk= X-Gm-Message-State: AOJu0YwigihOySl/edQrqOVIFJnXrz2UDq6sdK2qJ5K2zPi1nX+IdZ1R f6WWUQ7QwgkptxvGxfYhyF3IJD7Mp/OwJaYiVqte8oTwhfi0wpzxAaBTHIlyJ7USC4cCZ9LAvdD JUw== X-Google-Smtp-Source: AGHT+IFLjq+OOC6HxABObw2+dsRnAVN5vFTiItAERR8JUOvvPuzRVIyifpVCOExX/b8eIUFeDkfEtQ== X-Received: by 2002:a05:600c:1c8d:b0:414:800f:f992 with SMTP id k13-20020a05600c1c8d00b00414800ff992mr143664wms.2.1711200031343; Sat, 23 Mar 2024 06:20:31 -0700 (PDT) Received: from google.com (180.232.140.34.bc.googleusercontent.com. [34.140.232.180]) by smtp.gmail.com with ESMTPSA id q2-20020adfcd82000000b0033e7603987dsm4443672wrj.12.2024.03.23.06.20.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 23 Mar 2024 06:20:30 -0700 (PDT) Date: Sat, 23 Mar 2024 13:20:27 +0000 From: Mostafa Saleh To: Jason Gunthorpe Cc: iommu@lists.linux.dev, Joerg Roedel , linux-arm-kernel@lists.infradead.org, Robin Murphy , Will Deacon , Eric Auger , Jean-Philippe Brucker , Moritz Fischer , Michael Shavit , Nicolin Chen , patches@lists.linux.dev, Shameerali Kolothum Thodi Subject: Re: [PATCH v5 11/27] iommu/arm-smmu-v3: Build the whole CD in arm_smmu_make_s1_cd() Message-ID: References: <0-v5-9a37e0c884ce+31e3-smmuv3_newapi_p2_jgg@nvidia.com> <11-v5-9a37e0c884ce+31e3-smmuv3_newapi_p2_jgg@nvidia.com> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <11-v5-9a37e0c884ce+31e3-smmuv3_newapi_p2_jgg@nvidia.com> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20240323_062036_996944_784BC50A X-CRM114-Status: GOOD ( 20.62 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Hi Jason, On Mon, Mar 04, 2024 at 07:43:59PM -0400, Jason Gunthorpe wrote: > Half the code was living in arm_smmu_domain_finalise_s1(), just move it > here and take the values directly from the pgtbl_ops instead of storing > copies. > > Tested-by: Nicolin Chen > Signed-off-by: Jason Gunthorpe > --- > drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.c | 47 ++++++++------------- > drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.h | 3 -- > 2 files changed, 18 insertions(+), 32 deletions(-) > > diff --git a/drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.c b/drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.c > index 50d17e3ce0a956..dfdd48cf217c4e 100644 > --- a/drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.c > +++ b/drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.c > @@ -1301,15 +1301,25 @@ void arm_smmu_make_s1_cd(struct arm_smmu_cd *target, > struct arm_smmu_domain *smmu_domain) > { > struct arm_smmu_ctx_desc *cd = &smmu_domain->cd; > + const struct io_pgtable_cfg *pgtbl_cfg = > + &io_pgtable_ops_to_pgtable(smmu_domain->pgtbl_ops)->cfg; > + typeof(&pgtbl_cfg->arm_lpae_s1_cfg.tcr) tcr = > + &pgtbl_cfg->arm_lpae_s1_cfg.tcr; > > memset(target, 0, sizeof(*target)); > > target->data[0] = cpu_to_le64( > - cd->tcr | > + FIELD_PREP(CTXDESC_CD_0_TCR_T0SZ, tcr->tsz) | > + FIELD_PREP(CTXDESC_CD_0_TCR_TG0, tcr->tg) | > + FIELD_PREP(CTXDESC_CD_0_TCR_IRGN0, tcr->irgn) | > + FIELD_PREP(CTXDESC_CD_0_TCR_ORGN0, tcr->orgn) | > + FIELD_PREP(CTXDESC_CD_0_TCR_SH0, tcr->sh) | > + CTXDESC_CD_0_TCR_EPD1 | > #ifdef __BIG_ENDIAN > CTXDESC_CD_0_ENDI | > #endif > CTXDESC_CD_0_V | > + FIELD_PREP(CTXDESC_CD_0_TCR_IPS, tcr->ips) | > CTXDESC_CD_0_AA64 | > (master->stall_enabled ? CTXDESC_CD_0_S : 0) | > CTXDESC_CD_0_R | > @@ -1317,9 +1327,9 @@ void arm_smmu_make_s1_cd(struct arm_smmu_cd *target, > CTXDESC_CD_0_ASET | > FIELD_PREP(CTXDESC_CD_0_ASID, cd->asid) > ); > - > - target->data[1] = cpu_to_le64(cd->ttbr & CTXDESC_CD_1_TTB0_MASK); > - target->data[3] = cpu_to_le64(cd->mair); > + target->data[1] = cpu_to_le64(pgtbl_cfg->arm_lpae_s1_cfg.ttbr & > + CTXDESC_CD_1_TTB0_MASK); > + target->data[3] = cpu_to_le64(pgtbl_cfg->arm_lpae_s1_cfg.mair); > } > > void arm_smmu_clear_cd(struct arm_smmu_master *master, ioasid_t ssid) > @@ -2305,13 +2315,11 @@ static void arm_smmu_domain_free(struct iommu_domain *domain) > } > > static int arm_smmu_domain_finalise_s1(struct arm_smmu_device *smmu, > - struct arm_smmu_domain *smmu_domain, > - struct io_pgtable_cfg *pgtbl_cfg) > + struct arm_smmu_domain *smmu_domain) > { > int ret; > u32 asid; > struct arm_smmu_ctx_desc *cd = &smmu_domain->cd; > - typeof(&pgtbl_cfg->arm_lpae_s1_cfg.tcr) tcr = &pgtbl_cfg->arm_lpae_s1_cfg.tcr; > > refcount_set(&cd->refs, 1); > > @@ -2319,31 +2327,13 @@ static int arm_smmu_domain_finalise_s1(struct arm_smmu_device *smmu, > mutex_lock(&arm_smmu_asid_lock); > ret = xa_alloc(&arm_smmu_asid_xa, &asid, cd, > XA_LIMIT(1, (1 << smmu->asid_bits) - 1), GFP_KERNEL); > - if (ret) > - goto out_unlock; > - > cd->asid = (u16)asid; > - cd->ttbr = pgtbl_cfg->arm_lpae_s1_cfg.ttbr; > - cd->tcr = FIELD_PREP(CTXDESC_CD_0_TCR_T0SZ, tcr->tsz) | > - FIELD_PREP(CTXDESC_CD_0_TCR_TG0, tcr->tg) | > - FIELD_PREP(CTXDESC_CD_0_TCR_IRGN0, tcr->irgn) | > - FIELD_PREP(CTXDESC_CD_0_TCR_ORGN0, tcr->orgn) | > - FIELD_PREP(CTXDESC_CD_0_TCR_SH0, tcr->sh) | > - FIELD_PREP(CTXDESC_CD_0_TCR_IPS, tcr->ips) | > - CTXDESC_CD_0_TCR_EPD1 | CTXDESC_CD_0_AA64; > - cd->mair = pgtbl_cfg->arm_lpae_s1_cfg.mair; > - > - mutex_unlock(&arm_smmu_asid_lock); > - return 0; > - > -out_unlock: > mutex_unlock(&arm_smmu_asid_lock); > return ret; > } > > static int arm_smmu_domain_finalise_s2(struct arm_smmu_device *smmu, > - struct arm_smmu_domain *smmu_domain, > - struct io_pgtable_cfg *pgtbl_cfg) > + struct arm_smmu_domain *smmu_domain) > { > int vmid; > struct arm_smmu_s2_cfg *cfg = &smmu_domain->s2_cfg; > @@ -2367,8 +2357,7 @@ static int arm_smmu_domain_finalise(struct arm_smmu_domain *smmu_domain, > struct io_pgtable_cfg pgtbl_cfg; > struct io_pgtable_ops *pgtbl_ops; > int (*finalise_stage_fn)(struct arm_smmu_device *smmu, > - struct arm_smmu_domain *smmu_domain, > - struct io_pgtable_cfg *pgtbl_cfg); > + struct arm_smmu_domain *smmu_domain); > > /* Restrict the stage to what we can actually support */ > if (!(smmu->features & ARM_SMMU_FEAT_TRANS_S1)) > @@ -2411,7 +2400,7 @@ static int arm_smmu_domain_finalise(struct arm_smmu_domain *smmu_domain, > smmu_domain->domain.geometry.aperture_end = (1UL << pgtbl_cfg.ias) - 1; > smmu_domain->domain.geometry.force_aperture = true; > > - ret = finalise_stage_fn(smmu, smmu_domain, &pgtbl_cfg); > + ret = finalise_stage_fn(smmu, smmu_domain); > if (ret < 0) { > free_io_pgtable_ops(pgtbl_ops); > return ret; > diff --git a/drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.h b/drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.h > index 8eabcccb9420ba..468cd33b80ac35 100644 > --- a/drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.h > +++ b/drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.h > @@ -587,9 +587,6 @@ struct arm_smmu_strtab_l1_desc { > > struct arm_smmu_ctx_desc { > u16 asid; > - u64 ttbr; > - u64 tcr; > - u64 mair; > > refcount_t refs; > struct mm_struct *mm; > -- > 2.43.2 > Reviewed-by: Mostafa Saleh Thanks, Mostafa _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel