Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp718835img; Thu, 21 Mar 2019 07:34:08 -0700 (PDT) X-Google-Smtp-Source: APXvYqxoxOBkdYtv+9RLs4GJMwtOVaR9t73PfAmwWZlQyqa1i8HDh83geDd45vodCH/IX5Zg4cqE X-Received: by 2002:a63:d706:: with SMTP id d6mr3424313pgg.367.1553178848217; Thu, 21 Mar 2019 07:34:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553178848; cv=none; d=google.com; s=arc-20160816; b=SEGvTRFKAsRBsOLet3blVkBlAw19wrpVEppIM7Dbj1U4eEtJmO7IjTxTF23vGBoL6a 4SaCWaGMbPVKZTuA25yGna4WUTsiO9JdJIq+fZJKsanNH+Nhv8QeWvX+S5ovmDrOfouo KG1a/HiqZ9I3F0lDkonZFjcACx4CobD9PZs9f29UOg718d/Z7Gp98SHqRJcBWsXLV/jp bY7p0OMEhdIcH7dKU2GAxGfpFM+32T59zSqIHhCVeWJPiHbR6HG4giFC6dytI/Gkh/ok Hyyhw0TWVB7hPlXEfxJGhM7rRZTYLoOrxQHnDrLshFGmm8mFy+23zMxCAafZtZ2GgG7c 2WEA== 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:cc:to:subject; bh=z8Tq2wn9ULNOr1XQCy5DPBLLMiA3EwGNSnDJ3nEwP8Q=; b=BgyWpTrkLOczn70c+5LUG2sgl19y5UlI4mTZEVS2qXUofH88XhjiKEjbuPD51pceKQ 8cGp109G5LjDRBCL1z5oRDviQD0txS2UDnz7MZppGC+nkuKSmADspF6JMVv6x7ZR5GGr jkbOb8UGIQSAd73JbtwjUpssEn11hT7zjZRvvYHWd6x4s+37ha4Cs1duw823ddu+O24c B8xIrmLvW3G1+82RIOg35cfD33r+DPjaMBzijC4Qe9FfczmS3Bp/GVkhTvVaPnM4Voxj RMcS5dLCeBBxj1qelNdGTCa1V+rSEUENC7wXYm+o5VK2H+v9LIwUdZGft79stlAwF171 dzJg== 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=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f4si4234547pgs.333.2019.03.21.07.33.50; Thu, 21 Mar 2019 07:34: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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728286AbfCUOcy (ORCPT + 99 others); Thu, 21 Mar 2019 10:32:54 -0400 Received: from mx1.redhat.com ([209.132.183.28]:53956 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728093AbfCUOcx (ORCPT ); Thu, 21 Mar 2019 10:32:53 -0400 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id D3878308793F; Thu, 21 Mar 2019 14:32:52 +0000 (UTC) Received: from [10.36.116.167] (ovpn-116-167.ams2.redhat.com [10.36.116.167]) by smtp.corp.redhat.com (Postfix) with ESMTPS id AF84C60464; Thu, 21 Mar 2019 14:32:46 +0000 (UTC) Subject: Re: [PATCH v6 05/22] iommu: Introduce cache_invalidate API To: Jean-Philippe Brucker , Jacob Pan Cc: yi.l.liu@linux.intel.com, kevin.tian@intel.com, vincent.stehle@arm.com, ashok.raj@intel.com, kvm@vger.kernel.org, peter.maydell@linaro.org, marc.zyngier@arm.com, will.deacon@arm.com, linux-kernel@vger.kernel.org, iommu@lists.linux-foundation.org, christoffer.dall@arm.com, alex.williamson@redhat.com, robin.murphy@arm.com, kvmarm@lists.cs.columbia.edu, eric.auger.pro@gmail.com References: <20190317172232.1068-1-eric.auger@redhat.com> <20190317172232.1068-6-eric.auger@redhat.com> <20190320093727.45a86866@jacob-builder> <7ae1df77-18d0-0993-8dab-6af3a4474b42@arm.com> <109c3520-dd26-3c0b-35d1-48b169fea982@arm.com> From: Auger Eric Message-ID: <41173658-dde0-6e58-90ed-65cff2b1dd1c@redhat.com> Date: Thu, 21 Mar 2019 15:32:45 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.4.0 MIME-Version: 1.0 In-Reply-To: <109c3520-dd26-3c0b-35d1-48b169fea982@arm.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.11 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.45]); Thu, 21 Mar 2019 14:32:53 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi jean, Jacob, On 3/21/19 3:13 PM, Jean-Philippe Brucker wrote: > On 21/03/2019 13:54, Auger Eric wrote: >> Hi Jacob, Jean-Philippe, >> >> On 3/20/19 5:50 PM, Jean-Philippe Brucker wrote: >>> On 20/03/2019 16:37, Jacob Pan wrote: >>> [...] >>>>> +struct iommu_inv_addr_info { >>>>> +#define IOMMU_INV_ADDR_FLAGS_PASID (1 << 0) >>>>> +#define IOMMU_INV_ADDR_FLAGS_ARCHID (1 << 1) >>>>> +#define IOMMU_INV_ADDR_FLAGS_LEAF (1 << 2) >>>>> + __u32 flags; >>>>> + __u32 archid; >>>>> + __u64 pasid; >>>>> + __u64 addr; >>>>> + __u64 granule_size; >>>>> + __u64 nb_granules; >>>>> +}; >>>>> + >>>>> +/** >>>>> + * First level/stage invalidation information >>>>> + * @cache: bitfield that allows to select which caches to invalidate >>>>> + * @granularity: defines the lowest granularity used for the >>>>> invalidation: >>>>> + * domain > pasid > addr >>>>> + * >>>>> + * Not all the combinations of cache/granularity make sense: >>>>> + * >>>>> + * type | DEV_IOTLB | IOTLB | PASID | >>>>> + * granularity | | | >>>>> cache | >>>>> + * -------------+---------------+---------------+---------------+ >>>>> + * DOMAIN | N/A | Y | >>>>> Y | >>>>> + * PASID | Y | Y | >>>>> Y | >>>>> + * ADDR | Y | Y | >>>>> N/A | >>>>> + */ >>>>> +struct iommu_cache_invalidate_info { >>>>> +#define IOMMU_CACHE_INVALIDATE_INFO_VERSION_1 1 >>>>> + __u32 version; >>>>> +/* IOMMU paging structure cache */ >>>>> +#define IOMMU_CACHE_INV_TYPE_IOTLB (1 << 0) /* IOMMU IOTLB */ >>>>> +#define IOMMU_CACHE_INV_TYPE_DEV_IOTLB (1 << 1) /* Device >>>>> IOTLB */ +#define IOMMU_CACHE_INV_TYPE_PASID (1 << 2) /* PASID >>>>> cache */ >>>> Just a clarification, this used to be an enum. You do intend to issue a >>>> single invalidation request on multiple cache types? Perhaps for >>>> virtio-IOMMU? I only see a single cache type in your patch #14. For VT-d >>>> we plan to issue one cache type at a time for now. So this format works >>>> for us. >>> >>> Yes for virtio-iommu I'd like as little overhead as possible, which >>> means a single invalidation message to hit both IOTLB and ATC at once, >>> and the ability to specify multiple pages with @nb_granules. >> The original request/explanation from Jean-Philippe can be found here: >> https://lkml.org/lkml/2019/1/28/1497 >> >>> >>>> However, if multiple cache types are issued in a single invalidation. >>>> They must share a single granularity, not all combinations are valid. >>>> e.g. dev IOTLB does not support domain granularity. Just a reminder, >>>> not an issue. Driver could filter out invalid combinations. >> Sure I will add a comment about this restriction. >>> >>> Agreed. Even the core could filter out invalid combinations based on the >>> table above: IOTLB and domain granularity are N/A. >> I don't get this sentence. What about vtd IOTLB domain-selective >> invalidation: > > My mistake: I meant dev-IOTLB and domain granularity are N/A Ah OK, no worries. How do we proceed further with those user APIs? Besides the comment to be added above and previous suggestion from Jean ("Invalidations by @granularity use field ...), have we reached a consensus now on: - attach/detach_pasid_table - cache_invalidate - fault data and fault report API? If not, please let me know. Thanks Eric > > Thanks, > Jean > >> " >> • IOTLB entries caching mappings associated with the specified domain-id >> are invalidated. >> • Paging-structure-cache entries caching mappings associated with the >> specified domain-id are invalidated. >> " >> >> Thanks >> >> Eric >> >>> >>> Thanks, >>> Jean >>> >>>> >>>>> + __u8 cache; >>>>> + __u8 granularity; >>>>> + __u8 padding[2]; >>>>> + union { >>>>> + __u64 pasid; >>>>> + struct iommu_inv_addr_info addr_info; >>>>> + }; >>>>> +}; >>>>> + >>>>> + >>>>> #endif /* _UAPI_IOMMU_H */ >>>> >>>> [Jacob Pan] >>>> _______________________________________________ >>>> iommu mailing list >>>> iommu@lists.linux-foundation.org >>>> https://lists.linuxfoundation.org/mailman/listinfo/iommu >>>> >>> >> _______________________________________________ >> iommu mailing list >> iommu@lists.linux-foundation.org >> https://lists.linuxfoundation.org/mailman/listinfo/iommu >> >