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 X-Spam-Level: X-Spam-Status: No, score=-7.3 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS,USER_AGENT_SANE_1 autolearn=no autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 47E9CC4332B for ; Thu, 18 Feb 2021 12:30:58 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id F0F5E64E85 for ; Thu, 18 Feb 2021 12:30:55 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232063AbhBRM3X (ORCPT ); Thu, 18 Feb 2021 07:29:23 -0500 Received: from us-smtp-delivery-124.mimecast.com ([63.128.21.124]:44695 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230520AbhBRKht (ORCPT ); Thu, 18 Feb 2021 05:37:49 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1613644560; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=UB1lvh6jtSEiESfXxVHnPLX4NRWaq62eBV+yGoiXEsk=; b=VPYDqqcGf8BrI0lCp2Zi2Z7BZgooOvoo6Yn/hmuMX48C3GmY+qEzVZZUK7+max/2fTfYak f8QCV9hNjPZGHw5NqWTleK6we2lp8kBeOORuocXlKtVOEHAk0/FQDRylWebdg8edis61um 738vKuqMF0+v3wWenHnFF2DuPp52TV0= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-496-AaxVP747M9OwBRnLxO6nOQ-1; Thu, 18 Feb 2021 05:35:57 -0500 X-MC-Unique: AaxVP747M9OwBRnLxO6nOQ-1 Received: from smtp.corp.redhat.com (int-mx03.intmail.prod.int.phx2.redhat.com [10.5.11.13]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id E53B9CC620; Thu, 18 Feb 2021 10:35:54 +0000 (UTC) Received: from [10.36.114.34] (ovpn-114-34.ams2.redhat.com [10.36.114.34]) by smtp.corp.redhat.com (Postfix) with ESMTPS id B3DF460877; Thu, 18 Feb 2021 10:35:46 +0000 (UTC) Subject: Re: [PATCH v13 02/15] iommu: Introduce bind/unbind_guest_msi To: Keqian Zhu , eric.auger.pro@gmail.com, iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org, kvm@vger.kernel.org, kvmarm@lists.cs.columbia.edu, will@kernel.org, joro@8bytes.org, maz@kernel.org, robin.murphy@arm.com, alex.williamson@redhat.com Cc: jean-philippe@linaro.org, jacob.jun.pan@linux.intel.com, nicoleotsuka@gmail.com, vivek.gautam@arm.com, yi.l.liu@intel.com, zhangfei.gao@linaro.org References: <20201118112151.25412-1-eric.auger@redhat.com> <20201118112151.25412-3-eric.auger@redhat.com> <6a70d93d-329f-4129-bd90-03f8589c5de4@huawei.com> <1ef4f5ae-9ca6-7c6d-f8a9-31240e5688c2@redhat.com> From: Auger Eric Message-ID: <96edcdf3-baec-7432-529a-567a221d60a3@redhat.com> Date: Thu, 18 Feb 2021 11:35:44 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.6.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=windows-1252 Content-Language: en-US Content-Transfer-Encoding: 7bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.13 Precedence: bulk List-ID: X-Mailing-List: kvm@vger.kernel.org Hi Keqian, On 2/18/21 9:43 AM, Keqian Zhu wrote: > Hi Eric, > > On 2021/2/12 16:55, Auger Eric wrote: >> Hi Keqian, >> >> On 2/1/21 12:52 PM, Keqian Zhu wrote: >>> Hi Eric, >>> >>> On 2020/11/18 19:21, Eric Auger wrote: >>>> On ARM, MSI are translated by the SMMU. An IOVA is allocated >>>> for each MSI doorbell. If both the host and the guest are exposed >>>> with SMMUs, we end up with 2 different IOVAs allocated by each. >>>> guest allocates an IOVA (gIOVA) to map onto the guest MSI >>>> doorbell (gDB). The Host allocates another IOVA (hIOVA) to map >>>> onto the physical doorbell (hDB). >>>> >>>> So we end up with 2 untied mappings: >>>> S1 S2 >>>> gIOVA -> gDB >>>> hIOVA -> hDB >>>> >>>> Currently the PCI device is programmed by the host with hIOVA >>>> as MSI doorbell. So this does not work. >>>> >>>> This patch introduces an API to pass gIOVA/gDB to the host so >>>> that gIOVA can be reused by the host instead of re-allocating >>>> a new IOVA. So the goal is to create the following nested mapping: >>> Does the gDB can be reused under non-nested mode? >> >> Under non nested mode the hIOVA is allocated within the MSI reserved >> region exposed by the SMMU driver, [0x8000000, 80fffff]. see >> iommu_dma_prepare_msi/iommu_dma_get_msi_page in dma_iommu.c. this hIOVA >> is programmed in the physical device so that the physical SMMU >> translates it into the physical doorbell (hDB = host physical ITS > So, AFAIU, under non-nested mode, at smmu side, we reuse the workflow of non-virtualization scenario. Without virtualization, the host kernel also transparently allocates an iova to map the doorbell. With standard passthrough withou vIOMMU, the iova window is different (MSI RESV region). Thanks Eric > >> doorbell). The gDB is not used at pIOMMU programming level. It is only >> used when setting up the KVM irq route. >> >> Hope this answers your question. > Thanks for your explanation! >> > > Thanks, > Keqian > >>> >>>> >>>> S1 S2 >>>> gIOVA -> gDB -> hDB >>>> >>>> and program the PCI device with gIOVA MSI doorbell. >>>> >>>> In case we have several devices attached to this nested domain >>>> (devices belonging to the same group), they cannot be isolated >>>> on guest side either. So they should also end up in the same domain >>>> on guest side. We will enforce that all the devices attached to >>>> the host iommu domain use the same physical doorbell and similarly >>>> a single virtual doorbell mapping gets registered (1 single >>>> virtual doorbell is used on guest as well). >>>> >>> [...] >>> >>>> + * >>>> + * The associated IOVA can be reused by the host to create a nested >>>> + * stage2 binding mapping translating into the physical doorbell used >>>> + * by the devices attached to the domain. >>>> + * >>>> + * All devices within the domain must share the same physical doorbell. >>>> + * A single MSI GIOVA/GPA mapping can be attached to an iommu_domain. >>>> + */ >>>> + >>>> +int iommu_bind_guest_msi(struct iommu_domain *domain, >>>> + dma_addr_t giova, phys_addr_t gpa, size_t size) >>>> +{ >>>> + if (unlikely(!domain->ops->bind_guest_msi)) >>>> + return -ENODEV; >>>> + >>>> + return domain->ops->bind_guest_msi(domain, giova, gpa, size); >>>> +} >>>> +EXPORT_SYMBOL_GPL(iommu_bind_guest_msi); >>>> + >>>> +void iommu_unbind_guest_msi(struct iommu_domain *domain, >>>> + dma_addr_t iova) >>> nit: s/iova/giova >> sure >>> >>>> +{ >>>> + if (unlikely(!domain->ops->unbind_guest_msi)) >>>> + return; >>>> + >>>> + domain->ops->unbind_guest_msi(domain, iova); >>>> +} >>>> +EXPORT_SYMBOL_GPL(iommu_unbind_guest_msi); >>>> + >>> [...] >>> >>> Thanks, >>> Keqian >>> >> >> Thanks >> >> Eric >> >> . >> >