From: Christoph Hellwig <hch@lst.de>
To: "Michael Kelley (LINUX)" <mikelley@microsoft.com>
Cc: Christoph Hellwig <hch@lst.de>,
"iommu@lists.linux-foundation.org"
<iommu@lists.linux-foundation.org>,
"x86@kernel.org" <x86@kernel.org>,
Anshuman Khandual <anshuman.khandual@arm.com>,
Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>,
Stefano Stabellini <sstabellini@kernel.org>,
Boris Ostrovsky <boris.ostrovsky@oracle.com>,
Juergen Gross <jgross@suse.com>, Joerg Roedel <joro@8bytes.org>,
David Woodhouse <dwmw2@infradead.org>,
Lu Baolu <baolu.lu@linux.intel.com>,
Robin Murphy <robin.murphy@arm.com>,
"linux-arm-kernel@lists.infradead.org"
<linux-arm-kernel@lists.infradead.org>,
"xen-devel@lists.xenproject.org" <xen-devel@lists.xenproject.org>,
"linux-ia64@vger.kernel.org" <linux-ia64@vger.kernel.org>,
"linux-mips@vger.kernel.org" <linux-mips@vger.kernel.org>,
"linuxppc-dev@lists.ozlabs.org" <linuxppc-dev@lists.ozlabs.org>,
"linux-riscv@lists.infradead.org"
<linux-riscv@lists.infradead.org>,
"linux-s390@vger.kernel.org" <linux-s390@vger.kernel.org>,
"linux-hyperv@vger.kernel.org" <linux-hyperv@vger.kernel.org>,
"tboot-devel@lists.sourceforge.net"
<tboot-devel@lists.sourceforge.net>,
"linux-pci@vger.kernel.org" <linux-pci@vger.kernel.org>
Subject: Re: [PATCH 08/11] swiotlb: make the swiotlb_init interface more useful
Date: Mon, 28 Feb 2022 12:30:42 +0100 [thread overview]
Message-ID: <20220228113042.GA10570@lst.de> (raw)
In-Reply-To: <MN0PR21MB309816A344171B46735CA29CD7019@MN0PR21MB3098.namprd21.prod.outlook.com>
On Mon, Feb 28, 2022 at 02:53:39AM +0000, Michael Kelley (LINUX) wrote:
> From: Christoph Hellwig <hch@lst.de> Sent: Sunday, February 27, 2022 6:31 AM
> >
> > Pass a bool to pass if swiotlb needs to be enabled based on the
> > addressing needs and replace the verbose argument with a set of
> > flags, including one to force enable bounce buffering.
> >
> > Note that this patch removes the possibility to force xen-swiotlb
> > use using swiotlb=force on the command line on x86 (arm and arm64
> > never supported that), but this interface will be restored shortly.
> >
> > Signed-off-by: Christoph Hellwig <hch@lst.de>
> > ---
> > arch/arm/mm/init.c | 6 +----
> > arch/arm64/mm/init.c | 6 +----
> > arch/ia64/mm/init.c | 4 +--
> > arch/mips/cavium-octeon/dma-octeon.c | 2 +-
> > arch/mips/loongson64/dma.c | 2 +-
> > arch/mips/sibyte/common/dma.c | 2 +-
> > arch/powerpc/include/asm/swiotlb.h | 1 +
> > arch/powerpc/mm/mem.c | 3 ++-
> > arch/powerpc/platforms/pseries/setup.c | 3 ---
> > arch/riscv/mm/init.c | 8 +-----
> > arch/s390/mm/init.c | 3 +--
> > arch/x86/kernel/cpu/mshyperv.c | 8 ------
> > arch/x86/kernel/pci-dma.c | 15 ++++++-----
> > arch/x86/mm/mem_encrypt_amd.c | 3 ---
> > drivers/xen/swiotlb-xen.c | 4 +--
> > include/linux/swiotlb.h | 15 ++++++-----
> > include/trace/events/swiotlb.h | 29 ++++++++-------------
> > kernel/dma/swiotlb.c | 35 ++++++++++++++------------
> > 18 files changed, 56 insertions(+), 93 deletions(-)
>
> [snip]
>
> >
> > diff --git a/arch/x86/kernel/cpu/mshyperv.c b/arch/x86/kernel/cpu/mshyperv.c
> > index 5a99f993e6392..568274917f1cd 100644
> > --- a/arch/x86/kernel/cpu/mshyperv.c
> > +++ b/arch/x86/kernel/cpu/mshyperv.c
> > @@ -336,14 +336,6 @@ static void __init ms_hyperv_init_platform(void)
> > swiotlb_unencrypted_base = ms_hyperv.shared_gpa_boundary;
> > #endif
> > }
> > -
> > -#ifdef CONFIG_SWIOTLB
> > - /*
> > - * Enable swiotlb force mode in Isolation VM to
> > - * use swiotlb bounce buffer for dma transaction.
> > - */
> > - swiotlb_force = SWIOTLB_FORCE;
> > -#endif
>
> With this code removed, it's not clear to me what forces the use of the
> swiotlb in a Hyper-V isolated VM. The code in pci_swiotlb_detect_4g() doesn't
> catch this case because cc_platform_has(CC_ATTR_HOST_MEM_ENCRYPT)
> returns "false" in a Hyper-V guest. In the Hyper-V guest, it's only
> cc_platform_has(CC_ATTR_GUEST_MEM_ENCRYPT) that returns "true". I'm
> looking more closely at the meaning of the CC_ATTR_* values, and it may
> be that Hyper-V should also return "true" for CC_ATTR_MEM_ENCRYPT,
> but I don't think CC_ATTR_HOST_MEM_ENCRYPT should return "true".
Ok, I assumed that CC_ATTR_HOST_MEM_ENCRYPT returned true in this case.
I guess we just need to check for CC_ATTR_GUEST_MEM_ENCRYPT as well
there?
WARNING: multiple messages have this Message-ID (diff)
From: Christoph Hellwig <hch@lst.de>
To: "Michael Kelley (LINUX)" <mikelley@microsoft.com>
Cc: Christoph Hellwig <hch@lst.de>,
"iommu@lists.linux-foundation.org"
<iommu@lists.linux-foundation.org>,
"x86@kernel.org" <x86@kernel.org>,
Anshuman Khandual <anshuman.khandual@arm.com>,
Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>,
Stefano Stabellini <sstabellini@kernel.org>,
Boris Ostrovsky <boris.ostrovsky@oracle.com>,
Juergen Gross <jgross@suse.com>, Joerg Roedel <joro@8bytes.org>,
David Woodhouse <dwmw2@infradead.org>,
Lu Baolu <baolu.lu@linux.intel.com>,
Robin Murphy <robin.murphy@arm.com>,
"linux-arm-kernel@lists.infradead.org"
<linux-arm-kernel@lists.infradead.org>,
"xen-devel@lists.xenproject.org" <xen-devel@lists.xenproject.org>,
"linux-ia64@vger.kernel.org" <linux-ia64@vger.kernel.org>,
"linux-mips@vger.kernel.org" <linux-mips@vger.kernel.org>,
"linuxppc-dev@lists.ozlabs.org" <linuxppc-dev@lists.ozlabs.org>,
"linux-riscv@lists.infradead.org"
<linux-riscv@lists.infradead.org>,
"linux-s390@vger.kernel.org" <linux-s390@vger.kernel.org>,
"linux-hyperv@vger.kernel.org" <linux-hyperv@vger.kernel.org>,
"tboot-devel@lists.sourceforge.net"
<tboot-devel@lists.sourceforge.net>,
"linux-pci@vger.kernel.org" <linux-pci@vger.kernel.org>
Subject: Re: [PATCH 08/11] swiotlb: make the swiotlb_init interface more useful
Date: Mon, 28 Feb 2022 11:30:42 +0000 [thread overview]
Message-ID: <20220228113042.GA10570@lst.de> (raw)
In-Reply-To: <MN0PR21MB309816A344171B46735CA29CD7019@MN0PR21MB3098.namprd21.prod.outlook.com>
On Mon, Feb 28, 2022 at 02:53:39AM +0000, Michael Kelley (LINUX) wrote:
> From: Christoph Hellwig <hch@lst.de> Sent: Sunday, February 27, 2022 6:31 AM
> >
> > Pass a bool to pass if swiotlb needs to be enabled based on the
> > addressing needs and replace the verbose argument with a set of
> > flags, including one to force enable bounce buffering.
> >
> > Note that this patch removes the possibility to force xen-swiotlb
> > use using swiotlb=force on the command line on x86 (arm and arm64
> > never supported that), but this interface will be restored shortly.
> >
> > Signed-off-by: Christoph Hellwig <hch@lst.de>
> > ---
> > arch/arm/mm/init.c | 6 +----
> > arch/arm64/mm/init.c | 6 +----
> > arch/ia64/mm/init.c | 4 +--
> > arch/mips/cavium-octeon/dma-octeon.c | 2 +-
> > arch/mips/loongson64/dma.c | 2 +-
> > arch/mips/sibyte/common/dma.c | 2 +-
> > arch/powerpc/include/asm/swiotlb.h | 1 +
> > arch/powerpc/mm/mem.c | 3 ++-
> > arch/powerpc/platforms/pseries/setup.c | 3 ---
> > arch/riscv/mm/init.c | 8 +-----
> > arch/s390/mm/init.c | 3 +--
> > arch/x86/kernel/cpu/mshyperv.c | 8 ------
> > arch/x86/kernel/pci-dma.c | 15 ++++++-----
> > arch/x86/mm/mem_encrypt_amd.c | 3 ---
> > drivers/xen/swiotlb-xen.c | 4 +--
> > include/linux/swiotlb.h | 15 ++++++-----
> > include/trace/events/swiotlb.h | 29 ++++++++-------------
> > kernel/dma/swiotlb.c | 35 ++++++++++++++------------
> > 18 files changed, 56 insertions(+), 93 deletions(-)
>
> [snip]
>
> >
> > diff --git a/arch/x86/kernel/cpu/mshyperv.c b/arch/x86/kernel/cpu/mshyperv.c
> > index 5a99f993e6392..568274917f1cd 100644
> > --- a/arch/x86/kernel/cpu/mshyperv.c
> > +++ b/arch/x86/kernel/cpu/mshyperv.c
> > @@ -336,14 +336,6 @@ static void __init ms_hyperv_init_platform(void)
> > swiotlb_unencrypted_base = ms_hyperv.shared_gpa_boundary;
> > #endif
> > }
> > -
> > -#ifdef CONFIG_SWIOTLB
> > - /*
> > - * Enable swiotlb force mode in Isolation VM to
> > - * use swiotlb bounce buffer for dma transaction.
> > - */
> > - swiotlb_force = SWIOTLB_FORCE;
> > -#endif
>
> With this code removed, it's not clear to me what forces the use of the
> swiotlb in a Hyper-V isolated VM. The code in pci_swiotlb_detect_4g() doesn't
> catch this case because cc_platform_has(CC_ATTR_HOST_MEM_ENCRYPT)
> returns "false" in a Hyper-V guest. In the Hyper-V guest, it's only
> cc_platform_has(CC_ATTR_GUEST_MEM_ENCRYPT) that returns "true". I'm
> looking more closely at the meaning of the CC_ATTR_* values, and it may
> be that Hyper-V should also return "true" for CC_ATTR_MEM_ENCRYPT,
> but I don't think CC_ATTR_HOST_MEM_ENCRYPT should return "true".
Ok, I assumed that CC_ATTR_HOST_MEM_ENCRYPT returned true in this case.
I guess we just need to check for CC_ATTR_GUEST_MEM_ENCRYPT as well
there?
WARNING: multiple messages have this Message-ID (diff)
From: Christoph Hellwig <hch@lst.de>
To: "Michael Kelley (LINUX)" <mikelley@microsoft.com>
Cc: "linux-hyperv@vger.kernel.org" <linux-hyperv@vger.kernel.org>,
"x86@kernel.org" <x86@kernel.org>,
"linux-ia64@vger.kernel.org" <linux-ia64@vger.kernel.org>,
"linux-pci@vger.kernel.org" <linux-pci@vger.kernel.org>,
"linux-riscv@lists.infradead.org"
<linux-riscv@lists.infradead.org>, Christoph Hellwig <hch@lst.de>,
"linux-s390@vger.kernel.org" <linux-s390@vger.kernel.org>,
Stefano Stabellini <sstabellini@kernel.org>,
Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>,
"tboot-devel@lists.sourceforge.net"
<tboot-devel@lists.sourceforge.net>,
"xen-devel@lists.xenproject.org" <xen-devel@lists.xenproject.org>,
David Woodhouse <dwmw2@infradead.org>,
Anshuman Khandual <anshuman.khandual@arm.com>,
Boris Ostrovsky <boris.ostrovsky@oracle.com>,
"linux-arm-kernel@lists.infradead.org"
<linux-arm-kernel@lists.infradead.org>,
Juergen Gross <jgross@suse.com>,
"linuxppc-dev@lists.ozlabs.org" <linuxppc-dev@lists.ozlabs.org>,
"linux-mips@vger.kernel.org" <linux-mips@vger.kernel.org>,
"iommu@lists.linux-foundation.org"
<iommu@lists.linux-foundation.org>,
Robin Murphy <robin.murphy@arm.com>
Subject: Re: [PATCH 08/11] swiotlb: make the swiotlb_init interface more useful
Date: Mon, 28 Feb 2022 12:30:42 +0100 [thread overview]
Message-ID: <20220228113042.GA10570@lst.de> (raw)
In-Reply-To: <MN0PR21MB309816A344171B46735CA29CD7019@MN0PR21MB3098.namprd21.prod.outlook.com>
On Mon, Feb 28, 2022 at 02:53:39AM +0000, Michael Kelley (LINUX) wrote:
> From: Christoph Hellwig <hch@lst.de> Sent: Sunday, February 27, 2022 6:31 AM
> >
> > Pass a bool to pass if swiotlb needs to be enabled based on the
> > addressing needs and replace the verbose argument with a set of
> > flags, including one to force enable bounce buffering.
> >
> > Note that this patch removes the possibility to force xen-swiotlb
> > use using swiotlb=force on the command line on x86 (arm and arm64
> > never supported that), but this interface will be restored shortly.
> >
> > Signed-off-by: Christoph Hellwig <hch@lst.de>
> > ---
> > arch/arm/mm/init.c | 6 +----
> > arch/arm64/mm/init.c | 6 +----
> > arch/ia64/mm/init.c | 4 +--
> > arch/mips/cavium-octeon/dma-octeon.c | 2 +-
> > arch/mips/loongson64/dma.c | 2 +-
> > arch/mips/sibyte/common/dma.c | 2 +-
> > arch/powerpc/include/asm/swiotlb.h | 1 +
> > arch/powerpc/mm/mem.c | 3 ++-
> > arch/powerpc/platforms/pseries/setup.c | 3 ---
> > arch/riscv/mm/init.c | 8 +-----
> > arch/s390/mm/init.c | 3 +--
> > arch/x86/kernel/cpu/mshyperv.c | 8 ------
> > arch/x86/kernel/pci-dma.c | 15 ++++++-----
> > arch/x86/mm/mem_encrypt_amd.c | 3 ---
> > drivers/xen/swiotlb-xen.c | 4 +--
> > include/linux/swiotlb.h | 15 ++++++-----
> > include/trace/events/swiotlb.h | 29 ++++++++-------------
> > kernel/dma/swiotlb.c | 35 ++++++++++++++------------
> > 18 files changed, 56 insertions(+), 93 deletions(-)
>
> [snip]
>
> >
> > diff --git a/arch/x86/kernel/cpu/mshyperv.c b/arch/x86/kernel/cpu/mshyperv.c
> > index 5a99f993e6392..568274917f1cd 100644
> > --- a/arch/x86/kernel/cpu/mshyperv.c
> > +++ b/arch/x86/kernel/cpu/mshyperv.c
> > @@ -336,14 +336,6 @@ static void __init ms_hyperv_init_platform(void)
> > swiotlb_unencrypted_base = ms_hyperv.shared_gpa_boundary;
> > #endif
> > }
> > -
> > -#ifdef CONFIG_SWIOTLB
> > - /*
> > - * Enable swiotlb force mode in Isolation VM to
> > - * use swiotlb bounce buffer for dma transaction.
> > - */
> > - swiotlb_force = SWIOTLB_FORCE;
> > -#endif
>
> With this code removed, it's not clear to me what forces the use of the
> swiotlb in a Hyper-V isolated VM. The code in pci_swiotlb_detect_4g() doesn't
> catch this case because cc_platform_has(CC_ATTR_HOST_MEM_ENCRYPT)
> returns "false" in a Hyper-V guest. In the Hyper-V guest, it's only
> cc_platform_has(CC_ATTR_GUEST_MEM_ENCRYPT) that returns "true". I'm
> looking more closely at the meaning of the CC_ATTR_* values, and it may
> be that Hyper-V should also return "true" for CC_ATTR_MEM_ENCRYPT,
> but I don't think CC_ATTR_HOST_MEM_ENCRYPT should return "true".
Ok, I assumed that CC_ATTR_HOST_MEM_ENCRYPT returned true in this case.
I guess we just need to check for CC_ATTR_GUEST_MEM_ENCRYPT as well
there?
_______________________________________________
iommu mailing list
iommu@lists.linux-foundation.org
https://lists.linuxfoundation.org/mailman/listinfo/iommu
WARNING: multiple messages have this Message-ID (diff)
From: Christoph Hellwig <hch@lst.de>
To: "Michael Kelley (LINUX)" <mikelley@microsoft.com>
Cc: Christoph Hellwig <hch@lst.de>,
"iommu@lists.linux-foundation.org"
<iommu@lists.linux-foundation.org>,
"x86@kernel.org" <x86@kernel.org>,
Anshuman Khandual <anshuman.khandual@arm.com>,
Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>,
Stefano Stabellini <sstabellini@kernel.org>,
Boris Ostrovsky <boris.ostrovsky@oracle.com>,
Juergen Gross <jgross@suse.com>, Joerg Roedel <joro@8bytes.org>,
David Woodhouse <dwmw2@infradead.org>,
Lu Baolu <baolu.lu@linux.intel.com>,
Robin Murphy <robin.murphy@arm.com>,
"linux-arm-kernel@lists.infradead.org"
<linux-arm-kernel@lists.infradead.org>,
"xen-devel@lists.xenproject.org"
<xen-devel@lists.xenproject.org>,
"linux-ia64@vger.kernel.org" <linux-ia64@vger.kernel.org>,
"linux-mips@vger.kernel.org" <linux-mips@vger.kernel.org>,
"linuxppc-dev@lists.ozlabs.org" <linuxppc-dev@lists.ozlabs.org>,
"linux-riscv@lists.infradead.org"
<linux-riscv@lists.infradead.org>,
"linux-s390@vger.kernel.org" <linux-s390@vger.kernel.org>,
"linux-hyperv@vger.kernel.org" <linux-hyperv@vger.kernel.org>,
"tboot-devel@lists.sourceforge.net"
<tboot-devel@lists.sourceforge.net>,
"linux-pci@vger.kernel.org" <linux-pci@vger.kernel.org>
Subject: Re: [PATCH 08/11] swiotlb: make the swiotlb_init interface more useful
Date: Mon, 28 Feb 2022 12:30:42 +0100 [thread overview]
Message-ID: <20220228113042.GA10570@lst.de> (raw)
In-Reply-To: <MN0PR21MB309816A344171B46735CA29CD7019@MN0PR21MB3098.namprd21.prod.outlook.com>
On Mon, Feb 28, 2022 at 02:53:39AM +0000, Michael Kelley (LINUX) wrote:
> From: Christoph Hellwig <hch@lst.de> Sent: Sunday, February 27, 2022 6:31 AM
> >
> > Pass a bool to pass if swiotlb needs to be enabled based on the
> > addressing needs and replace the verbose argument with a set of
> > flags, including one to force enable bounce buffering.
> >
> > Note that this patch removes the possibility to force xen-swiotlb
> > use using swiotlb=force on the command line on x86 (arm and arm64
> > never supported that), but this interface will be restored shortly.
> >
> > Signed-off-by: Christoph Hellwig <hch@lst.de>
> > ---
> > arch/arm/mm/init.c | 6 +----
> > arch/arm64/mm/init.c | 6 +----
> > arch/ia64/mm/init.c | 4 +--
> > arch/mips/cavium-octeon/dma-octeon.c | 2 +-
> > arch/mips/loongson64/dma.c | 2 +-
> > arch/mips/sibyte/common/dma.c | 2 +-
> > arch/powerpc/include/asm/swiotlb.h | 1 +
> > arch/powerpc/mm/mem.c | 3 ++-
> > arch/powerpc/platforms/pseries/setup.c | 3 ---
> > arch/riscv/mm/init.c | 8 +-----
> > arch/s390/mm/init.c | 3 +--
> > arch/x86/kernel/cpu/mshyperv.c | 8 ------
> > arch/x86/kernel/pci-dma.c | 15 ++++++-----
> > arch/x86/mm/mem_encrypt_amd.c | 3 ---
> > drivers/xen/swiotlb-xen.c | 4 +--
> > include/linux/swiotlb.h | 15 ++++++-----
> > include/trace/events/swiotlb.h | 29 ++++++++-------------
> > kernel/dma/swiotlb.c | 35 ++++++++++++++------------
> > 18 files changed, 56 insertions(+), 93 deletions(-)
>
> [snip]
>
> >
> > diff --git a/arch/x86/kernel/cpu/mshyperv.c b/arch/x86/kernel/cpu/mshyperv.c
> > index 5a99f993e6392..568274917f1cd 100644
> > --- a/arch/x86/kernel/cpu/mshyperv.c
> > +++ b/arch/x86/kernel/cpu/mshyperv.c
> > @@ -336,14 +336,6 @@ static void __init ms_hyperv_init_platform(void)
> > swiotlb_unencrypted_base = ms_hyperv.shared_gpa_boundary;
> > #endif
> > }
> > -
> > -#ifdef CONFIG_SWIOTLB
> > - /*
> > - * Enable swiotlb force mode in Isolation VM to
> > - * use swiotlb bounce buffer for dma transaction.
> > - */
> > - swiotlb_force = SWIOTLB_FORCE;
> > -#endif
>
> With this code removed, it's not clear to me what forces the use of the
> swiotlb in a Hyper-V isolated VM. The code in pci_swiotlb_detect_4g() doesn't
> catch this case because cc_platform_has(CC_ATTR_HOST_MEM_ENCRYPT)
> returns "false" in a Hyper-V guest. In the Hyper-V guest, it's only
> cc_platform_has(CC_ATTR_GUEST_MEM_ENCRYPT) that returns "true". I'm
> looking more closely at the meaning of the CC_ATTR_* values, and it may
> be that Hyper-V should also return "true" for CC_ATTR_MEM_ENCRYPT,
> but I don't think CC_ATTR_HOST_MEM_ENCRYPT should return "true".
Ok, I assumed that CC_ATTR_HOST_MEM_ENCRYPT returned true in this case.
I guess we just need to check for CC_ATTR_GUEST_MEM_ENCRYPT as well
there?
_______________________________________________
linux-riscv mailing list
linux-riscv@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-riscv
WARNING: multiple messages have this Message-ID (diff)
From: Christoph Hellwig <hch@lst.de>
To: "Michael Kelley (LINUX)" <mikelley@microsoft.com>
Cc: "linux-hyperv@vger.kernel.org" <linux-hyperv@vger.kernel.org>,
"x86@kernel.org" <x86@kernel.org>,
"linux-ia64@vger.kernel.org" <linux-ia64@vger.kernel.org>,
"linux-pci@vger.kernel.org" <linux-pci@vger.kernel.org>,
"linux-riscv@lists.infradead.org"
<linux-riscv@lists.infradead.org>, Christoph Hellwig <hch@lst.de>,
"linux-s390@vger.kernel.org" <linux-s390@vger.kernel.org>,
Stefano Stabellini <sstabellini@kernel.org>,
Joerg Roedel <joro@8bytes.org>,
Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>,
"tboot-devel@lists.sourceforge.net"
<tboot-devel@lists.sourceforge.net>,
"xen-devel@lists.xenproject.org" <xen-devel@lists.xenproject.org>,
David Woodhouse <dwmw2@infradead.org>,
Anshuman Khandual <anshuman.khandual@arm.com>,
Boris Ostrovsky <boris.ostrovsky@oracle.com>,
"linux-arm-kernel@lists.infradead.org"
<linux-arm-kernel@lists.infradead.org>,
Juergen Gross <jgross@suse.com>,
"linuxppc-dev@lists.ozlabs.org" <linuxppc-dev@lists.ozlabs.org>,
"linux-mips@vger.kernel.org" <linux-mips@vger.kernel.org>,
"iommu@lists.linux-foundation.org"
<iommu@lists.linux-foundation.org>,
Robin Murphy <robin.murphy@arm.com>,
Lu Baolu <baolu.lu@linux.intel.com>
Subject: Re: [PATCH 08/11] swiotlb: make the swiotlb_init interface more useful
Date: Mon, 28 Feb 2022 12:30:42 +0100 [thread overview]
Message-ID: <20220228113042.GA10570@lst.de> (raw)
In-Reply-To: <MN0PR21MB309816A344171B46735CA29CD7019@MN0PR21MB3098.namprd21.prod.outlook.com>
On Mon, Feb 28, 2022 at 02:53:39AM +0000, Michael Kelley (LINUX) wrote:
> From: Christoph Hellwig <hch@lst.de> Sent: Sunday, February 27, 2022 6:31 AM
> >
> > Pass a bool to pass if swiotlb needs to be enabled based on the
> > addressing needs and replace the verbose argument with a set of
> > flags, including one to force enable bounce buffering.
> >
> > Note that this patch removes the possibility to force xen-swiotlb
> > use using swiotlb=force on the command line on x86 (arm and arm64
> > never supported that), but this interface will be restored shortly.
> >
> > Signed-off-by: Christoph Hellwig <hch@lst.de>
> > ---
> > arch/arm/mm/init.c | 6 +----
> > arch/arm64/mm/init.c | 6 +----
> > arch/ia64/mm/init.c | 4 +--
> > arch/mips/cavium-octeon/dma-octeon.c | 2 +-
> > arch/mips/loongson64/dma.c | 2 +-
> > arch/mips/sibyte/common/dma.c | 2 +-
> > arch/powerpc/include/asm/swiotlb.h | 1 +
> > arch/powerpc/mm/mem.c | 3 ++-
> > arch/powerpc/platforms/pseries/setup.c | 3 ---
> > arch/riscv/mm/init.c | 8 +-----
> > arch/s390/mm/init.c | 3 +--
> > arch/x86/kernel/cpu/mshyperv.c | 8 ------
> > arch/x86/kernel/pci-dma.c | 15 ++++++-----
> > arch/x86/mm/mem_encrypt_amd.c | 3 ---
> > drivers/xen/swiotlb-xen.c | 4 +--
> > include/linux/swiotlb.h | 15 ++++++-----
> > include/trace/events/swiotlb.h | 29 ++++++++-------------
> > kernel/dma/swiotlb.c | 35 ++++++++++++++------------
> > 18 files changed, 56 insertions(+), 93 deletions(-)
>
> [snip]
>
> >
> > diff --git a/arch/x86/kernel/cpu/mshyperv.c b/arch/x86/kernel/cpu/mshyperv.c
> > index 5a99f993e6392..568274917f1cd 100644
> > --- a/arch/x86/kernel/cpu/mshyperv.c
> > +++ b/arch/x86/kernel/cpu/mshyperv.c
> > @@ -336,14 +336,6 @@ static void __init ms_hyperv_init_platform(void)
> > swiotlb_unencrypted_base = ms_hyperv.shared_gpa_boundary;
> > #endif
> > }
> > -
> > -#ifdef CONFIG_SWIOTLB
> > - /*
> > - * Enable swiotlb force mode in Isolation VM to
> > - * use swiotlb bounce buffer for dma transaction.
> > - */
> > - swiotlb_force = SWIOTLB_FORCE;
> > -#endif
>
> With this code removed, it's not clear to me what forces the use of the
> swiotlb in a Hyper-V isolated VM. The code in pci_swiotlb_detect_4g() doesn't
> catch this case because cc_platform_has(CC_ATTR_HOST_MEM_ENCRYPT)
> returns "false" in a Hyper-V guest. In the Hyper-V guest, it's only
> cc_platform_has(CC_ATTR_GUEST_MEM_ENCRYPT) that returns "true". I'm
> looking more closely at the meaning of the CC_ATTR_* values, and it may
> be that Hyper-V should also return "true" for CC_ATTR_MEM_ENCRYPT,
> but I don't think CC_ATTR_HOST_MEM_ENCRYPT should return "true".
Ok, I assumed that CC_ATTR_HOST_MEM_ENCRYPT returned true in this case.
I guess we just need to check for CC_ATTR_GUEST_MEM_ENCRYPT as well
there?
WARNING: multiple messages have this Message-ID (diff)
From: Christoph Hellwig <hch@lst.de>
To: "Michael Kelley (LINUX)" <mikelley@microsoft.com>
Cc: Christoph Hellwig <hch@lst.de>,
"iommu@lists.linux-foundation.org"
<iommu@lists.linux-foundation.org>,
"x86@kernel.org" <x86@kernel.org>,
Anshuman Khandual <anshuman.khandual@arm.com>,
Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>,
Stefano Stabellini <sstabellini@kernel.org>,
Boris Ostrovsky <boris.ostrovsky@oracle.com>,
Juergen Gross <jgross@suse.com>, Joerg Roedel <joro@8bytes.org>,
David Woodhouse <dwmw2@infradead.org>,
Lu Baolu <baolu.lu@linux.intel.com>,
Robin Murphy <robin.murphy@arm.com>,
"linux-arm-kernel@lists.infradead.org"
<linux-arm-kernel@lists.infradead.org>,
"xen-devel@lists.xenproject.org"
<xen-devel@lists.xenproject.org>,
"linux-ia64@vger.kernel.org" <linux-ia64@vger.kernel.org>,
"linux-mips@vger.kernel.org" <linux-mips@vger.kernel.org>,
"linuxppc-dev@lists.ozlabs.org" <linuxppc-dev@lists.ozlabs.org>,
"linux-riscv@lists.infradead.org"
<linux-riscv@lists.infradead.org>,
"linux-s390@vger.kernel.org" <linux-s390@vger.kernel.org>,
"linux-hyperv@vger.kernel.org" <linux-hyperv@vger.kernel.org>,
"tboot-devel@lists.sourceforge.net"
<tboot-devel@lists.sourceforge.net>,
"linux-pci@vger.kernel.org" <linux-pci@vger.kernel.org>
Subject: Re: [PATCH 08/11] swiotlb: make the swiotlb_init interface more useful
Date: Mon, 28 Feb 2022 12:30:42 +0100 [thread overview]
Message-ID: <20220228113042.GA10570@lst.de> (raw)
In-Reply-To: <MN0PR21MB309816A344171B46735CA29CD7019@MN0PR21MB3098.namprd21.prod.outlook.com>
On Mon, Feb 28, 2022 at 02:53:39AM +0000, Michael Kelley (LINUX) wrote:
> From: Christoph Hellwig <hch@lst.de> Sent: Sunday, February 27, 2022 6:31 AM
> >
> > Pass a bool to pass if swiotlb needs to be enabled based on the
> > addressing needs and replace the verbose argument with a set of
> > flags, including one to force enable bounce buffering.
> >
> > Note that this patch removes the possibility to force xen-swiotlb
> > use using swiotlb=force on the command line on x86 (arm and arm64
> > never supported that), but this interface will be restored shortly.
> >
> > Signed-off-by: Christoph Hellwig <hch@lst.de>
> > ---
> > arch/arm/mm/init.c | 6 +----
> > arch/arm64/mm/init.c | 6 +----
> > arch/ia64/mm/init.c | 4 +--
> > arch/mips/cavium-octeon/dma-octeon.c | 2 +-
> > arch/mips/loongson64/dma.c | 2 +-
> > arch/mips/sibyte/common/dma.c | 2 +-
> > arch/powerpc/include/asm/swiotlb.h | 1 +
> > arch/powerpc/mm/mem.c | 3 ++-
> > arch/powerpc/platforms/pseries/setup.c | 3 ---
> > arch/riscv/mm/init.c | 8 +-----
> > arch/s390/mm/init.c | 3 +--
> > arch/x86/kernel/cpu/mshyperv.c | 8 ------
> > arch/x86/kernel/pci-dma.c | 15 ++++++-----
> > arch/x86/mm/mem_encrypt_amd.c | 3 ---
> > drivers/xen/swiotlb-xen.c | 4 +--
> > include/linux/swiotlb.h | 15 ++++++-----
> > include/trace/events/swiotlb.h | 29 ++++++++-------------
> > kernel/dma/swiotlb.c | 35 ++++++++++++++------------
> > 18 files changed, 56 insertions(+), 93 deletions(-)
>
> [snip]
>
> >
> > diff --git a/arch/x86/kernel/cpu/mshyperv.c b/arch/x86/kernel/cpu/mshyperv.c
> > index 5a99f993e6392..568274917f1cd 100644
> > --- a/arch/x86/kernel/cpu/mshyperv.c
> > +++ b/arch/x86/kernel/cpu/mshyperv.c
> > @@ -336,14 +336,6 @@ static void __init ms_hyperv_init_platform(void)
> > swiotlb_unencrypted_base = ms_hyperv.shared_gpa_boundary;
> > #endif
> > }
> > -
> > -#ifdef CONFIG_SWIOTLB
> > - /*
> > - * Enable swiotlb force mode in Isolation VM to
> > - * use swiotlb bounce buffer for dma transaction.
> > - */
> > - swiotlb_force = SWIOTLB_FORCE;
> > -#endif
>
> With this code removed, it's not clear to me what forces the use of the
> swiotlb in a Hyper-V isolated VM. The code in pci_swiotlb_detect_4g() doesn't
> catch this case because cc_platform_has(CC_ATTR_HOST_MEM_ENCRYPT)
> returns "false" in a Hyper-V guest. In the Hyper-V guest, it's only
> cc_platform_has(CC_ATTR_GUEST_MEM_ENCRYPT) that returns "true". I'm
> looking more closely at the meaning of the CC_ATTR_* values, and it may
> be that Hyper-V should also return "true" for CC_ATTR_MEM_ENCRYPT,
> but I don't think CC_ATTR_HOST_MEM_ENCRYPT should return "true".
Ok, I assumed that CC_ATTR_HOST_MEM_ENCRYPT returned true in this case.
I guess we just need to check for CC_ATTR_GUEST_MEM_ENCRYPT as well
there?
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
next prev parent reply other threads:[~2022-02-28 11:30 UTC|newest]
Thread overview: 124+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-02-27 14:30 cleanup swiotlb initialization v2 Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` [PATCH 01/11] dma-direct: use is_swiotlb_active in dma_direct_map_page Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` [PATCH 02/11] swiotlb: make swiotlb_exit a no-op if SWIOTLB_FORCE is set Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` [PATCH 03/11] swiotlb: simplify swiotlb_max_segment Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` [PATCH 04/11] swiotlb: rename swiotlb_late_init_with_default_size Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` [PATCH 05/11] swiotlb: pass a gfp_mask argument to swiotlb_init_late Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` [PATCH 06/11] MIPS/octeon: use swiotlb_init instead of open coding it Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` [PATCH 07/11] x86: remove the IOMMU table infrastructure Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-03-01 18:20 ` Konrad Rzeszutek Wilk
2022-03-01 18:20 ` Konrad Rzeszutek Wilk
2022-03-01 18:20 ` Konrad Rzeszutek Wilk
2022-03-01 18:20 ` Konrad Rzeszutek Wilk
2022-03-01 18:20 ` Konrad Rzeszutek Wilk
2022-03-01 18:20 ` Konrad Rzeszutek Wilk
2022-03-02 8:07 ` Christoph Hellwig
2022-03-02 8:07 ` Christoph Hellwig
2022-03-02 8:07 ` Christoph Hellwig
2022-03-02 8:07 ` Christoph Hellwig
2022-03-02 8:07 ` Christoph Hellwig
2022-03-02 8:07 ` Christoph Hellwig
2022-03-02 9:18 ` Anatoly Pugachev
2022-03-02 9:18 ` Anatoly Pugachev
2022-03-02 9:18 ` Anatoly Pugachev
2022-03-02 9:18 ` Anatoly Pugachev
2022-03-02 9:18 ` Anatoly Pugachev
2022-03-02 9:18 ` Anatoly Pugachev
2022-03-02 9:22 ` Christoph Hellwig
2022-03-02 9:22 ` Christoph Hellwig
2022-03-02 9:22 ` Christoph Hellwig
2022-03-02 9:22 ` Christoph Hellwig
2022-03-02 9:22 ` Christoph Hellwig
2022-03-02 9:22 ` Christoph Hellwig
2022-02-27 14:30 ` [PATCH 08/11] swiotlb: make the swiotlb_init interface more useful Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 18:15 ` Christophe Leroy
2022-02-27 18:15 ` Christophe Leroy
2022-02-27 18:15 ` Christophe Leroy
2022-02-27 18:15 ` Christophe Leroy
2022-02-27 18:15 ` Christophe Leroy
2022-02-27 18:15 ` Christophe Leroy
2022-02-28 2:53 ` Michael Kelley (LINUX)
2022-02-28 2:53 ` Michael Kelley (LINUX)
2022-02-28 2:53 ` Michael Kelley (LINUX)
2022-02-28 2:53 ` Michael Kelley (LINUX)
2022-02-28 2:53 ` Michael Kelley (LINUX) via iommu
2022-02-28 11:30 ` Christoph Hellwig [this message]
2022-02-28 11:30 ` Christoph Hellwig
2022-02-28 11:30 ` Christoph Hellwig
2022-02-28 11:30 ` Christoph Hellwig
2022-02-28 11:30 ` Christoph Hellwig
2022-02-28 11:30 ` Christoph Hellwig
2022-02-28 17:21 ` Michael Kelley (LINUX)
2022-02-28 17:21 ` Michael Kelley (LINUX)
2022-02-28 17:21 ` Michael Kelley (LINUX)
2022-02-28 17:21 ` Michael Kelley (LINUX)
2022-02-28 17:21 ` Michael Kelley (LINUX) via iommu
2022-02-27 14:30 ` [PATCH 09/11] swiotlb: add a SWIOTLB_ANY flag to lift the low memory restriction Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` [PATCH 10/11] swiotlb: merge swiotlb-xen initialization into swiotlb Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` [PATCH 11/11] x86: remove cruft from <asm/dma-mapping.h> Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
2022-02-27 14:30 ` Christoph Hellwig
-- strict thread matches above, loose matches on Subject: below --
2022-02-22 15:35 cleanup swiotlb initialization Christoph Hellwig
2022-02-22 15:35 ` [PATCH 08/11] swiotlb: make the swiotlb_init interface more useful Christoph Hellwig
2022-02-22 15:35 ` Christoph Hellwig
2022-02-22 15:35 ` Christoph Hellwig
2022-02-22 15:35 ` Christoph Hellwig
2022-02-22 15:35 ` Christoph Hellwig
2022-02-22 15:35 ` Christoph Hellwig
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20220228113042.GA10570@lst.de \
--to=hch@lst.de \
--cc=anshuman.khandual@arm.com \
--cc=baolu.lu@linux.intel.com \
--cc=boris.ostrovsky@oracle.com \
--cc=dwmw2@infradead.org \
--cc=iommu@lists.linux-foundation.org \
--cc=jgross@suse.com \
--cc=joro@8bytes.org \
--cc=konrad.wilk@oracle.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-hyperv@vger.kernel.org \
--cc=linux-ia64@vger.kernel.org \
--cc=linux-mips@vger.kernel.org \
--cc=linux-pci@vger.kernel.org \
--cc=linux-riscv@lists.infradead.org \
--cc=linux-s390@vger.kernel.org \
--cc=linuxppc-dev@lists.ozlabs.org \
--cc=mikelley@microsoft.com \
--cc=robin.murphy@arm.com \
--cc=sstabellini@kernel.org \
--cc=tboot-devel@lists.sourceforge.net \
--cc=x86@kernel.org \
--cc=xen-devel@lists.xenproject.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.