Received: by 2002:a05:6520:4211:b029:f4:110d:56bc with SMTP id o17csp1547509lkv; Wed, 19 May 2021 12:29:14 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyjsC5OJi5DUxD7EELqw4u11qd8fyOYbfoLIkrNjm70uSbhMaJGBKiPbJtHpsS3BY9FW+fW X-Received: by 2002:a50:fb0a:: with SMTP id d10mr657232edq.47.1621452554699; Wed, 19 May 2021 12:29:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621452554; cv=none; d=google.com; s=arc-20160816; b=ahbjAqC1+ZaW6GcJaqaFAhczHLQobfMYlYDcetF0AP176ViEY21YojANbaIUJrKsJW fiffUjXmsv9jBVPBGU9ECtGshKeOddOuWzrSQmYNcVyA9/r0xm3UQP7A08QH8SjTdF3D /SNvxRkD2jywdKGD6YFN/IV4v9wS4j1Zfb8weebxbUI81+bbStfT1IBpFPx0rokaTyBs Tm7rLN/z4IwRxB2Jc37ODq5M4lUKdfNWBaMuVBlbIRq9kHru9UoS0jP3SEc7c/6ucoXu vqO6uYRhZTs4Dt0jTsSMCQRars1xd/AqWDloqzRJIlIOyqdXTrUoLQoLTyGKgkvwDRE/ RfnQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=YSAcuOLJGeEoeLeynUv7Z53TmAqhXg2HFE2m7g0ca6g=; b=VFjvSToKx7JswtKsgNHJWclGDKIZR7PobnK4NC8yy8BsN/Cphz/8t4Qn5cfr4IHfAO ppqjnMi9o8ouWhb521cc9T3extDEmi4B3gV7sPo451CjPakkoQeFdiScrjTTYisN7CZs pWEetWGr9SntODFIeRGxmdlTNJM1Na0PkGVzN0dkMqgH10K5XNAYAItE7q2Im5/X2Ud+ IOoMmv5KPd2zNditYSW2RZlLkl6lchgLgeQ9jaEQmam9l5UkXOYLXXZtYc5sdx36pJFH ss3DPC6A9yojb8zfn4q/boZcF9CWUbbeLWvbsTUIBIiIWuPDktMvXM5OzIcQZzI931dI JKig== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id gb26si617403ejc.3.2021.05.19.12.28.49; Wed, 19 May 2021 12:29:14 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S1345665AbhESKDR (ORCPT + 99 others); Wed, 19 May 2021 06:03:17 -0400 Received: from foss.arm.com ([217.140.110.172]:57234 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230308AbhESKDL (ORCPT ); Wed, 19 May 2021 06:03:11 -0400 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 B74F3101E; Wed, 19 May 2021 03:01:39 -0700 (PDT) Received: from [10.57.66.179] (unknown [10.57.66.179]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 8E03A3F719; Wed, 19 May 2021 03:01:38 -0700 (PDT) Subject: Re: [RFC PATCH v1 0/2] iommu/arm-smmu-v3: Add some parameter check in __arm_smmu_tlb_inv_range() To: Kunkun Jiang , Will Deacon , Eric Auger , "moderated list:ARM SMMU DRIVERS" , "open list:IOMMU DRIVERS" , open list Cc: wanghaibin.wang@huawei.com References: <20210519094307.3275-1-jiangkunkun@huawei.com> From: Robin Murphy Message-ID: Date: Wed, 19 May 2021 11:01:33 +0100 User-Agent: Mozilla/5.0 (Windows NT 10.0; rv:78.0) Gecko/20100101 Thunderbird/78.10.1 MIME-Version: 1.0 In-Reply-To: <20210519094307.3275-1-jiangkunkun@huawei.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-GB Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2021-05-19 10:43, Kunkun Jiang wrote: > Hi all, > > This set of patches solves some errors when I tested the SMMU nested mode. > > Test scenario description: > guest kernel: 4KB translation granule > host kernel: 16KB translation granule > > errors: > 1. encountered an endless loop in __arm_smmu_tlb_inv_range because > num_pages is 0 > 2. encountered CERROR_ILL because the fields of TLB invalidation > command are as follow: TG = 2, NUM = 0, SCALE = 0, TTL = 0. The > combination is exactly the kind of reserved combination pointed > out in the SMMUv3 spec(page 143-144, version D.a) > > In my opinion, it is more appropriate to add parameter check in > __arm_smmu_tlb_inv_range(), although these problems only appeared > when I tested the SMMU nested mode. What do you think? FWIW I think it would be better to fix the caller to not issue broken commands in the first place. The kernel shouldn't do so for itself (and definitely needs fixing if it ever does), so it sounds like the nesting implementation needs to do a bit more validation of what it's passing through. Robin. > This series include patches as below: > Patch 1: > - align the invalid range with leaf page size upwards when smmu > supports RIL > > Patch 2: > - add a check to standardize granule size when smmu supports RIL > > Kunkun Jiang (2): > iommu/arm-smmu-v3: Align invalid range with leaf page size upwards > when support RIL > iommu/arm-smmu-v3: Standardize granule size when support RIL > > drivers/iommu/arm/arm-smmu-v3/arm-smmu-v3.c | 9 +++++++++ > 1 file changed, 9 insertions(+) >