Received: by 2002:a05:6358:700f:b0:131:369:b2a3 with SMTP id 15csp3327779rwo; Fri, 4 Aug 2023 03:12:24 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHHQ458virlolv9oMZMlQYUsaqNuBEvrWHmFmewDx/a4ytKJxxA3Cc7fPdP6PQZO2A4cBW4 X-Received: by 2002:a17:906:3050:b0:974:1ef7:1e88 with SMTP id d16-20020a170906305000b009741ef71e88mr1064873ejd.13.1691143943853; Fri, 04 Aug 2023 03:12:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691143943; cv=none; d=google.com; s=arc-20160816; b=acP4HjrqUAM2ts8OgHuSR+qsFHP4tFrDgy1smbpC+3TCKCKU7xJT1KcrYJp1+4QTDt B4Jjs8RsYLTPUkqqR1+AENo5+dKgkBSwogwHbfSfgvcirOGaBY2fq/si7/yjR42LCMq7 sm8k+LtQE5nOv7+7h0e5MW7QDz02lQeQRTmtDhmz4w2AJPZ09dxvamSrnBc1bLH3qX5G lAQZGCUUSlYX+zRNoC2sgZehUGI3mWL/RGb1YbAno3TpJqOTDJddLue7YmNtNb7h4PYJ sdh6nRlW8wzZXBMsIKNCrto4tPu4YVL8X5yv9FYG7TR23fZjNTguEjVDlWCWA7sxjVk4 SYLA== 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 :mime-version:user-agent:date:message-id:references:cc:to:from :subject; bh=UIwa8h+iiCtxNEC5Y3zDhzd+Q3bZi6ee95JsL8tlsFc=; fh=O2GoO1XYliNEn7OJ4x4SrIe7gExYfFm+HXAiXitkRtA=; b=apUMsBID80G06YCF2+bYFCR+zSr4pPMqtiZWZLUEsIK2STfjlFA85Bv7ymKhEU6oYI U3g17UnzVPNDeRAZVLA7EY6A054hrQCKmIJKKLHG52/4/GSVlEJzl0CHQ/faitCUjEPU PEx4IrWsc/SS8UHLxOzU9nzyaeu+V5BiJMMxNTYa5vXxbhVzf6JxH6smzEY1TVIxU4D3 yx6+Y7BJqtfvWEc0CSwiTqrqdBjAG51SfzBuHDvwi0/nLMUdIdAGpFgNi5WluXproJum 7HNz7OHsPHkyK9EqaLRoUFJTjMgWMHjWcCJQ0ECa90UPGVv3pmBdJlGswmScf7yY/Nsd +SkA== 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id z13-20020a17090655cd00b0099bd6dd9362si1518531ejp.907.2023.08.04.03.11.57; Fri, 04 Aug 2023 03:12:23 -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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230422AbjHDJbm (ORCPT + 99 others); Fri, 4 Aug 2023 05:31:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41808 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230465AbjHDJb1 (ORCPT ); Fri, 4 Aug 2023 05:31:27 -0400 Received: from szxga01-in.huawei.com (szxga01-in.huawei.com [45.249.212.187]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5074149EC for ; Fri, 4 Aug 2023 02:31:24 -0700 (PDT) Received: from canpemm500006.china.huawei.com (unknown [172.30.72.53]) by szxga01-in.huawei.com (SkyGuard) with ESMTP id 4RHL3d3LknztRs2; Fri, 4 Aug 2023 17:27:57 +0800 (CST) Received: from [10.67.145.224] (10.67.145.224) by canpemm500006.china.huawei.com (7.192.105.130) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.27; Fri, 4 Aug 2023 17:31:21 +0800 Subject: [PATCH v2 1/1] iommu/arm-smmu-v3: Fix error case of range command From: zhurui To: Will Deacon CC: , , , Robin Murphy , Joerg Roedel , Lu Baolu , Jason Gunthorpe , Yicong Yang , Tomas Krcka , Jean-Philippe Brucker , Nicolin Chen References: <1690784482-30028-1-git-send-email-wangwudi@hisilicon.com> <20230801085504.GA26130@willie-the-truck> <27c895b8-1fb0-be88-8bc3-878d754684c8@huawei.com> Message-ID: Date: Fri, 4 Aug 2023 17:31:20 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.6.0 MIME-Version: 1.0 In-Reply-To: <27c895b8-1fb0-be88-8bc3-878d754684c8@huawei.com> Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-Originating-IP: [10.67.145.224] X-ClientProxiedBy: dggems703-chm.china.huawei.com (10.3.19.180) To canpemm500006.china.huawei.com (7.192.105.130) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, RCVD_IN_MSPIKE_H5,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE,SPF_PASS, URIBL_BLOCKED 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 When tg != 0 but ttl, scale, num all 0 in a range tlbi command, it is reserved and will cause the CERROR_ILL error. This case means that the size to be invalidated is only one page size, and the range invalidation is meaningless here. So we set tg to 0 in this case to do an non-range invalidation instead. Cc: Will Deacon Cc: Robin Murphy Cc: Joerg Roedel Cc: Lu Baolu Cc: Jason Gunthorpe Cc: Yicong Yang Cc: Tomas Krcka Cc: Jean-Philippe Brucker Cc: Nicolin Chen Cc: Rui Zhu Signed-off-by: Rui Zhu --- ChangeLog: v1-->v2: 1. Change from "Revert" to modify the problematic case drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.c | 9 ++++++--- 1 file changed, 6 insertions(+), 3 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 9b0dc3505601..5e56c7e85819 100644 --- a/drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.c +++ b/drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.c @@ -1895,9 +1895,6 @@ static void __arm_smmu_tlb_inv_range(struct arm_smmu_cmdq_ent *cmd, /* Get the leaf page size */ tg = __ffs(smmu_domain->domain.pgsize_bitmap); - /* Convert page size of 12,14,16 (log2) to 1,2,3 */ - cmd->tlbi.tg = (tg - 10) / 2; - /* * Determine what level the granule is at. For non-leaf, io-pgtable * assumes .tlb_flush_walk can invalidate multiple levels at once, @@ -1930,6 +1927,12 @@ static void __arm_smmu_tlb_inv_range(struct arm_smmu_cmdq_ent *cmd, num = (num_pages >> scale) & CMDQ_TLBI_RANGE_NUM_MAX; cmd->tlbi.num = num - 1; + /* Prevent error caused by one page tlbi with leaf 0 */ + if (scale == 0 && num == 1 && cmd->tlbi.leaf == 0) + cmd->tlbi.tg = 0; + else /* Convert page size of 12,14,16 (log2) to 1,2,3 */ + cmd->tlbi.tg = (tg - 10) / 2; + /* range is num * 2^scale * pgsize */ inv_range = num << (scale + tg); -- 1.8.3.1