Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp2861747imm; Fri, 20 Jul 2018 06:16:49 -0700 (PDT) X-Google-Smtp-Source: AAOMgpcyGKwEKb+/WR5FGwkaqDCspu76/F2ekxkPgCkE83ImsMI1IMcLKlLcAms4BmsSKF5fvRC1 X-Received: by 2002:a17:902:301:: with SMTP id 1-v6mr2046187pld.127.1532092609315; Fri, 20 Jul 2018 06:16:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532092609; cv=none; d=google.com; s=arc-20160816; b=u966e7QQDYhfrg/fb5EKJNmvAfO7dEvfGD217lgsoT8Y++WMU8yIDOgIFzS5t9unk7 PlH5z/zC5rf42xLRGuB2ibmB030yY+Sm89KKMt+rRnyJ4Oo8XzN6B35M2tHDAHeVrPuv b/RRXhsGe0LUa6gPuWLzaq4Ft1TS26tUZaHqbBY8c4TZq91WJFgeyDkaiwnMB1vmcURd PGq14K5WCKwbLTu1bN8EPM6EdM3c2J7ygY8h50sa4FwGrqPr8cTloKmSpjxmNoN2+0ae ZUmvfpiXAK8IRXndYU5F4x0nrYB43sne7zT7kaVVtM/nAfaAKyZJMpEbaERQN4GzWQC/ jTYw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :arc-authentication-results; bh=BzOyrhysq9u2Jy+udu8kc2nTjk4NQTDUaKR0xFWa4z4=; b=PS0n6VfzpePTawDSn6CCnq5UMAxPRMyV2lzYBOLQWMzu0IAbhAtTU5G8KgymNTng3T oNX4I+CpfP+HZ8IPobV2z3EzIVlZn3YkCX0dbVtqeMOYxT9C2N2SY2GJSUqlSl4PbQtc FO72Zzbi5d6Slw7BUgSefz6/nhoCeYvmspROTOtGldb32QBLDbLdfviw8hx8WlSOTsjZ h/1YHQcoYJs9M7kFyBj/rAHa2vwwlq1km8aui3e9HNc+krBFXrPgFwKBDOyLGX3kZC3U kKcjSENwV6iqibbWAfvG9BrPt4j1yZ+/jWXFH+Hj2IZycNh5yMeW7IEpa68IIDkfQ/CX E2jA== 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 g80-v6si1849616pfk.53.2018.07.20.06.16.34; Fri, 20 Jul 2018 06:16:49 -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 S1731693AbeGTODu (ORCPT + 99 others); Fri, 20 Jul 2018 10:03:50 -0400 Received: from mx3-rdu2.redhat.com ([66.187.233.73]:42504 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1731361AbeGTODu (ORCPT ); Fri, 20 Jul 2018 10:03:50 -0400 Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.rdu2.redhat.com [10.11.54.4]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id F36EB4072CF7; Fri, 20 Jul 2018 13:15:33 +0000 (UTC) Received: from redhat.com (ovpn-121-184.rdu2.redhat.com [10.10.121.184]) by smtp.corp.redhat.com (Postfix) with SMTP id 097072026D6B; Fri, 20 Jul 2018 13:15:28 +0000 (UTC) Date: Fri, 20 Jul 2018 16:15:28 +0300 From: "Michael S. Tsirkin" To: Anshuman Khandual Cc: virtualization@lists.linux-foundation.org, linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, aik@ozlabs.ru, robh@kernel.org, joe@perches.com, elfring@users.sourceforge.net, david@gibson.dropbear.id.au, jasowang@redhat.com, benh@kernel.crashing.org, mpe@ellerman.id.au, hch@infradead.org, linuxram@us.ibm.com, haren@linux.vnet.ibm.com, paulus@samba.org, srikar@linux.vnet.ibm.com Subject: Re: [RFC 4/4] virtio: Add platform specific DMA API translation for virito devices Message-ID: <20180720160550-mutt-send-email-mst@kernel.org> References: <20180720035941.6844-1-khandual@linux.vnet.ibm.com> <20180720035941.6844-5-khandual@linux.vnet.ibm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180720035941.6844-5-khandual@linux.vnet.ibm.com> X-Scanned-By: MIMEDefang 2.78 on 10.11.54.4 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.7]); Fri, 20 Jul 2018 13:15:34 +0000 (UTC) X-Greylist: inspected by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.7]); Fri, 20 Jul 2018 13:15:34 +0000 (UTC) for IP:'10.11.54.4' DOMAIN:'int-mx04.intmail.prod.int.rdu2.redhat.com' HELO:'smtp.corp.redhat.com' FROM:'mst@redhat.com' RCPT:'' Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Jul 20, 2018 at 09:29:41AM +0530, Anshuman Khandual wrote: >Subject: Re: [RFC 4/4] virtio: Add platform specific DMA API translation for > virito devices s/virito/virtio/ > This adds a hook which a platform can define in order to allow it to > override virtio device's DMA OPS irrespective of whether it has the > flag VIRTIO_F_IOMMU_PLATFORM set or not. We want to use this to do > bounce-buffering of data on the new secure pSeries platform, currently > under development, where a KVM host cannot access all of the memory > space of a secure KVM guest. The host can only access the pages which > the guest has explicitly requested to be shared with the host, thus > the virtio implementation in the guest has to copy data to and from > shared pages. > > With this hook, the platform code in the secure guest can force the > use of swiotlb for virtio buffers, with a back-end for swiotlb which > will use a pool of pre-allocated shared pages. Thus all data being > sent or received by virtio devices will be copied through pages which > the host has access to. > > Signed-off-by: Anshuman Khandual > --- > arch/powerpc/include/asm/dma-mapping.h | 6 ++++++ > arch/powerpc/platforms/pseries/iommu.c | 6 ++++++ > drivers/virtio/virtio.c | 7 +++++++ > 3 files changed, 19 insertions(+) > > diff --git a/arch/powerpc/include/asm/dma-mapping.h b/arch/powerpc/include/asm/dma-mapping.h > index 8fa3945..bc5a9d3 100644 > --- a/arch/powerpc/include/asm/dma-mapping.h > +++ b/arch/powerpc/include/asm/dma-mapping.h > @@ -116,3 +116,9 @@ extern u64 __dma_get_required_mask(struct device *dev); > > #endif /* __KERNEL__ */ > #endif /* _ASM_DMA_MAPPING_H */ > + > +#define platform_override_dma_ops platform_override_dma_ops > + > +struct virtio_device; > + > +extern void platform_override_dma_ops(struct virtio_device *vdev); > diff --git a/arch/powerpc/platforms/pseries/iommu.c b/arch/powerpc/platforms/pseries/iommu.c > index 06f0296..5773bc7 100644 > --- a/arch/powerpc/platforms/pseries/iommu.c > +++ b/arch/powerpc/platforms/pseries/iommu.c > @@ -38,6 +38,7 @@ > #include > #include > #include > +#include > #include > #include > #include > @@ -1396,3 +1397,8 @@ static int __init disable_multitce(char *str) > __setup("multitce=", disable_multitce); > > machine_subsys_initcall_sync(pseries, tce_iommu_bus_notifier_init); > + > +void platform_override_dma_ops(struct virtio_device *vdev) > +{ > + /* Override vdev->parent.dma_ops if required */ > +} > diff --git a/drivers/virtio/virtio.c b/drivers/virtio/virtio.c > index 6b13987..432c332 100644 > --- a/drivers/virtio/virtio.c > +++ b/drivers/virtio/virtio.c > @@ -168,6 +168,12 @@ EXPORT_SYMBOL_GPL(virtio_add_status); > > const struct dma_map_ops virtio_direct_dma_ops; > > +#ifndef platform_override_dma_ops > +static inline void platform_override_dma_ops(struct virtio_device *vdev) > +{ > +} > +#endif > + > int virtio_finalize_features(struct virtio_device *dev) > { > int ret = dev->config->finalize_features(dev); > @@ -179,6 +185,7 @@ int virtio_finalize_features(struct virtio_device *dev) > if (virtio_has_iommu_quirk(dev)) > set_dma_ops(dev->dev.parent, &virtio_direct_dma_ops); > > + platform_override_dma_ops(dev); Is there a single place where virtio_has_iommu_quirk is called now? If so, we could put this into virtio_has_iommu_quirk then. > if (!virtio_has_feature(dev, VIRTIO_F_VERSION_1)) > return 0; > > -- > 2.9.3