* Re: [PATCH 1/2] arm: msm: Add System MMU support.
[not found] <1280270466-13503-1-git-send-email-stepanm@codeaurora.org>
@ 2010-07-27 22:43 ` Daniel Walker
2010-07-28 8:39 ` Arnd Bergmann
1 sibling, 0 replies; 47+ messages in thread
From: Daniel Walker @ 2010-07-27 22:43 UTC (permalink / raw)
To: Stepan Moskovchenko; +Cc: linux-arm-kernel, linux-kernel, linux-arm-msm
On Tue, 2010-07-27 at 15:41 -0700, Stepan Moskovchenko wrote:
> +/* Copyright (c) 2010, Code Aurora Forum. All rights reserved.
> + *
> + * Redistribution and use in source and binary forms, with or without
> + * modification, are permitted provided that the following conditions are
> + * met:
> + * * Redistributions of source code must retain the above copyright
> + * notice, this list of conditions and the following disclaimer.
> + * * Redistributions in binary form must reproduce the above
> + * copyright notice, this list of conditions and the following
> + * disclaimer in the documentation and/or other materials provided
> + * with the distribution.
> + * * Neither the name of Code Aurora Forum, Inc. nor the names of its
> + * contributors may be used to endorse or promote products derived
> + * from this software without specific prior written permission.
This should be GPLv2 ..
Daniel
--
Sent by an consultant of the Qualcomm Innovation Center, Inc.
The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
[not found] <1280270466-13503-1-git-send-email-stepanm@codeaurora.org>
2010-07-27 22:43 ` [PATCH 1/2] arm: msm: Add System MMU support Daniel Walker
@ 2010-07-28 8:39 ` Arnd Bergmann
2010-07-28 17:39 ` stepanm
1 sibling, 1 reply; 47+ messages in thread
From: Arnd Bergmann @ 2010-07-28 8:39 UTC (permalink / raw)
To: Stepan Moskovchenko
Cc: dwalker, linux-arm-kernel, linux-kernel, linux-arm-msm
On Wednesday 28 July 2010 00:41:06 Stepan Moskovchenko wrote:
>
> Add support for the System MMUs found on the 8x60 and 8x72
> families of Qualcomm chips. These SMMUs allow virtualization
> of the address space used by most of the multimedia cores
> on these chips.
>
How is this different from an IOMMU?
>From a very brief look, it seems that you should be using the
existing dma-mapping APIs here instead of making up your own.
Arnd
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-28 8:39 ` Arnd Bergmann
@ 2010-07-28 17:39 ` stepanm
2010-07-28 17:50 ` Arnd Bergmann
0 siblings, 1 reply; 47+ messages in thread
From: stepanm @ 2010-07-28 17:39 UTC (permalink / raw)
To: Arnd Bergmann
Cc: Stepan Moskovchenko, dwalker, linux-arm-kernel, linux-kernel,
linux-arm-msm
> On Wednesday 28 July 2010 00:41:06 Stepan Moskovchenko wrote:
>> Add support for the System MMUs found on the 8x60 and 8x72
>> families of Qualcomm chips. These SMMUs allow virtualization
>> of the address space used by most of the multimedia cores
>> on these chips.
>
> How is this different from an IOMMU?
>
> From a very brief look, it seems that you should be using the
> existing dma-mapping APIs here instead of making up your own.
>
> Arnd
These are just SMMU APIs, and the DMA-mapping API is one layer above this.
We have our own SMMU API for the MSM SoCs because we have muliple IOMMUs,
each one having multiple contexts, or even having multiple instances of
the same context. Our usage model is also quite a bit different from how
the DMA APIs are set up. I believe only two IOMMU drivers actually make
use of the DMA API (Intel and AMD) and the other ones (OMAP and other
SoCs) have their own APIs for their specific use cases.
Steve
Sent by an employee of the Qualcomm Innovation Center, Inc.
The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-28 17:39 ` stepanm
@ 2010-07-28 17:50 ` Arnd Bergmann
2010-07-28 21:21 ` Russell King - ARM Linux
2010-07-29 0:58 ` stepanm
0 siblings, 2 replies; 47+ messages in thread
From: Arnd Bergmann @ 2010-07-28 17:50 UTC (permalink / raw)
To: linux-arm-kernel; +Cc: stepanm, linux-arm-msm, dwalker, linux-kernel
On Wednesday 28 July 2010, stepanm@codeaurora.org wrote:
> > On Wednesday 28 July 2010 00:41:06 Stepan Moskovchenko wrote:
> >> Add support for the System MMUs found on the 8x60 and 8x72
> >> families of Qualcomm chips. These SMMUs allow virtualization
> >> of the address space used by most of the multimedia cores
> >> on these chips.
> >
> > How is this different from an IOMMU?
> >
> > From a very brief look, it seems that you should be using the
> > existing dma-mapping APIs here instead of making up your own.
> >
> > Arnd
>
>
> These are just SMMU APIs, and the DMA-mapping API is one layer above this.
>
> We have our own SMMU API for the MSM SoCs because we have muliple IOMMUs,
> each one having multiple contexts, or even having multiple instances of
> the same context. Our usage model is also quite a bit different from how
> the DMA APIs are set up. I believe only two IOMMU drivers actually make
> use of the DMA API (Intel and AMD) and the other ones (OMAP and other
> SoCs) have their own APIs for their specific use cases.
The DMA API is extremely flexible, it works just fine with all the
IOMMUs that I've seen so far. Please take a look at
include/asm-generic/dma-mapping-common.h and its users to see how
to use multiple IOMMUs depending on the device.
If the OMAP developers got this wrong, that's not your problem :-)
Arnd
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-28 17:50 ` Arnd Bergmann
@ 2010-07-28 21:21 ` Russell King - ARM Linux
2010-07-29 4:15 ` FUJITA Tomonori
2010-07-29 8:12 ` Arnd Bergmann
2010-07-29 0:58 ` stepanm
1 sibling, 2 replies; 47+ messages in thread
From: Russell King - ARM Linux @ 2010-07-28 21:21 UTC (permalink / raw)
To: Arnd Bergmann
Cc: linux-arm-kernel, linux-arm-msm, dwalker, stepanm, linux-kernel
On Wed, Jul 28, 2010 at 07:50:20PM +0200, Arnd Bergmann wrote:
> The DMA API is extremely flexible, it works just fine with all the
> IOMMUs that I've seen so far. Please take a look at
> include/asm-generic/dma-mapping-common.h and its users to see how
> to use multiple IOMMUs depending on the device.
We don't yet use those DMA API interface extensions because we haven't
had the need. If someone who has the need wants to put the effort in
though...
One of the problems with it though is the abstraction of the sync*
operations is the wrong way around for stuff like dmabounce - we want
to be passed the base address of the buffer (so we can look this up),
plus offset and length. We don't want to know just the region which
is affected.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-28 17:50 ` Arnd Bergmann
2010-07-28 21:21 ` Russell King - ARM Linux
@ 2010-07-29 0:58 ` stepanm
2010-07-29 3:35 ` FUJITA Tomonori
1 sibling, 1 reply; 47+ messages in thread
From: stepanm @ 2010-07-29 0:58 UTC (permalink / raw)
To: Arnd Bergmann
Cc: linux-arm-kernel, stepanm, linux-arm-msm, dwalker, linux-kernel
> On Wednesday 28 July 2010, stepanm@codeaurora.org wrote:
>> > On Wednesday 28 July 2010 00:41:06 Stepan Moskovchenko wrote:
>> >> Add support for the System MMUs found on the 8x60 and 8x72
>> >> families of Qualcomm chips. These SMMUs allow virtualization
>> >> of the address space used by most of the multimedia cores
>> >> on these chips.
>> >
>> > How is this different from an IOMMU?
>> >
>> > From a very brief look, it seems that you should be using the
>> > existing dma-mapping APIs here instead of making up your own.
>> >
>> > Arnd
>>
>>
>> These are just SMMU APIs, and the DMA-mapping API is one layer above
>> this.
>>
>> We have our own SMMU API for the MSM SoCs because we have muliple
>> IOMMUs,
>> each one having multiple contexts, or even having multiple instances of
>> the same context. Our usage model is also quite a bit different from how
>> the DMA APIs are set up. I believe only two IOMMU drivers actually make
>> use of the DMA API (Intel and AMD) and the other ones (OMAP and other
>> SoCs) have their own APIs for their specific use cases.
>
> The DMA API is extremely flexible, it works just fine with all the
> IOMMUs that I've seen so far. Please take a look at
> include/asm-generic/dma-mapping-common.h and its users to see how
> to use multiple IOMMUs depending on the device.
>
> If the OMAP developers got this wrong, that's not your problem :-)
>
> Arnd
Hi Arnd,
>From what I have been able to tell, the IOMMU interface was written by
AMD/Intel to allow the kvm code to work with a common IOMMU interface. To
that end, it isn't really a generic IOMMU interface. We have chosen to use
our own interface because it provides us with a lightweight way of
managing mappings for more esoteric MSM-specific use cases.
These map functions also take into account the way in which we map buffers
that we get from our own physical pool, because the current API was not
intended to deal with prioritized allocation of things like on/off-chip
memory. We are currently evaluating how to use the DMA API with our own
specialized allocator, which has been undergoing some discussion on the
other lists. We would like to use this allocator to maximize TLB
performance, as well as to prioritize the allocation from several
different memory pools.
Steve
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 0:58 ` stepanm
@ 2010-07-29 3:35 ` FUJITA Tomonori
2010-07-29 8:26 ` Arnd Bergmann
2010-07-31 2:30 ` Benjamin Herrenschmidt
0 siblings, 2 replies; 47+ messages in thread
From: FUJITA Tomonori @ 2010-07-29 3:35 UTC (permalink / raw)
To: stepanm; +Cc: arnd, linux-arm-kernel, linux-arm-msm, dwalker, linux-kernel
On Wed, 28 Jul 2010 17:58:50 -0700 (PDT)
stepanm@codeaurora.org wrote:
> >> These are just SMMU APIs, and the DMA-mapping API is one layer above
> >> this.
> >>
> >> We have our own SMMU API for the MSM SoCs because we have muliple
> >> IOMMUs,
> >> each one having multiple contexts, or even having multiple instances of
> >> the same context. Our usage model is also quite a bit different from how
> >> the DMA APIs are set up. I believe only two IOMMU drivers actually make
> >> use of the DMA API (Intel and AMD) and the other ones (OMAP and other
> >> SoCs) have their own APIs for their specific use cases.
> >
> > The DMA API is extremely flexible, it works just fine with all the
> > IOMMUs that I've seen so far. Please take a look at
> > include/asm-generic/dma-mapping-common.h and its users to see how
> > to use multiple IOMMUs depending on the device.
> >
> > If the OMAP developers got this wrong, that's not your problem :-)
> >
> > Arnd
>
> Hi Arnd,
>
> From what I have been able to tell, the IOMMU interface was written by
> AMD/Intel to allow the kvm code to work with a common IOMMU interface. To
Don't confuse the IOMMU interface with the DMA API that Arnd
mentioned.
They are not related at all.
The DMA API is defined in Documentation/DMA-API.txt.
Arnd told you that include/asm-generic/dma-mapping-common.h is the
library to support the DMA API with multiple IOMMUs. Lots of
architectures (x86, powerpc, sh, alpha, ia64, microblaze, sparc)
use it.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-28 21:21 ` Russell King - ARM Linux
@ 2010-07-29 4:15 ` FUJITA Tomonori
2010-07-29 8:12 ` Arnd Bergmann
1 sibling, 0 replies; 47+ messages in thread
From: FUJITA Tomonori @ 2010-07-29 4:15 UTC (permalink / raw)
To: linux; +Cc: arnd, linux-arm-kernel, linux-arm-msm, dwalker, stepanm,
linux-kernel
On Wed, 28 Jul 2010 22:21:56 +0100
Russell King - ARM Linux <linux@arm.linux.org.uk> wrote:
> On Wed, Jul 28, 2010 at 07:50:20PM +0200, Arnd Bergmann wrote:
> > The DMA API is extremely flexible, it works just fine with all the
> > IOMMUs that I've seen so far. Please take a look at
> > include/asm-generic/dma-mapping-common.h and its users to see how
> > to use multiple IOMMUs depending on the device.
>
> We don't yet use those DMA API interface extensions because we haven't
> had the need. If someone who has the need wants to put the effort in
> though...
>
> One of the problems with it though is the abstraction of the sync*
> operations is the wrong way around for stuff like dmabounce - we want
> to be passed the base address of the buffer (so we can look this up),
> plus offset and length. We don't want to know just the region which
> is affected.
We can't pass the base address because the DMA API callers don't pass
the base address for dma_sync_single_for_{device|cpu}.
dma_sync_single_range_for_* requires the base address but they are
obsolete.
So you need to fix dmabounce. Actually, I send you a patch to fix
dmabounce long ago (looks like not applied yet):
http://kerneltrap.org/mailarchive/linux-netdev/2010/4/5/6274046
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-28 21:21 ` Russell King - ARM Linux
2010-07-29 4:15 ` FUJITA Tomonori
@ 2010-07-29 8:12 ` Arnd Bergmann
2010-07-29 11:47 ` Russell King - ARM Linux
1 sibling, 1 reply; 47+ messages in thread
From: Arnd Bergmann @ 2010-07-29 8:12 UTC (permalink / raw)
To: linux-arm-kernel, FUJITA Tomonori
Cc: Russell King - ARM Linux, linux-arm-msm, dwalker, stepanm,
linux-kernel
On Wednesday 28 July 2010 23:21:56 Russell King - ARM Linux wrote:
> On Wed, Jul 28, 2010 at 07:50:20PM +0200, Arnd Bergmann wrote:
> > The DMA API is extremely flexible, it works just fine with all the
> > IOMMUs that I've seen so far. Please take a look at
> > include/asm-generic/dma-mapping-common.h and its users to see how
> > to use multiple IOMMUs depending on the device.
>
> We don't yet use those DMA API interface extensions because we haven't
> had the need. If someone who has the need wants to put the effort in
> though...
Right, it shouldn't be hard now that the groundwork for that is done.
Also, it's only really needed if you have IOMMUs of different types in the
same system. If msm doesn't have any swiotlb or dmabounce devices,
it could always use the same implementation for all devices.
> One of the problems with it though is the abstraction of the sync*
> operations is the wrong way around for stuff like dmabounce - we want
> to be passed the base address of the buffer (so we can look this up),
> plus offset and length. We don't want to know just the region which
> is affected.
Yes, but that is an unrelated (dmabounce specific) problem that seems to
be fixed by an existing patch.
The driver posted by Stepan doesn't even support the dma_sync_single_*
style operations, and I don't think it can run into that specific problem.
Are there even (hardware) IOMMUs that are connected to noncoherent
buses? AFAICT, anything that needs to flush a dcache range in dma_sync_*
has a trivial mapping between bus and phys addresses.
Arnd
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 3:35 ` FUJITA Tomonori
@ 2010-07-29 8:26 ` Arnd Bergmann
2010-07-29 8:35 ` FUJITA Tomonori
` (2 more replies)
2010-07-31 2:30 ` Benjamin Herrenschmidt
1 sibling, 3 replies; 47+ messages in thread
From: Arnd Bergmann @ 2010-07-29 8:26 UTC (permalink / raw)
To: FUJITA Tomonori, Joerg Roedel
Cc: stepanm, linux-arm-kernel, linux-arm-msm, dwalker, linux-kernel
On Thursday 29 July 2010 05:35:48 FUJITA Tomonori wrote:
> >
> > From what I have been able to tell, the IOMMU interface was written by
> > AMD/Intel to allow the kvm code to work with a common IOMMU interface. To
>
> Don't confuse the IOMMU interface with the DMA API that Arnd
> mentioned.
>
> They are not related at all.
Exactly, thanks for the clarification. I also didn't realize that there
is now an include/linux/iommu.h file that only describes the PCI SR-IOV
interfaces, unlike the generic IOMMU support that we have in your
include/linux/dma-mapping.h file.
Maybe we should rename linux/iommu.h to something more specific so we
can reduce this confusion in the future.
Arnd
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 8:26 ` Arnd Bergmann
@ 2010-07-29 8:35 ` FUJITA Tomonori
2010-07-29 8:40 ` Roedel, Joerg
2010-07-31 3:15 ` Benjamin Herrenschmidt
2 siblings, 0 replies; 47+ messages in thread
From: FUJITA Tomonori @ 2010-07-29 8:35 UTC (permalink / raw)
To: arnd
Cc: fujita.tomonori, joerg.roedel, stepanm, linux-arm-kernel,
linux-arm-msm, dwalker, linux-kernel
On Thu, 29 Jul 2010 10:26:55 +0200
Arnd Bergmann <arnd@arndb.de> wrote:
> On Thursday 29 July 2010 05:35:48 FUJITA Tomonori wrote:
> > >
> > > From what I have been able to tell, the IOMMU interface was written by
> > > AMD/Intel to allow the kvm code to work with a common IOMMU interface. To
> >
> > Don't confuse the IOMMU interface with the DMA API that Arnd
> > mentioned.
> >
> > They are not related at all.
>
> Exactly, thanks for the clarification. I also didn't realize that there
> is now an include/linux/iommu.h file that only describes the PCI SR-IOV
> interfaces, unlike the generic IOMMU support that we have in your
> include/linux/dma-mapping.h file.
>
> Maybe we should rename linux/iommu.h to something more specific so we
> can reduce this confusion in the future.
I also said that linux/iommu.h was a bad name when it was introduced
:) Well, the author disagreed. Now the name actually confuse
developers. The author might rethink.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 8:26 ` Arnd Bergmann
2010-07-29 8:35 ` FUJITA Tomonori
@ 2010-07-29 8:40 ` Roedel, Joerg
2010-07-29 8:46 ` FUJITA Tomonori
2010-07-31 3:15 ` Benjamin Herrenschmidt
2 siblings, 1 reply; 47+ messages in thread
From: Roedel, Joerg @ 2010-07-29 8:40 UTC (permalink / raw)
To: Arnd Bergmann
Cc: FUJITA Tomonori, stepanm@codeaurora.org,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Thu, Jul 29, 2010 at 04:26:55AM -0400, Arnd Bergmann wrote:
> On Thursday 29 July 2010 05:35:48 FUJITA Tomonori wrote:
> > >
> > > From what I have been able to tell, the IOMMU interface was written by
> > > AMD/Intel to allow the kvm code to work with a common IOMMU interface. To
> >
> > Don't confuse the IOMMU interface with the DMA API that Arnd
> > mentioned.
> >
> > They are not related at all.
Thats not 100% true. They are not strictly related, but they are related
as they may use the same backend kernel drivers to provide their
functionality. Both APIs exist for different purposes, of course.
> Exactly, thanks for the clarification. I also didn't realize that there
> is now an include/linux/iommu.h file that only describes the PCI SR-IOV
> interfaces, unlike the generic IOMMU support that we have in your
> include/linux/dma-mapping.h file.
The IOMMU-API is not about SR-IOV. It is about the capabilities of
modern IOMMU hardware that we can not provide to the kernel with the
DMA-API such as the ability to choose ourself at which io-virtual
address a given cpu physical address should be mapped.
Also I wouldn't call the DMA-API an IOMMU interface. The API does not
depend on an IOMMU which is an important difference to the IOMMU-API.
The IOMMU-API is probably not generic enough to handle all kinds of
IOMMUs but its closer to a generic IOMMU-API than the DMA-API.
Joerg
--
Joerg Roedel - AMD Operating System Research Center
Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
General Managers: Alberto Bozzo, Andrew Bowd
Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr. 43632
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 8:40 ` Roedel, Joerg
@ 2010-07-29 8:46 ` FUJITA Tomonori
2010-07-29 9:06 ` Roedel, Joerg
0 siblings, 1 reply; 47+ messages in thread
From: FUJITA Tomonori @ 2010-07-29 8:46 UTC (permalink / raw)
To: Joerg.Roedel
Cc: arnd, fujita.tomonori, stepanm, linux-arm-kernel, linux-arm-msm,
dwalker, linux-kernel
On Thu, 29 Jul 2010 10:40:19 +0200
"Roedel, Joerg" <Joerg.Roedel@amd.com> wrote:
> The IOMMU-API is not about SR-IOV.
That's true. However, the point is that include/iommu.h is far from
the IOMMU-API.
You could still insist that include/iommu.h is designed for the
generic IOMMU-API. But the fact is that it's designed for very
specific purposes. No intention to make it for generic purposes.
Since you added it two years ago, nobody has tried to extend
it. Instead, we have something like
arch/arm/plat-omap/include/plat/iommu.h.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 8:46 ` FUJITA Tomonori
@ 2010-07-29 9:06 ` Roedel, Joerg
2010-07-29 9:14 ` FUJITA Tomonori
2010-07-30 5:19 ` stepanm
0 siblings, 2 replies; 47+ messages in thread
From: Roedel, Joerg @ 2010-07-29 9:06 UTC (permalink / raw)
To: FUJITA Tomonori
Cc: arnd@arndb.de, stepanm@codeaurora.org,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Thu, Jul 29, 2010 at 04:46:59AM -0400, FUJITA Tomonori wrote:
> On Thu, 29 Jul 2010 10:40:19 +0200
> "Roedel, Joerg" <Joerg.Roedel@amd.com> wrote:
>
> > The IOMMU-API is not about SR-IOV.
>
> That's true. However, the point is that include/iommu.h is far from
> the IOMMU-API.
>
> You could still insist that include/iommu.h is designed for the
> generic IOMMU-API. But the fact is that it's designed for very
> specific purposes. No intention to make it for generic purposes.
I have no clue about the ARM iommus on the omap-platform. From a quick
look into the header file I see some similarities to the IOMMU-API. I am
also very open for discussions about how the IOMMU-API could be extended
to fit the needs of other platforms. Only because nobody has tried to
discuss about such an effort is no reason to push the IOMMU-API back.
>
> Since you added it two years ago, nobody has tried to extend
> it. Instead, we have something like
> arch/arm/plat-omap/include/plat/iommu.h.
And I think we should try to merge this platform-specific functionality
into the IOMMU-API.
Joerg
--
Joerg Roedel - AMD Operating System Research Center
Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
General Managers: Alberto Bozzo, Andrew Bowd
Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr. 43632
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 9:06 ` Roedel, Joerg
@ 2010-07-29 9:14 ` FUJITA Tomonori
2010-07-29 9:25 ` Roedel, Joerg
2010-07-29 9:28 ` Roedel, Joerg
2010-07-30 5:19 ` stepanm
1 sibling, 2 replies; 47+ messages in thread
From: FUJITA Tomonori @ 2010-07-29 9:14 UTC (permalink / raw)
To: Joerg.Roedel
Cc: fujita.tomonori, arnd, stepanm, linux-arm-kernel, linux-arm-msm,
dwalker, linux-kernel
On Thu, 29 Jul 2010 11:06:08 +0200
"Roedel, Joerg" <Joerg.Roedel@amd.com> wrote:
> On Thu, Jul 29, 2010 at 04:46:59AM -0400, FUJITA Tomonori wrote:
> > On Thu, 29 Jul 2010 10:40:19 +0200
> > "Roedel, Joerg" <Joerg.Roedel@amd.com> wrote:
> >
> > > The IOMMU-API is not about SR-IOV.
> >
> > That's true. However, the point is that include/iommu.h is far from
> > the IOMMU-API.
> >
> > You could still insist that include/iommu.h is designed for the
> > generic IOMMU-API. But the fact is that it's designed for very
> > specific purposes. No intention to make it for generic purposes.
>
> I have no clue about the ARM iommus on the omap-platform. From a quick
> look into the header file I see some similarities to the IOMMU-API. I am
ARM's iommu stuff might be more appropriate as the IOMMU-API than
include/linux/iommu.h
> also very open for discussions about how the IOMMU-API could be extended
> to fit the needs of other platforms. Only because nobody has tried to
> discuss about such an effort is no reason to push the IOMMU-API back.
Well, the reason (nobody has tried) might be that linux/iommu.h
doesn't look something intended for the generic IOMMU-API.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 9:14 ` FUJITA Tomonori
@ 2010-07-29 9:25 ` Roedel, Joerg
2010-07-29 9:28 ` Roedel, Joerg
1 sibling, 0 replies; 47+ messages in thread
From: Roedel, Joerg @ 2010-07-29 9:25 UTC (permalink / raw)
To: FUJITA Tomonori
Cc: arnd@arndb.de, stepanm@codeaurora.org,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Thu, Jul 29, 2010 at 05:14:49AM -0400, FUJITA Tomonori wrote:
> On Thu, 29 Jul 2010 11:06:08 +0200
> "Roedel, Joerg" <Joerg.Roedel@amd.com> wrote:
> > I have no clue about the ARM iommus on the omap-platform. From a quick
> > look into the header file I see some similarities to the IOMMU-API. I am
>
> ARM's iommu stuff might be more appropriate as the IOMMU-API than
> include/linux/iommu.h
Then lets add this functionality to the generic IOMMU-API.
> > also very open for discussions about how the IOMMU-API could be extended
> > to fit the needs of other platforms. Only because nobody has tried to
> > discuss about such an effort is no reason to push the IOMMU-API back.
>
> Well, the reason (nobody has tried) might be that linux/iommu.h
> doesn't look something intended for the generic IOMMU-API.
How does it not look like a generic intention? The function names are
all generic and do not express that this API should only be used for
KVM. If you talk about the design of the API itself, it was designed for
the IOMMUs I was aware of at the time writing the API (in fact, the
initial design was not my own, it was a generalization of the VT-d
interfaces for KVM).
In other words it was a bottom-up approach to fit the needs of the time
it was written. But its an kernel-only API so we can easily change it
and extend it for other users/iommus when the need arises. I think this
is the way we should go instead of letting each architecture design
their own IOMMU-interfaces.
Joerg
--
Joerg Roedel - AMD Operating System Research Center
Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
General Managers: Alberto Bozzo, Andrew Bowd
Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr. 43632
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 9:14 ` FUJITA Tomonori
2010-07-29 9:25 ` Roedel, Joerg
@ 2010-07-29 9:28 ` Roedel, Joerg
2010-07-29 9:44 ` FUJITA Tomonori
1 sibling, 1 reply; 47+ messages in thread
From: Roedel, Joerg @ 2010-07-29 9:28 UTC (permalink / raw)
To: FUJITA Tomonori
Cc: arnd@arndb.de, stepanm@codeaurora.org,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Thu, Jul 29, 2010 at 05:14:49AM -0400, FUJITA Tomonori wrote:
> Well, the reason (nobody has tried) might be that linux/iommu.h
> doesn't look something intended for the generic IOMMU-API.
Oh, and as an additional note, the reason might also be that people were
not aware of its existence :-)
--
Joerg Roedel - AMD Operating System Research Center
Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
General Managers: Alberto Bozzo, Andrew Bowd
Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr. 43632
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 9:28 ` Roedel, Joerg
@ 2010-07-29 9:44 ` FUJITA Tomonori
2010-07-29 10:01 ` Roedel, Joerg
0 siblings, 1 reply; 47+ messages in thread
From: FUJITA Tomonori @ 2010-07-29 9:44 UTC (permalink / raw)
To: Joerg.Roedel
Cc: fujita.tomonori, arnd, stepanm, linux-arm-kernel, linux-arm-msm,
dwalker, linux-kernel
On Thu, 29 Jul 2010 11:28:21 +0200
"Roedel, Joerg" <Joerg.Roedel@amd.com> wrote:
> On Thu, Jul 29, 2010 at 05:14:49AM -0400, FUJITA Tomonori wrote:
> > Well, the reason (nobody has tried) might be that linux/iommu.h
> > doesn't look something intended for the generic IOMMU-API.
>
> Oh, and as an additional note, the reason might also be that people were
> not aware of its existence :-)
No. People actually read it and think that it's not intended for
generic purposes, i.e., it was designed for VT-d/AMD-IOMMU with KVM:
http://lkml.org/lkml/2010/7/28/470
You designed it for what you need at the time. It should have been
named appropriately to avoid confusion. Later, when we actually
understand what other IOMMUs need, we can evolve the specific API for
generic purposes. Then we can rename the API to more generic.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 9:44 ` FUJITA Tomonori
@ 2010-07-29 10:01 ` Roedel, Joerg
2010-07-29 11:25 ` Arnd Bergmann
0 siblings, 1 reply; 47+ messages in thread
From: Roedel, Joerg @ 2010-07-29 10:01 UTC (permalink / raw)
To: FUJITA Tomonori
Cc: arnd@arndb.de, stepanm@codeaurora.org,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Thu, Jul 29, 2010 at 05:44:13AM -0400, FUJITA Tomonori wrote:
> On Thu, 29 Jul 2010 11:28:21 +0200
> "Roedel, Joerg" <Joerg.Roedel@amd.com> wrote:
>
> > On Thu, Jul 29, 2010 at 05:14:49AM -0400, FUJITA Tomonori wrote:
> > > Well, the reason (nobody has tried) might be that linux/iommu.h
> > > doesn't look something intended for the generic IOMMU-API.
> >
> > Oh, and as an additional note, the reason might also be that people were
> > not aware of its existence :-)
>
> No. People actually read it and think that it's not intended for
> generic purposes, i.e., it was designed for VT-d/AMD-IOMMU with KVM:
>
> http://lkml.org/lkml/2010/7/28/470
This states the as-is situation. There is not a single sentence that
states why the iommu-api can't be extended to fit their needs. Nobody
has ever written me an email about this to discuss this possibility.
> You designed it for what you need at the time. It should have been
> named appropriately to avoid confusion. Later, when we actually
> understand what other IOMMUs need, we can evolve the specific API for
> generic purposes. Then we can rename the API to more generic.
At the time the iommu-api was written is was generic enough for what we
had. So it was designed as an generic API. At this point in time nobody
knew what the future requirements would we. So today it turns out that
it is not generic enough anymore for latest hardware. The logical
consequence is to fix this in the iommu-api.
Joerg
--
Joerg Roedel - AMD Operating System Research Center
Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
General Managers: Alberto Bozzo, Andrew Bowd
Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr. 43632
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 10:01 ` Roedel, Joerg
@ 2010-07-29 11:25 ` Arnd Bergmann
2010-07-29 12:12 ` Roedel, Joerg
0 siblings, 1 reply; 47+ messages in thread
From: Arnd Bergmann @ 2010-07-29 11:25 UTC (permalink / raw)
To: Roedel, Joerg
Cc: FUJITA Tomonori, stepanm@codeaurora.org,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Thursday 29 July 2010, Roedel, Joerg wrote:
> > You designed it for what you need at the time. It should have been
> > named appropriately to avoid confusion. Later, when we actually
> > understand what other IOMMUs need, we can evolve the specific API for
> > generic purposes. Then we can rename the API to more generic.
>
> At the time the iommu-api was written is was generic enough for what we
> had. So it was designed as an generic API. At this point in time nobody
> knew what the future requirements would we. So today it turns out that
> it is not generic enough anymore for latest hardware. The logical
> consequence is to fix this in the iommu-api.
Well, I think the real question is why we have two APIs that both claim
to work with IOMMUs in a generic way and how we could unify the two.
The Intel and AMD IOMMU drivers currently register at both the DMA
API and the IOMMU API. The first one is used by everything except
KVM and the second is only used by KVM.
I really think we should not extend the (KVM) IOMMU API further but
just use the generic DMA mapping api for KVM and extend it as necessary.
It already has the concept of cache coherency and mapping/unmapping
that are in the IOMMU API and could be extended to support domains
as well, through the use of dma_attrs.
Arnd
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 8:12 ` Arnd Bergmann
@ 2010-07-29 11:47 ` Russell King - ARM Linux
2010-07-30 6:14 ` FUJITA Tomonori
0 siblings, 1 reply; 47+ messages in thread
From: Russell King - ARM Linux @ 2010-07-29 11:47 UTC (permalink / raw)
To: Arnd Bergmann
Cc: linux-arm-kernel, FUJITA Tomonori, linux-arm-msm, dwalker,
stepanm, linux-kernel
On Thu, Jul 29, 2010 at 10:12:05AM +0200, Arnd Bergmann wrote:
> On Wednesday 28 July 2010 23:21:56 Russell King - ARM Linux wrote:
> > On Wed, Jul 28, 2010 at 07:50:20PM +0200, Arnd Bergmann wrote:
> > > The DMA API is extremely flexible, it works just fine with all the
> > > IOMMUs that I've seen so far. Please take a look at
> > > include/asm-generic/dma-mapping-common.h and its users to see how
> > > to use multiple IOMMUs depending on the device.
> >
> > We don't yet use those DMA API interface extensions because we haven't
> > had the need. If someone who has the need wants to put the effort in
> > though...
>
> Right, it shouldn't be hard now that the groundwork for that is done.
> Also, it's only really needed if you have IOMMUs of different types in the
> same system. If msm doesn't have any swiotlb or dmabounce devices,
> it could always use the same implementation for all devices.
>
> > One of the problems with it though is the abstraction of the sync*
> > operations is the wrong way around for stuff like dmabounce - we want
> > to be passed the base address of the buffer (so we can look this up),
> > plus offset and length. We don't want to know just the region which
> > is affected.
>
> Yes, but that is an unrelated (dmabounce specific) problem that seems to
> be fixed by an existing patch.
It's not unrelated because it stands in the way of using that interface.
The patch also seems to be buggy in that it doesn't fix the for_device
case - it leaves 'off' as zero.
I'm also not sold on this idea that the sync_range API is being obsoleted.
It seems to me to be a step in the wrong direction. The range API is a
natural subset of the 'normal' sync API, yet people are trying to shoehorn
the range API into the 'norma' API. If anything it's the 'normal' API
which should be obsoleted as it provides reduced information to
implementations, which then have to start fuzzy-matching the passed
address.
If we're going to start fuzzy-matching the passed address, then I think
we also need to add detection of overlapping mappings and BUG() on such
cases - otherwise we risk the possibility of having multiple overlapping
mappings and hitting the wrong mapping with this reduced-information sync
API.
> The driver posted by Stepan doesn't even support the dma_sync_single_*
> style operations, and I don't think it can run into that specific problem.
> Are there even (hardware) IOMMUs that are connected to noncoherent
> buses?
Yes. Virtually all ARM systems have non-cache coherent DMA. Doesn't
matter if there's an IOMMU or not.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 11:25 ` Arnd Bergmann
@ 2010-07-29 12:12 ` Roedel, Joerg
2010-07-29 13:01 ` Arnd Bergmann
0 siblings, 1 reply; 47+ messages in thread
From: Roedel, Joerg @ 2010-07-29 12:12 UTC (permalink / raw)
To: Arnd Bergmann
Cc: FUJITA Tomonori, stepanm@codeaurora.org,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Thu, Jul 29, 2010 at 07:25:47AM -0400, Arnd Bergmann wrote:
> On Thursday 29 July 2010, Roedel, Joerg wrote:
>
> > > You designed it for what you need at the time. It should have been
> > > named appropriately to avoid confusion. Later, when we actually
> > > understand what other IOMMUs need, we can evolve the specific API for
> > > generic purposes. Then we can rename the API to more generic.
> >
> > At the time the iommu-api was written is was generic enough for what we
> > had. So it was designed as an generic API. At this point in time nobody
> > knew what the future requirements would we. So today it turns out that
> > it is not generic enough anymore for latest hardware. The logical
> > consequence is to fix this in the iommu-api.
>
> Well, I think the real question is why we have two APIs that both claim
> to work with IOMMUs in a generic way and how we could unify the two.
The DMA-API itself does not claim to be an iommu-frontend. The purpose
of the DMA-API is to convert physical memory addresses into dma handles
and do all the management of these handles. Backend implementations can
use hardware iommus for this task. But depending on the hardware in the
system the DMA-API can very well be implemented without any hardware
support. This is an important difference to the IOMMU-API which needs
hardware because it exposes hardware iommu features to software.
> The Intel and AMD IOMMU drivers currently register at both the DMA
> API and the IOMMU API. The first one is used by everything except
> KVM and the second is only used by KVM.
Right. But there is also a mode where the AMD IOMMU driver only
registers for the IOMMU-API.
> I really think we should not extend the (KVM) IOMMU API further but
> just use the generic DMA mapping api for KVM and extend it as necessary.
> It already has the concept of cache coherency and mapping/unmapping
> that are in the IOMMU API and could be extended to support domains
> as well, through the use of dma_attrs.
If we find a nice and clean way to expose lower-level iommu
functionality through the DMA-API, thats fine. We could certainly
discuss ideas in this direction. I think this is going to be hard
because the DMA-API today does not provide enough flexibility to let the
user choose both sides of a io-virtual<->cpu-physical address mapping.
Thats fine for most drivers because it makes sense for them to use the
generic io-address-allocator the DMA-API provides but not for KVM which
needs this flexibility.
Joerg
--
Joerg Roedel - AMD Operating System Research Center
Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
General Managers: Alberto Bozzo, Andrew Bowd
Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr. 43632
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 12:12 ` Roedel, Joerg
@ 2010-07-29 13:01 ` Arnd Bergmann
0 siblings, 0 replies; 47+ messages in thread
From: Arnd Bergmann @ 2010-07-29 13:01 UTC (permalink / raw)
To: Roedel, Joerg
Cc: FUJITA Tomonori, stepanm@codeaurora.org,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Thursday 29 July 2010, Roedel, Joerg wrote:
> On Thu, Jul 29, 2010 at 07:25:47AM -0400, Arnd Bergmann wrote:
> > On Thursday 29 July 2010, Roedel, Joerg wrote:
> >
> > > > You designed it for what you need at the time. It should have been
> > > > named appropriately to avoid confusion. Later, when we actually
> > > > understand what other IOMMUs need, we can evolve the specific API for
> > > > generic purposes. Then we can rename the API to more generic.
> > >
> > > At the time the iommu-api was written is was generic enough for what we
> > > had. So it was designed as an generic API. At this point in time nobody
> > > knew what the future requirements would we. So today it turns out that
> > > it is not generic enough anymore for latest hardware. The logical
> > > consequence is to fix this in the iommu-api.
> >
> > Well, I think the real question is why we have two APIs that both claim
> > to work with IOMMUs in a generic way and how we could unify the two.
>
> The DMA-API itself does not claim to be an iommu-frontend. The purpose
> of the DMA-API is to convert physical memory addresses into dma handles
> and do all the management of these handles. Backend implementations can
> use hardware iommus for this task. But depending on the hardware in the
> system the DMA-API can very well be implemented without any hardware
> support. This is an important difference to the IOMMU-API which needs
> hardware because it exposes hardware iommu features to software.
Well, you could call that a limitation in the IOMMU API ;-)
The idea behind the DMA mapping API is to allow a device driver
to work without knowing if the hardware can, cannot or must use
an IOMMU.
> > I really think we should not extend the (KVM) IOMMU API further but
> > just use the generic DMA mapping api for KVM and extend it as necessary.
> > It already has the concept of cache coherency and mapping/unmapping
> > that are in the IOMMU API and could be extended to support domains
> > as well, through the use of dma_attrs.
>
> If we find a nice and clean way to expose lower-level iommu
> functionality through the DMA-API, thats fine. We could certainly
> discuss ideas in this direction. I think this is going to be hard
> because the DMA-API today does not provide enough flexibility to let the
> user choose both sides of a io-virtual<->cpu-physical address mapping.
> Thats fine for most drivers because it makes sense for them to use the
> generic io-address-allocator the DMA-API provides but not for KVM which
> needs this flexibility.
One way to do this would be to add a new attribute, e.g.
enum dma_attr {
DMA_ATTR_WRITE_BARRIER,
DMA_ATTR_WEAK_ORDERING,
DMA_ATTR_FIXED_MAPPING, /* this one is new */
DMA_ATTR_MAX,
};
struct dma_attrs {
unsigned long flags[__DMA_ATTRS_LONGS];
dma_add_t dest;
};
Nothing except for KVM would need to use that attribute, and KVM would
obviously need a way to check if this is supported by the underlying
implementation.
Arnd
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 9:06 ` Roedel, Joerg
2010-07-29 9:14 ` FUJITA Tomonori
@ 2010-07-30 5:19 ` stepanm
2010-07-30 8:01 ` Arnd Bergmann
2010-08-02 7:58 ` Roedel, Joerg
1 sibling, 2 replies; 47+ messages in thread
From: stepanm @ 2010-07-30 5:19 UTC (permalink / raw)
To: Roedel, Joerg
Cc: FUJITA Tomonori, arnd@arndb.de, stepanm@codeaurora.org,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
Joerg,
Thanks for the information. I have been trying to adapt the MSM IOMMU
driver to use your IOMMU interface, and it looks like it might work, with
one minor modification.
Unlike a more traditional system with one IOMMU between the bus and
memory, MSM has multiple IOMMUs, with each one hard-wired to a dedicated
device. Furthermore, each IOMMU can have more than one translation
context. One of the use cases is being able to create mappings within
multiple instances of one context, and arbitrarily context-switch the
IOMMU on the fly.
It sounds like the domain abstraction and attach_device/detach_device can
encapsulate this rather nicely and I am in the process of updating my
driver to fit this framework.
My problem, however, is with iommu_domain_alloc(). This will set up a
domain and call the ops function to initialize it, but I want to be able
to pass it an IOMMU id" that will tell the underlying driver which IOMMU
(and which "stream id") is to be associated with that domain instance.
This can be a void* parameter that gets passed through to domain_init. I
feel like this change will make it easy to deal with multiple
IOMMUs/translation contexts, and implementations that have only a singular
IOMMU/translation context are free to ignore that parameter.
The alternative for me is to have a separate msm_iommu_domain_alloc(void
*context_id) function, to which I can specify which IOMMU I want to use,
but I would like to fully use your API if possible.
What are your thoughts? I can prepare a patch if you like - the
domain_alloc change looks like it will be very innocuous.
Thanks
Steve
> On Thu, Jul 29, 2010 at 04:46:59AM -0400, FUJITA Tomonori wrote:
>> On Thu, 29 Jul 2010 10:40:19 +0200
>> "Roedel, Joerg" <Joerg.Roedel@amd.com> wrote:
>>
>> > The IOMMU-API is not about SR-IOV.
>>
>> That's true. However, the point is that include/iommu.h is far from
>> the IOMMU-API.
>>
>> You could still insist that include/iommu.h is designed for the
>> generic IOMMU-API. But the fact is that it's designed for very
>> specific purposes. No intention to make it for generic purposes.
>
> I have no clue about the ARM iommus on the omap-platform. From a quick
> look into the header file I see some similarities to the IOMMU-API. I am
> also very open for discussions about how the IOMMU-API could be extended
> to fit the needs of other platforms. Only because nobody has tried to
> discuss about such an effort is no reason to push the IOMMU-API back.
>
>>
>> Since you added it two years ago, nobody has tried to extend
>> it. Instead, we have something like
>> arch/arm/plat-omap/include/plat/iommu.h.
>
> And I think we should try to merge this platform-specific functionality
> into the IOMMU-API.
>
> Joerg
>
> --
> Joerg Roedel - AMD Operating System Research Center
>
> Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
> General Managers: Alberto Bozzo, Andrew Bowd
> Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr.
> 43632
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-arm-msm"
> in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
>
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 11:47 ` Russell King - ARM Linux
@ 2010-07-30 6:14 ` FUJITA Tomonori
0 siblings, 0 replies; 47+ messages in thread
From: FUJITA Tomonori @ 2010-07-30 6:14 UTC (permalink / raw)
To: linux
Cc: arnd, linux-arm-kernel, fujita.tomonori, linux-arm-msm, dwalker,
stepanm, linux-kernel, linux-arch
On Thu, 29 Jul 2010 12:47:26 +0100
Russell King - ARM Linux <linux@arm.linux.org.uk> wrote:
> On Thu, Jul 29, 2010 at 10:12:05AM +0200, Arnd Bergmann wrote:
> > On Wednesday 28 July 2010 23:21:56 Russell King - ARM Linux wrote:
> > > On Wed, Jul 28, 2010 at 07:50:20PM +0200, Arnd Bergmann wrote:
> > > > The DMA API is extremely flexible, it works just fine with all the
> > > > IOMMUs that I've seen so far. Please take a look at
> > > > include/asm-generic/dma-mapping-common.h and its users to see how
> > > > to use multiple IOMMUs depending on the device.
> > >
> > > We don't yet use those DMA API interface extensions because we haven't
> > > had the need. If someone who has the need wants to put the effort in
> > > though...
> >
> > Right, it shouldn't be hard now that the groundwork for that is done.
> > Also, it's only really needed if you have IOMMUs of different types in the
> > same system. If msm doesn't have any swiotlb or dmabounce devices,
> > it could always use the same implementation for all devices.
> >
> > > One of the problems with it though is the abstraction of the sync*
> > > operations is the wrong way around for stuff like dmabounce - we want
> > > to be passed the base address of the buffer (so we can look this up),
> > > plus offset and length. We don't want to know just the region which
> > > is affected.
> >
> > Yes, but that is an unrelated (dmabounce specific) problem that seems to
> > be fixed by an existing patch.
>
> It's not unrelated because it stands in the way of using that interface.
> The patch also seems to be buggy in that it doesn't fix the for_device
> case - it leaves 'off' as zero.
Ah, sorry about the bug. Surely, the for_device needs to do the same
as the for_cpu. I've attached the updated patch.
We need to fix dmabounce.c anyway (even if we keep the sync_range API)
because drivers use the sync API to do a partial sync.
> I'm also not sold on this idea that the sync_range API is being obsoleted.
> It seems to me to be a step in the wrong direction. The range API is a
> natural subset of the 'normal' sync API, yet people are trying to shoehorn
> the range API into the 'norma' API. If anything it's the 'normal' API
> which should be obsoleted as it provides reduced information to
> implementations, which then have to start fuzzy-matching the passed
> address.
It would have been nice if you had opposed when this issue was
discussed...
commit 8127bfc5645db0e050468e0ff971b4081f73ddcf
Author: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
Date: Wed Mar 10 15:23:18 2010 -0800
DMA-API.txt: remove dma_sync_single_range description
As you said, the range API might be safer (since it requires more
information). However, there were already drivers using the
dma_sync_single_for API to do a partial sync (i.e. do a sync on
range).
Inspecting all the usage of the dma_sync_single_for API to see which
drivers to do a partial sync looks unrealistic. So keeping the
dma_sync_single_range_for API is pointless since drivers keep using
dma_sync_single_for API.
And the majority of implementations doesn't use 'range' information,
i.e., the implementation of dma_sync_single_for and
dma_sync_single_range_for API is identical.
> If we're going to start fuzzy-matching the passed address, then I think
> we also need to add detection of overlapping mappings and BUG() on such
> cases - otherwise we risk the possibility of having multiple overlapping
> mappings and hitting the wrong mapping with this reduced-information sync
> API.
Strict checking would be nice. If architectures can do such easily, we
had better to do so.
However, I'm not sure we need to take special care for the
dma_sync_single_for API. In general, misuse of the majority of the DMA
functions is deadly.
=
From: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
Subject: [PATCH] ARM: dmabounce: fix partial sync in dma_sync_single_* API
Some network drivers do a partial sync with
dma_sync_single_for_{device|cpu}. The dma_addr argument might not be
the same as one as passed into the mapping API.
This adds some tricks to find_safe_buffer() for
dma_sync_single_for_{device|cpu}.
Signed-off-by: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
---
arch/arm/common/dmabounce.c | 32 +++++++++++++++++++++++---------
1 files changed, 23 insertions(+), 9 deletions(-)
diff --git a/arch/arm/common/dmabounce.c b/arch/arm/common/dmabounce.c
index cc0a932..dbd30dc 100644
--- a/arch/arm/common/dmabounce.c
+++ b/arch/arm/common/dmabounce.c
@@ -163,7 +163,8 @@ alloc_safe_buffer(struct dmabounce_device_info *device_info, void *ptr,
/* determine if a buffer is from our "safe" pool */
static inline struct safe_buffer *
-find_safe_buffer(struct dmabounce_device_info *device_info, dma_addr_t safe_dma_addr)
+find_safe_buffer(struct dmabounce_device_info *device_info, dma_addr_t safe_dma_addr,
+ int for_sync)
{
struct safe_buffer *b, *rb = NULL;
unsigned long flags;
@@ -171,9 +172,17 @@ find_safe_buffer(struct dmabounce_device_info *device_info, dma_addr_t safe_dma_
read_lock_irqsave(&device_info->lock, flags);
list_for_each_entry(b, &device_info->safe_buffers, node)
- if (b->safe_dma_addr == safe_dma_addr) {
- rb = b;
- break;
+ if (for_sync) {
+ if (b->safe_dma_addr <= safe_dma_addr &&
+ safe_dma_addr < b->safe_dma_addr + b->size) {
+ rb = b;
+ break;
+ }
+ } else {
+ if (b->safe_dma_addr == safe_dma_addr) {
+ rb = b;
+ break;
+ }
}
read_unlock_irqrestore(&device_info->lock, flags);
@@ -205,7 +214,8 @@ free_safe_buffer(struct dmabounce_device_info *device_info, struct safe_buffer *
/* ************************************************** */
static struct safe_buffer *find_safe_buffer_dev(struct device *dev,
- dma_addr_t dma_addr, const char *where)
+ dma_addr_t dma_addr, const char *where,
+ int for_sync)
{
if (!dev || !dev->archdata.dmabounce)
return NULL;
@@ -216,7 +226,7 @@ static struct safe_buffer *find_safe_buffer_dev(struct device *dev,
pr_err("unknown device: Trying to %s invalid mapping\n", where);
return NULL;
}
- return find_safe_buffer(dev->archdata.dmabounce, dma_addr);
+ return find_safe_buffer(dev->archdata.dmabounce, dma_addr, for_sync);
}
static inline dma_addr_t map_single(struct device *dev, void *ptr, size_t size,
@@ -286,7 +296,7 @@ static inline dma_addr_t map_single(struct device *dev, void *ptr, size_t size,
static inline void unmap_single(struct device *dev, dma_addr_t dma_addr,
size_t size, enum dma_data_direction dir)
{
- struct safe_buffer *buf = find_safe_buffer_dev(dev, dma_addr, "unmap");
+ struct safe_buffer *buf = find_safe_buffer_dev(dev, dma_addr, "unmap", 0);
if (buf) {
BUG_ON(buf->size != size);
@@ -398,7 +408,7 @@ int dmabounce_sync_for_cpu(struct device *dev, dma_addr_t addr,
dev_dbg(dev, "%s(dma=%#x,off=%#lx,sz=%zx,dir=%x)\n",
__func__, addr, off, sz, dir);
- buf = find_safe_buffer_dev(dev, addr, __func__);
+ buf = find_safe_buffer_dev(dev, addr, __func__, 1);
if (!buf)
return 1;
@@ -411,6 +421,8 @@ int dmabounce_sync_for_cpu(struct device *dev, dma_addr_t addr,
DO_STATS(dev->archdata.dmabounce->bounce_count++);
if (dir == DMA_FROM_DEVICE || dir == DMA_BIDIRECTIONAL) {
+ if (addr != buf->safe_dma_addr)
+ off = addr - buf->safe_dma_addr;
dev_dbg(dev, "%s: copy back safe %p to unsafe %p size %d\n",
__func__, buf->safe + off, buf->ptr + off, sz);
memcpy(buf->ptr + off, buf->safe + off, sz);
@@ -427,7 +439,7 @@ int dmabounce_sync_for_device(struct device *dev, dma_addr_t addr,
dev_dbg(dev, "%s(dma=%#x,off=%#lx,sz=%zx,dir=%x)\n",
__func__, addr, off, sz, dir);
- buf = find_safe_buffer_dev(dev, addr, __func__);
+ buf = find_safe_buffer_dev(dev, addr, __func__, 1);
if (!buf)
return 1;
@@ -440,6 +452,8 @@ int dmabounce_sync_for_device(struct device *dev, dma_addr_t addr,
DO_STATS(dev->archdata.dmabounce->bounce_count++);
if (dir == DMA_TO_DEVICE || dir == DMA_BIDIRECTIONAL) {
+ if (addr != buf->safe_dma_addr)
+ off = addr - buf->safe_dma_addr;
dev_dbg(dev, "%s: copy out unsafe %p to safe %p, size %d\n",
__func__,buf->ptr + off, buf->safe + off, sz);
memcpy(buf->safe + off, buf->ptr + off, sz);
--
1.6.5
^ permalink raw reply related [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-30 5:19 ` stepanm
@ 2010-07-30 8:01 ` Arnd Bergmann
2010-07-30 16:25 ` stepanm
2010-08-02 7:58 ` Roedel, Joerg
1 sibling, 1 reply; 47+ messages in thread
From: Arnd Bergmann @ 2010-07-30 8:01 UTC (permalink / raw)
To: stepanm
Cc: Roedel, Joerg, FUJITA Tomonori,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Friday 30 July 2010 07:19:06 stepanm@codeaurora.org wrote:
> Unlike a more traditional system with one IOMMU between the bus and
> memory, MSM has multiple IOMMUs, with each one hard-wired to a dedicated
> device. Furthermore, each IOMMU can have more than one translation
> context. One of the use cases is being able to create mappings within
> multiple instances of one context, and arbitrarily context-switch the
> IOMMU on the fly.
>
> It sounds like the domain abstraction and attach_device/detach_device can
> encapsulate this rather nicely and I am in the process of updating my
> driver to fit this framework.
>
> My problem, however, is with iommu_domain_alloc(). This will set up a
> domain and call the ops function to initialize it, but I want to be able
> to pass it an “IOMMU id" that will tell the underlying driver which IOMMU
> (and which "stream id") is to be associated with that domain instance.
This probably best fits into the device itself, so you can assign the
iommu data when probing the bus, e.g. (I don't know what bus you use)
struct msm_device {
struct msm_iommu *iommu;
struct device dev;
};
This will work both for device drivers using the DMA API and for KVM
with the IOMMU API.
> This can be a void* parameter that gets passed through to domain_init. I
> feel like this change will make it easy to deal with multiple
> IOMMUs/translation contexts, and implementations that have only a singular
> IOMMU/translation context are free to ignore that parameter.
>
> The alternative for me is to have a separate msm_iommu_domain_alloc(void
> *context_id) function, to which I can specify which IOMMU I want to use,
> but I would like to fully use your API if possible.
No, that would require adding msm specific code to KVM and potential
other users.
Arnd
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-30 8:01 ` Arnd Bergmann
@ 2010-07-30 16:25 ` stepanm
2010-07-30 21:59 ` Arnd Bergmann
0 siblings, 1 reply; 47+ messages in thread
From: stepanm @ 2010-07-30 16:25 UTC (permalink / raw)
To: Arnd Bergmann
Cc: stepanm, Roedel, Joerg, FUJITA Tomonori,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
> On Friday 30 July 2010 07:19:06 stepanm@codeaurora.org wrote:
>> Unlike a more traditional system with one IOMMU between the bus and
>> memory, MSM has multiple IOMMUs, with each one hard-wired to a dedicated
>> device. Furthermore, each IOMMU can have more than one translation
>> context. One of the use cases is being able to create mappings within
>> multiple instances of one context, and arbitrarily context-switch the
>> IOMMU on the fly.
>>
>> It sounds like the domain abstraction and attach_device/detach_device
>> can
>> encapsulate this rather nicely and I am in the process of updating my
>> driver to fit this framework.
>>
>> My problem, however, is with iommu_domain_alloc(). This will set up a
>> domain and call the ops function to initialize it, but I want to be able
>> to pass it an âIOMMU id" that will tell the underlying driver which
>> IOMMU
>> (and which "stream id") is to be associated with that domain instance.
>
> This probably best fits into the device itself, so you can assign the
> iommu data when probing the bus, e.g. (I don't know what bus you use)
>
> struct msm_device {
> struct msm_iommu *iommu;
> struct device dev;
> };
>
> This will work both for device drivers using the DMA API and for KVM
> with the IOMMU API.
Right, this makes sense, and that is similar to how we were planning to
set the iommus for the devices. But my question is, how does the IOMMU API
know *which* IOMMU to talk to? It seems like this API has been designed
with a singular IOMMU in mind, and it is implied that things like
iommu_domain_alloc, iommu_map, etc all use "the" IOMMU. But I would like
to allocate a domain and specify which IOMMU it is to be used for.
I can think of solving this in several ways.
One way would be to modify iommu_domain_alloc to take an IOMMU parameter,
which gets passed into domain_init. This seems like the cleanest solution.
Another way would be to have something like msm_iommu_domain_bind(domain,
iommu) which would need to be called after iommu_domain_alloc to set the
domain binding.
A third way that I could see is to delay the domain/iommu binding until
iommu_attach_device, where the iommu could be picked up from the device
that is passed in. I am not certain of this approach, since I had not been
planning to pass in full devices, as in the MSM case this makes little
sense (that is, if I am understanding the API correctly). On MSM, each
device already has a dedicated IOMMU hard-wired to it. I had been planning
to use iommu_attach_device to switch between active domains on a specific
IOMMU and the given device would be of little use because that association
is implicit on MSM.
Does that make sense? Am I correctly understanding the API? What do you
think would be a good way to handle the multiple-iommu case?
Thanks
Steve
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-30 16:25 ` stepanm
@ 2010-07-30 21:59 ` Arnd Bergmann
2010-07-30 22:58 ` stepanm
0 siblings, 1 reply; 47+ messages in thread
From: Arnd Bergmann @ 2010-07-30 21:59 UTC (permalink / raw)
To: stepanm
Cc: Roedel, Joerg, FUJITA Tomonori,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Friday 30 July 2010 18:25:48 stepanm@codeaurora.org wrote:
> > This probably best fits into the device itself, so you can assign the
> > iommu data when probing the bus, e.g. (I don't know what bus you use)
> >
> > struct msm_device {
> > struct msm_iommu *iommu;
> > struct device dev;
> > };
> >
> > This will work both for device drivers using the DMA API and for KVM
> > with the IOMMU API.
>
>
> Right, this makes sense, and that is similar to how we were planning to
> set the iommus for the devices. But my question is, how does the IOMMU API
> know *which* IOMMU to talk to? It seems like this API has been designed
> with a singular IOMMU in mind, and it is implied that things like
> iommu_domain_alloc, iommu_map, etc all use "the" IOMMU.
The primary key is always the device pointer. If you look e.g. at
arch/powerpc/include/asm/dma-mapping.h, you find
static inline struct dma_map_ops *get_dma_ops(struct device *dev)
{
return dev->archdata.dma_ops;
}
>From there, you know the type of the iommu, each of which has its
own dma_ops pointer. The dma_ops->map_sg() referenced there is
specific to one (or a fixed small number of) bus_type, e.g. PCI
or in your case an MSM specific SoC bus, so it can cast the device
to the bus specific data structure:
int msm_dma_map_sg(struct device *dev, struct scatterlist *sg, int nents,
enum dma_data_direction dir)
{
struct msm_device *dev = container_of(dev, struct msm_device, dev);
...
}
> But I would like
> to allocate a domain and specify which IOMMU it is to be used for.
> I can think of solving this in several ways.
> One way would be to modify iommu_domain_alloc to take an IOMMU parameter,
> which gets passed into domain_init. This seems like the cleanest solution.
> Another way would be to have something like msm_iommu_domain_bind(domain,
> iommu) which would need to be called after iommu_domain_alloc to set the
> domain binding.
The iommu_domain is currently a concept that is only used in KVM, and there
a domain currently would always span all of the IOMMUs that can host
virtualized devices. I'm not sure what you want to do with domains though.
Are you implementing KVM or another hypervisor, or is there another use
case?
I've seen discussions about using an IOMMU to share page tables with
regular processes so that user space can program a device to do DMA into
its own address space, which would require an IOMMU domain per process
using the device.
However, most of the time, it is better to change the programming model
of those devices to do the mapping inside of a kernel device driver
that allocates a physical memory area and maps it into both the BUS
address space (using dma_map_{sg,single}) and the user address space
(using mmap()).
> A third way that I could see is to delay the domain/iommu binding until
> iommu_attach_device, where the iommu could be picked up from the device
> that is passed in. I am not certain of this approach, since I had not been
> planning to pass in full devices, as in the MSM case this makes little
> sense (that is, if I am understanding the API correctly). On MSM, each
> device already has a dedicated IOMMU hard-wired to it. I had been planning
> to use iommu_attach_device to switch between active domains on a specific
> IOMMU and the given device would be of little use because that association
> is implicit on MSM.
>
> Does that make sense? Am I correctly understanding the API? What do you
> think would be a good way to handle the multiple-iommu case?
My impression is that you are confusing the multi-IOMMU and the multi-domain
problem, which are orthogonal. The dma-mapping API can deal with multiple
IOMMUs as I described above, but has no concept of domains. KVM uses the
iommu.h API to get one domain per guest OS, but as you said, it does not
have a concept of multiple IOMMUs because neither Intel nor AMD require that
today.
If you really need multiple domains across multiple IOMMUs, I'd suggest that
we first merge the APIs and then port your code to that, but as a first step
you could implement the standard dma-mapping.h API, which allows you to use
the IOMMUs in kernel space.
Arnd
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-30 21:59 ` Arnd Bergmann
@ 2010-07-30 22:58 ` stepanm
2010-07-31 9:37 ` Arnd Bergmann
0 siblings, 1 reply; 47+ messages in thread
From: stepanm @ 2010-07-30 22:58 UTC (permalink / raw)
To: Arnd Bergmann
Cc: stepanm, Roedel, Joerg, FUJITA Tomonori,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
> On Friday 30 July 2010 18:25:48 stepanm@codeaurora.org wrote:
>
>> > This probably best fits into the device itself, so you can assign the
>> > iommu data when probing the bus, e.g. (I don't know what bus you use)
>> >
>> > struct msm_device {
>> > struct msm_iommu *iommu;
>> > struct device dev;
>> > };
>> >
>> > This will work both for device drivers using the DMA API and for KVM
>> > with the IOMMU API.
>>
>>
>> Right, this makes sense, and that is similar to how we were planning to
>> set the iommus for the devices. But my question is, how does the IOMMU
>> API
>> know *which* IOMMU to talk to? It seems like this API has been designed
>> with a singular IOMMU in mind, and it is implied that things like
>> iommu_domain_alloc, iommu_map, etc all use "the" IOMMU.
>
> The primary key is always the device pointer. If you look e.g. at
> arch/powerpc/include/asm/dma-mapping.h, you find
>
> static inline struct dma_map_ops *get_dma_ops(struct device *dev)
> {
> return dev->archdata.dma_ops;
> }
>
> From there, you know the type of the iommu, each of which has its
> own dma_ops pointer. The dma_ops->map_sg() referenced there is
> specific to one (or a fixed small number of) bus_type, e.g. PCI
> or in your case an MSM specific SoC bus, so it can cast the device
> to the bus specific data structure:
>
> int msm_dma_map_sg(struct device *dev, struct scatterlist *sg, int nents,
> enum dma_data_direction dir)
> {
> struct msm_device *dev = container_of(dev, struct msm_device, dev);
>
> ...
> }
>
>> But I would like
>> to allocate a domain and specify which IOMMU it is to be used for.
>> I can think of solving this in several ways.
>> One way would be to modify iommu_domain_alloc to take an IOMMU
>> parameter,
>> which gets passed into domain_init. This seems like the cleanest
>> solution.
>> Another way would be to have something like
>> msm_iommu_domain_bind(domain,
>> iommu) which would need to be called after iommu_domain_alloc to set the
>> domain binding.
>
> The iommu_domain is currently a concept that is only used in KVM, and
> there
> a domain currently would always span all of the IOMMUs that can host
> virtualized devices. I'm not sure what you want to do with domains though.
> Are you implementing KVM or another hypervisor, or is there another use
> case?
>
> I've seen discussions about using an IOMMU to share page tables with
> regular processes so that user space can program a device to do DMA into
> its own address space, which would require an IOMMU domain per process
> using the device.
>
> However, most of the time, it is better to change the programming model
> of those devices to do the mapping inside of a kernel device driver
> that allocates a physical memory area and maps it into both the BUS
> address space (using dma_map_{sg,single}) and the user address space
> (using mmap()).
>
>> A third way that I could see is to delay the domain/iommu binding until
>> iommu_attach_device, where the iommu could be picked up from the device
>> that is passed in. I am not certain of this approach, since I had not
>> been
>> planning to pass in full devices, as in the MSM case this makes little
>> sense (that is, if I am understanding the API correctly). On MSM, each
>> device already has a dedicated IOMMU hard-wired to it. I had been
>> planning
>> to use iommu_attach_device to switch between active domains on a
>> specific
>> IOMMU and the given device would be of little use because that
>> association
>> is implicit on MSM.
>>
>> Does that make sense? Am I correctly understanding the API? What do you
>> think would be a good way to handle the multiple-iommu case?
>
> My impression is that you are confusing the multi-IOMMU and the
> multi-domain
> problem, which are orthogonal. The dma-mapping API can deal with multiple
> IOMMUs as I described above, but has no concept of domains. KVM uses the
> iommu.h API to get one domain per guest OS, but as you said, it does not
> have a concept of multiple IOMMUs because neither Intel nor AMD require
> that
> today.
>
> If you really need multiple domains across multiple IOMMUs, I'd suggest
> that
> we first merge the APIs and then port your code to that, but as a first
> step
> you could implement the standard dma-mapping.h API, which allows you to
> use
> the IOMMUs in kernel space.
One of our uses cases actually does involve using domains pretty much as
you had described them, though only on one of the IOMMUs. That is, the
domain for that IOMMU basically abstracts its page table, and it is a
legitimate thing to switch out page tables for the IOMMU on the fly. I
guess the difference is that you described the domain as the set of
mappings made on ALL the IOMMUs, whereas I had envisioned there being one
(or more) domains for each IOMMU.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 3:35 ` FUJITA Tomonori
2010-07-29 8:26 ` Arnd Bergmann
@ 2010-07-31 2:30 ` Benjamin Herrenschmidt
1 sibling, 0 replies; 47+ messages in thread
From: Benjamin Herrenschmidt @ 2010-07-31 2:30 UTC (permalink / raw)
To: FUJITA Tomonori
Cc: stepanm, arnd, linux-arm-kernel, linux-arm-msm, dwalker,
linux-kernel
On Thu, 2010-07-29 at 12:35 +0900, FUJITA Tomonori wrote:
> Don't confuse the IOMMU interface with the DMA API that Arnd
> mentioned.
>
> They are not related at all.
>
> The DMA API is defined in Documentation/DMA-API.txt.
>
> Arnd told you that include/asm-generic/dma-mapping-common.h is the
> library to support the DMA API with multiple IOMMUs. Lots of
> architectures (x86, powerpc, sh, alpha, ia64, microblaze, sparc)
> use it.
Also, some of the iommu layer actually originates from powerpc.
Cheers,
Ben.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-29 8:26 ` Arnd Bergmann
2010-07-29 8:35 ` FUJITA Tomonori
2010-07-29 8:40 ` Roedel, Joerg
@ 2010-07-31 3:15 ` Benjamin Herrenschmidt
2010-08-02 7:48 ` Roedel, Joerg
2 siblings, 1 reply; 47+ messages in thread
From: Benjamin Herrenschmidt @ 2010-07-31 3:15 UTC (permalink / raw)
To: Arnd Bergmann
Cc: FUJITA Tomonori, Joerg Roedel, stepanm, linux-arm-kernel,
linux-arm-msm, dwalker, linux-kernel
On Thu, 2010-07-29 at 10:26 +0200, Arnd Bergmann wrote:
> Exactly, thanks for the clarification. I also didn't realize that
> there
> is now an include/linux/iommu.h file that only describes the PCI
> SR-IOV
> interfaces, unlike the generic IOMMU support that we have in your
> include/linux/dma-mapping.h file.
>
> Maybe we should rename linux/iommu.h to something more specific so we
> can reduce this confusion in the future.
Hrm, indeed I just noticed that. Pretty gross... it should definitly be
renamed, is will caused endless confusion with unrelated iommu.h and
iommu_* interfaces which represent something different.
Ben.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-30 22:58 ` stepanm
@ 2010-07-31 9:37 ` Arnd Bergmann
0 siblings, 0 replies; 47+ messages in thread
From: Arnd Bergmann @ 2010-07-31 9:37 UTC (permalink / raw)
To: stepanm
Cc: Roedel, Joerg, FUJITA Tomonori,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Saturday 31 July 2010 00:58:00 stepanm@codeaurora.org wrote:
> > If you really need multiple domains across multiple IOMMUs, I'd suggest that
> > we first merge the APIs and then port your code to that, but as a first step
> > you could implement the standard dma-mapping.h API, which allows you to use
> > the IOMMUs in kernel space.
>
> One of our uses cases actually does involve using domains pretty much as
> you had described them, though only on one of the IOMMUs. That is, the
> domain for that IOMMU basically abstracts its page table, and it is a
> legitimate thing to switch out page tables for the IOMMU on the fly. I
> guess the difference is that you described the domain as the set of
> mappings made on ALL the IOMMUs, whereas I had envisioned there being one
> (or more) domains for each IOMMU.
Can you be more specific on what kind of device would use multiple domains
in your case and how you intend to use them? Is this for some kind of DSP
interacting with user processes?
This seems to be a scenario that we haven't dealt with before (or perhaps
avoided intentionally), so if we need to make API changes, we should all
understand what we need them for. It's no problem to extend the API if you
have good reasons for using multiple domains, but I also want to make sure
that there isn't also a way to achieve the same or better result with the
current APIs.
Arnd
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-31 3:15 ` Benjamin Herrenschmidt
@ 2010-08-02 7:48 ` Roedel, Joerg
2010-08-02 8:03 ` Benjamin Herrenschmidt
0 siblings, 1 reply; 47+ messages in thread
From: Roedel, Joerg @ 2010-08-02 7:48 UTC (permalink / raw)
To: Benjamin Herrenschmidt
Cc: Arnd Bergmann, FUJITA Tomonori, stepanm@codeaurora.org,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Fri, Jul 30, 2010 at 11:15:24PM -0400, Benjamin Herrenschmidt wrote:
> On Thu, 2010-07-29 at 10:26 +0200, Arnd Bergmann wrote:
> > Exactly, thanks for the clarification. I also didn't realize that
> > there
> > is now an include/linux/iommu.h file that only describes the PCI
> > SR-IOV
> > interfaces, unlike the generic IOMMU support that we have in your
> > include/linux/dma-mapping.h file.
> >
> > Maybe we should rename linux/iommu.h to something more specific so we
> > can reduce this confusion in the future.
>
> Hrm, indeed I just noticed that. Pretty gross... it should definitly be
> renamed, is will caused endless confusion with unrelated iommu.h and
> iommu_* interfaces which represent something different.
The first direction to go should be trying to unify all the different
iommu* interfaces into the iommu-api. The generic api will definitly
need to be extended for that, but since it is an in-kernel interface
thats no problem.
--
Joerg Roedel - AMD Operating System Research Center
Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
General Managers: Alberto Bozzo, Andrew Bowd
Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr. 43632
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-07-30 5:19 ` stepanm
2010-07-30 8:01 ` Arnd Bergmann
@ 2010-08-02 7:58 ` Roedel, Joerg
2010-08-02 20:29 ` Zach Pfeffer
1 sibling, 1 reply; 47+ messages in thread
From: Roedel, Joerg @ 2010-08-02 7:58 UTC (permalink / raw)
To: stepanm@codeaurora.org
Cc: FUJITA Tomonori, arnd@arndb.de,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
Hi Stephan,
On Fri, Jul 30, 2010 at 01:19:06AM -0400, stepanm@codeaurora.org wrote:
> Unlike a more traditional system with one IOMMU between the bus and
> memory, MSM has multiple IOMMUs, with each one hard-wired to a dedicated
> device. Furthermore, each IOMMU can have more than one translation
> context. One of the use cases is being able to create mappings within
> multiple instances of one context, and arbitrarily context-switch the
> IOMMU on the fly.
The IOMMU-API supports multiple IOMMUs (at least multiple AMD/Intel
IOMMUs). But the face that there are more than one IOMMU is hidden in
the backend driver implementation. The API itself only works with
domains and devices. The IOMMU driver needs to know which IOMMU it needs
to program for a given device. If I understand the concept of your
hardware correctly you also have this information.
> It sounds like the domain abstraction and attach_device/detach_device can
> encapsulate this rather nicely and I am in the process of updating my
> driver to fit this framework.
>
> My problem, however, is with iommu_domain_alloc(). This will set up a
> domain and call the ops function to initialize it, but I want to be able
> to pass it an “IOMMU id" that will tell the underlying driver which IOMMU
> (and which "stream id") is to be associated with that domain instance.
> This can be a void* parameter that gets passed through to domain_init. I
> feel like this change will make it easy to deal with multiple
> IOMMUs/translation contexts, and implementations that have only a singular
> IOMMU/translation context are free to ignore that parameter.
In the means of the IOMMU-API the domain is the abstraction of an
address space (in other words a page table). The IOMMU(s) which this domain
is later assigned to are determined by the iommu_attach_device calls.
I think the right way to go here is to create the concept of a
device-context in the IOMMU-API and add functions like
iommu_attach_context(struct iommu_domain *domain,
struct iommu_context *ctxt);
iommu_detach_context(struct iommu_context *ctxt);
This would work if you can determine in your iommu-driver which iommu
you need to program for which device. What do you think?
Joerg
--
Joerg Roedel - AMD Operating System Research Center
Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
General Managers: Alberto Bozzo, Andrew Bowd
Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr. 43632
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-08-02 7:48 ` Roedel, Joerg
@ 2010-08-02 8:03 ` Benjamin Herrenschmidt
2010-08-02 8:10 ` Roedel, Joerg
` (2 more replies)
0 siblings, 3 replies; 47+ messages in thread
From: Benjamin Herrenschmidt @ 2010-08-02 8:03 UTC (permalink / raw)
To: Roedel, Joerg
Cc: Arnd Bergmann, FUJITA Tomonori, stepanm@codeaurora.org,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Mon, 2010-08-02 at 09:48 +0200, Roedel, Joerg wrote:
> > Hrm, indeed I just noticed that. Pretty gross... it should definitly
> be
> > renamed, is will caused endless confusion with unrelated iommu.h and
> > iommu_* interfaces which represent something different.
>
> The first direction to go should be trying to unify all the different
> iommu* interfaces into the iommu-api. The generic api will definitly
> need to be extended for that, but since it is an in-kernel interface
> thats no problem.
Well, I suppose I'm the de-facto candidate to take care of the powerpc
side then :-)
I don't have the bandwidth right now, but I'll try to have a look when
time permits.
Cheers,
Ben.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-08-02 8:03 ` Benjamin Herrenschmidt
@ 2010-08-02 8:10 ` Roedel, Joerg
2010-08-02 8:30 ` FUJITA Tomonori
2010-08-02 8:35 ` Roedel, Joerg
2 siblings, 0 replies; 47+ messages in thread
From: Roedel, Joerg @ 2010-08-02 8:10 UTC (permalink / raw)
To: Benjamin Herrenschmidt
Cc: Arnd Bergmann, FUJITA Tomonori, stepanm@codeaurora.org,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Mon, Aug 02, 2010 at 04:03:02AM -0400, Benjamin Herrenschmidt wrote:
> On Mon, 2010-08-02 at 09:48 +0200, Roedel, Joerg wrote:
> > > Hrm, indeed I just noticed that. Pretty gross... it should definitly
> > be
> > > renamed, is will caused endless confusion with unrelated iommu.h and
> > > iommu_* interfaces which represent something different.
> >
> > The first direction to go should be trying to unify all the different
> > iommu* interfaces into the iommu-api. The generic api will definitly
> > need to be extended for that, but since it is an in-kernel interface
> > thats no problem.
>
> Well, I suppose I'm the de-facto candidate to take care of the powerpc
> side then :-)
>
> I don't have the bandwidth right now, but I'll try to have a look when
> time permits.
Great :-)
--
Joerg Roedel - AMD Operating System Research Center
Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
General Managers: Alberto Bozzo, Andrew Bowd
Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr. 43632
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-08-02 8:03 ` Benjamin Herrenschmidt
2010-08-02 8:10 ` Roedel, Joerg
@ 2010-08-02 8:30 ` FUJITA Tomonori
2010-08-02 9:03 ` Russell King - ARM Linux
2010-08-02 9:45 ` Roedel, Joerg
2010-08-02 8:35 ` Roedel, Joerg
2 siblings, 2 replies; 47+ messages in thread
From: FUJITA Tomonori @ 2010-08-02 8:30 UTC (permalink / raw)
To: benh
Cc: Joerg.Roedel, arnd, fujita.tomonori, stepanm, linux-arm-kernel,
linux-arm-msm, dwalker, linux-kernel
On Mon, 02 Aug 2010 18:03:02 +1000
Benjamin Herrenschmidt <benh@kernel.crashing.org> wrote:
> On Mon, 2010-08-02 at 09:48 +0200, Roedel, Joerg wrote:
> > > Hrm, indeed I just noticed that. Pretty gross... it should definitly
> > be
> > > renamed, is will caused endless confusion with unrelated iommu.h and
> > > iommu_* interfaces which represent something different.
> >
> > The first direction to go should be trying to unify all the different
> > iommu* interfaces into the iommu-api. The generic api will definitly
> > need to be extended for that, but since it is an in-kernel interface
> > thats no problem.
>
> Well, I suppose I'm the de-facto candidate to take care of the powerpc
> side then :-)
We already agreed that what the iommu-api looks like?
ARM's iommu code (arch/plat-omap/include/plat/iommu.h) is a library to
simplify the IOMMU implementations. It could be useful for all the
iommu implementations.
The current iommu-api (include/linux/iommu.h) provides the common
interface for specific purposes (for KVM).
I think that the current iommu-api can be a part of the former.
I also think that the IOMMU part of this new msm should be integrated
into the former.
Another question is how the above can work with the DMA-API.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-08-02 8:03 ` Benjamin Herrenschmidt
2010-08-02 8:10 ` Roedel, Joerg
2010-08-02 8:30 ` FUJITA Tomonori
@ 2010-08-02 8:35 ` Roedel, Joerg
2 siblings, 0 replies; 47+ messages in thread
From: Roedel, Joerg @ 2010-08-02 8:35 UTC (permalink / raw)
To: Benjamin Herrenschmidt
Cc: Arnd Bergmann, FUJITA Tomonori, stepanm@codeaurora.org,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Mon, Aug 02, 2010 at 04:03:02AM -0400, Benjamin Herrenschmidt wrote:
> On Mon, 2010-08-02 at 09:48 +0200, Roedel, Joerg wrote:
> > > Hrm, indeed I just noticed that. Pretty gross... it should definitly
> > be
> > > renamed, is will caused endless confusion with unrelated iommu.h and
> > > iommu_* interfaces which represent something different.
> >
> > The first direction to go should be trying to unify all the different
> > iommu* interfaces into the iommu-api. The generic api will definitly
> > need to be extended for that, but since it is an in-kernel interface
> > thats no problem.
>
> Well, I suppose I'm the de-facto candidate to take care of the powerpc
> side then :-)
>
> I don't have the bandwidth right now, but I'll try to have a look when
> time permits.
Btw. I have some ideas to extend the IOMMU-API to also support GART-like
IOMMUs. These pieces could also support (limited-size) domains (without
isolation) using segmentation. Not sure if this makes sense for the
use-cases in other architectures but we should not declare this
impossible for now.
--
Joerg Roedel - AMD Operating System Research Center
Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
General Managers: Alberto Bozzo, Andrew Bowd
Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr. 43632
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-08-02 8:30 ` FUJITA Tomonori
@ 2010-08-02 9:03 ` Russell King - ARM Linux
2010-08-02 9:20 ` FUJITA Tomonori
2010-08-02 9:45 ` Roedel, Joerg
1 sibling, 1 reply; 47+ messages in thread
From: Russell King - ARM Linux @ 2010-08-02 9:03 UTC (permalink / raw)
To: FUJITA Tomonori
Cc: benh, dwalker, arnd, Joerg.Roedel, linux-kernel, stepanm,
linux-arm-msm, linux-arm-kernel
On Mon, Aug 02, 2010 at 05:30:26PM +0900, FUJITA Tomonori wrote:
> ARM's iommu code (arch/plat-omap/include/plat/iommu.h) is a library to
> simplify the IOMMU implementations. It could be useful for all the
> iommu implementations.
ITYM OMAP's iommu code.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-08-02 9:03 ` Russell King - ARM Linux
@ 2010-08-02 9:20 ` FUJITA Tomonori
2010-08-02 10:04 ` Russell King - ARM Linux
0 siblings, 1 reply; 47+ messages in thread
From: FUJITA Tomonori @ 2010-08-02 9:20 UTC (permalink / raw)
To: linux
Cc: fujita.tomonori, benh, dwalker, arnd, Joerg.Roedel, linux-kernel,
stepanm, linux-arm-msm, linux-arm-kernel
On Mon, 2 Aug 2010 10:03:26 +0100
Russell King - ARM Linux <linux@arm.linux.org.uk> wrote:
> On Mon, Aug 02, 2010 at 05:30:26PM +0900, FUJITA Tomonori wrote:
> > ARM's iommu code (arch/plat-omap/include/plat/iommu.h) is a library to
> > simplify the IOMMU implementations. It could be useful for all the
> > iommu implementations.
>
> ITYM OMAP's iommu code.
Yeah, I meant that we could extend it to make it useful for other
iommu implementations. At least, we could make something generic like
struct iommu_functions, I think. Then we can embed a generic iommu
structure into an iommu specific struct (like we do with inode).
The current iommu-api (include/linux/iommu.h) is just about domain and
mapping concept. We can implement it on the top of the above
infrastructure.
I'm still trying to figure out how the DMA-API can work well with
them.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-08-02 8:30 ` FUJITA Tomonori
2010-08-02 9:03 ` Russell King - ARM Linux
@ 2010-08-02 9:45 ` Roedel, Joerg
1 sibling, 0 replies; 47+ messages in thread
From: Roedel, Joerg @ 2010-08-02 9:45 UTC (permalink / raw)
To: FUJITA Tomonori
Cc: benh@kernel.crashing.org, arnd@arndb.de, stepanm@codeaurora.org,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Mon, Aug 02, 2010 at 04:30:26AM -0400, FUJITA Tomonori wrote:
> On Mon, 02 Aug 2010 18:03:02 +1000
> Benjamin Herrenschmidt <benh@kernel.crashing.org> wrote:
>
> > On Mon, 2010-08-02 at 09:48 +0200, Roedel, Joerg wrote:
> > > > Hrm, indeed I just noticed that. Pretty gross... it should definitly
> > > be
> > > > renamed, is will caused endless confusion with unrelated iommu.h and
> > > > iommu_* interfaces which represent something different.
> > >
> > > The first direction to go should be trying to unify all the different
> > > iommu* interfaces into the iommu-api. The generic api will definitly
> > > need to be extended for that, but since it is an in-kernel interface
> > > thats no problem.
> >
> > Well, I suppose I'm the de-facto candidate to take care of the powerpc
> > side then :-)
>
> We already agreed that what the iommu-api looks like?
Well, we currently trying to figure out how to extend the IOMMU-API
concepts to fit the omap-hardware in. Thats what I currently discuss
with Stephan. It looks to me that we need to add the concept
of device contexts to the IOMMU-API. We should also add IO-TLB
management functions. The TLB management is currently handled completly
in the backend driver. This needs to be changed and makes sense for
AMD IOMMUs and Intel IOMMUs with QPI too.
> ARM's iommu code (arch/plat-omap/include/plat/iommu.h) is a library to
> simplify the IOMMU implementations. It could be useful for all the
> iommu implementations.
To me it looks like a very hardware specific library. But it should fit
well in the domain/device concept the IOMMU-API provides (when we also
add device-contexts to it)
> The current iommu-api (include/linux/iommu.h) provides the common
> interface for specific purposes (for KVM).
The IOMMU-API is not limited to the purposes of KVM. There is
currently development effort to use the IOMMU-API for UIO stuff. So the
IOMMU-API is by no means KVM specific.
> Another question is how the above can work with the DMA-API.
This would work if we handle every device-context the platform provides
as 'struct device'. But does that really need to work with the DMA-API?
What is the driver use-case for that?
Joerg
--
Joerg Roedel - AMD Operating System Research Center
Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
General Managers: Alberto Bozzo, Andrew Bowd
Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr. 43632
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-08-02 9:20 ` FUJITA Tomonori
@ 2010-08-02 10:04 ` Russell King - ARM Linux
2010-08-02 15:26 ` FUJITA Tomonori
0 siblings, 1 reply; 47+ messages in thread
From: Russell King - ARM Linux @ 2010-08-02 10:04 UTC (permalink / raw)
To: FUJITA Tomonori
Cc: benh, dwalker, arnd, Joerg.Roedel, linux-kernel, stepanm,
linux-arm-msm, linux-arm-kernel
On Mon, Aug 02, 2010 at 06:20:01PM +0900, FUJITA Tomonori wrote:
> On Mon, 2 Aug 2010 10:03:26 +0100
> Russell King - ARM Linux <linux@arm.linux.org.uk> wrote:
>
> > On Mon, Aug 02, 2010 at 05:30:26PM +0900, FUJITA Tomonori wrote:
> > > ARM's iommu code (arch/plat-omap/include/plat/iommu.h) is a library to
> > > simplify the IOMMU implementations. It could be useful for all the
> > > iommu implementations.
> >
> > ITYM OMAP's iommu code.
>
> Yeah, I meant that we could extend it to make it useful for other
> iommu implementations. At least, we could make something generic like
> struct iommu_functions, I think. Then we can embed a generic iommu
> structure into an iommu specific struct (like we do with inode).
>
> The current iommu-api (include/linux/iommu.h) is just about domain and
> mapping concept. We can implement it on the top of the above
> infrastructure.
>
> I'm still trying to figure out how the DMA-API can work well with
> them.
I'm not sure it can in totality. The DMA-API solves the host CPU <->
device aspect of DMA support only.
However, there is another use case for IOMMUs, which is to allow two
separate peripheral devices to communicate with each other via system
memory. As the streaming DMA-API involves the idea of buffer ownership
(of a singular agent), it is unsuitable for this use case.
The coherent allocation part of the DMA-API also only deals with the
idea of there being a singular DMA agent accessing the allocated buffer
(in conjunction with the host CPU).
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-08-02 10:04 ` Russell King - ARM Linux
@ 2010-08-02 15:26 ` FUJITA Tomonori
0 siblings, 0 replies; 47+ messages in thread
From: FUJITA Tomonori @ 2010-08-02 15:26 UTC (permalink / raw)
To: linux
Cc: fujita.tomonori, benh, dwalker, arnd, Joerg.Roedel, linux-kernel,
stepanm, linux-arm-msm, linux-arm-kernel
On Mon, 2 Aug 2010 11:04:19 +0100
Russell King - ARM Linux <linux@arm.linux.org.uk> wrote:
> On Mon, Aug 02, 2010 at 06:20:01PM +0900, FUJITA Tomonori wrote:
> > On Mon, 2 Aug 2010 10:03:26 +0100
> > Russell King - ARM Linux <linux@arm.linux.org.uk> wrote:
> >
> > > On Mon, Aug 02, 2010 at 05:30:26PM +0900, FUJITA Tomonori wrote:
> > > > ARM's iommu code (arch/plat-omap/include/plat/iommu.h) is a library to
> > > > simplify the IOMMU implementations. It could be useful for all the
> > > > iommu implementations.
> > >
> > > ITYM OMAP's iommu code.
> >
> > Yeah, I meant that we could extend it to make it useful for other
> > iommu implementations. At least, we could make something generic like
> > struct iommu_functions, I think. Then we can embed a generic iommu
> > structure into an iommu specific struct (like we do with inode).
> >
> > The current iommu-api (include/linux/iommu.h) is just about domain and
> > mapping concept. We can implement it on the top of the above
> > infrastructure.
> >
> > I'm still trying to figure out how the DMA-API can work well with
> > them.
>
> I'm not sure it can in totality. The DMA-API solves the host CPU <->
> device aspect of DMA support only.
>
> However, there is another use case for IOMMUs, which is to allow two
> separate peripheral devices to communicate with each other via system
> memory. As the streaming DMA-API involves the idea of buffer ownership
> (of a singular agent), it is unsuitable for this use case.
>
> The coherent allocation part of the DMA-API also only deals with the
> idea of there being a singular DMA agent accessing the allocated buffer
> (in conjunction with the host CPU).
I don't have a clear idea what kinda API works well in the above case
yet.
But we have been talking about more bigger things? Not just about the
interface, how things work together.
- OMAP's iommu code is a library to simplify OMAP implementations.
- include/linux/iommu.h is an interface to IOMMUs for specific
interfaces.
- the DMA API could access to IOMMUs internally.
IOMMU library provides generic iommu interfaces (a structure including
IOMMU implementation specific function pointers). KVM uses some of
them. Architectures could implement the DMA API on the top of some the
interfaces too.
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-08-02 7:58 ` Roedel, Joerg
@ 2010-08-02 20:29 ` Zach Pfeffer
2010-08-03 9:23 ` Roedel, Joerg
0 siblings, 1 reply; 47+ messages in thread
From: Zach Pfeffer @ 2010-08-02 20:29 UTC (permalink / raw)
To: Roedel, Joerg
Cc: stepanm@codeaurora.org, FUJITA Tomonori, arnd@arndb.de,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Mon, Aug 02, 2010 at 09:58:02AM +0200, Roedel, Joerg wrote:
> Hi Stephan,
>
> On Fri, Jul 30, 2010 at 01:19:06AM -0400, stepanm@codeaurora.org wrote:
> > Unlike a more traditional system with one IOMMU between the bus and
> > memory, MSM has multiple IOMMUs, with each one hard-wired to a dedicated
> > device. Furthermore, each IOMMU can have more than one translation
> > context. One of the use cases is being able to create mappings within
> > multiple instances of one context, and arbitrarily context-switch the
> > IOMMU on the fly.
>
> The IOMMU-API supports multiple IOMMUs (at least multiple AMD/Intel
> IOMMUs). But the face that there are more than one IOMMU is hidden in
> the backend driver implementation. The API itself only works with
> domains and devices. The IOMMU driver needs to know which IOMMU it needs
> to program for a given device. If I understand the concept of your
> hardware correctly you also have this information.
>
> > It sounds like the domain abstraction and attach_device/detach_device can
> > encapsulate this rather nicely and I am in the process of updating my
> > driver to fit this framework.
> >
> > My problem, however, is with iommu_domain_alloc(). This will set up a
> > domain and call the ops function to initialize it, but I want to be able
> > to pass it an ???IOMMU id" that will tell the underlying driver which IOMMU
> > (and which "stream id") is to be associated with that domain instance.
> > This can be a void* parameter that gets passed through to domain_init. I
> > feel like this change will make it easy to deal with multiple
> > IOMMUs/translation contexts, and implementations that have only a singular
> > IOMMU/translation context are free to ignore that parameter.
>
> In the means of the IOMMU-API the domain is the abstraction of an
> address space (in other words a page table). The IOMMU(s) which this domain
> is later assigned to are determined by the iommu_attach_device calls.
> I think the right way to go here is to create the concept of a
> device-context in the IOMMU-API and add functions like
>
> iommu_attach_context(struct iommu_domain *domain,
> struct iommu_context *ctxt);
> iommu_detach_context(struct iommu_context *ctxt);
>
> This would work if you can determine in your iommu-driver which iommu
> you need to program for which device. What do you think?
>
Joerg, I'd like to make sure I understand this. A domain is an address
space separate from the actual page-tables that may be part of an
iommu_context, correct? After I iommu_attach_context the ctxt will
reflect the address space of the domain, correct?
>
> Joerg
>
> --
> Joerg Roedel - AMD Operating System Research Center
>
> Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
> General Managers: Alberto Bozzo, Andrew Bowd
> Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr. 43632
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-arm-msm" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-08-02 20:29 ` Zach Pfeffer
@ 2010-08-03 9:23 ` Roedel, Joerg
2010-08-03 18:43 ` Stepan Moskovchenko
0 siblings, 1 reply; 47+ messages in thread
From: Roedel, Joerg @ 2010-08-03 9:23 UTC (permalink / raw)
To: Zach Pfeffer
Cc: stepanm@codeaurora.org, FUJITA Tomonori, arnd@arndb.de,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Mon, Aug 02, 2010 at 04:29:38PM -0400, Zach Pfeffer wrote:
> On Mon, Aug 02, 2010 at 09:58:02AM +0200, Roedel, Joerg wrote:
> > In the means of the IOMMU-API the domain is the abstraction of an
> > address space (in other words a page table). The IOMMU(s) which this domain
> > is later assigned to are determined by the iommu_attach_device calls.
> > I think the right way to go here is to create the concept of a
> > device-context in the IOMMU-API and add functions like
> >
> > iommu_attach_context(struct iommu_domain *domain,
> > struct iommu_context *ctxt);
> > iommu_detach_context(struct iommu_context *ctxt);
> >
> > This would work if you can determine in your iommu-driver which iommu
> > you need to program for which device. What do you think?
> >
>
> Joerg, I'd like to make sure I understand this. A domain is an address
> space separate from the actual page-tables that may be part of an
> iommu_context, correct? After I iommu_attach_context the ctxt will
> reflect the address space of the domain, correct?
A domain is defined by a single page-table which can be modified using
the iommu_map/iommu_unmap function calls. I am not completly sure what
you mean by an iommu_context. Can you describe what it means in your
context?
Joerg
--
AMD Operating System Research Center
Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
General Managers: Alberto Bozzo, Andrew Bowd
Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr. 43632
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-08-03 9:23 ` Roedel, Joerg
@ 2010-08-03 18:43 ` Stepan Moskovchenko
2010-08-04 9:52 ` Roedel, Joerg
0 siblings, 1 reply; 47+ messages in thread
From: Stepan Moskovchenko @ 2010-08-03 18:43 UTC (permalink / raw)
To: Roedel, Joerg
Cc: Zach Pfeffer, FUJITA Tomonori, arnd@arndb.de,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On 8/3/2010 2:23 AM, Roedel, Joerg wrote:
> On Mon, Aug 02, 2010 at 04:29:38PM -0400, Zach Pfeffer wrote:
>> On Mon, Aug 02, 2010 at 09:58:02AM +0200, Roedel, Joerg wrote:
>>> In the means of the IOMMU-API the domain is the abstraction of an
>>> address space (in other words a page table). The IOMMU(s) which this domain
>>> is later assigned to are determined by the iommu_attach_device calls.
>>> I think the right way to go here is to create the concept of a
>>> device-context in the IOMMU-API and add functions like
>>>
>>> iommu_attach_context(struct iommu_domain *domain,
>>> struct iommu_context *ctxt);
>>> iommu_detach_context(struct iommu_context *ctxt);
>>>
>>> This would work if you can determine in your iommu-driver which iommu
>>> you need to program for which device. What do you think?
>>>
>> Joerg, I'd like to make sure I understand this. A domain is an address
>> space separate from the actual page-tables that may be part of an
>> iommu_context, correct? After I iommu_attach_context the ctxt will
>> reflect the address space of the domain, correct?
> A domain is defined by a single page-table which can be modified using
> the iommu_map/iommu_unmap function calls. I am not completly sure what
> you mean by an iommu_context. Can you describe what it means in your
> context?
>
> Joerg
>
Joerg,
I think with some rework, all my use cases can be handled by your
existing iommu API. If the domain is treated basically a page table,
there will be some changes, but I think it can be done. I will push a
new version of my driver in a few days.
One thing that may be helpful for the future, however, is maybe
something like adding iommu_tlb_flush to the ops. I suppose this would
either have to take a device, or the domain would need to keep a list of
devices it had been attached to (so that their TLBs can be invalidated).
But I suppose on the other hand, iommu_map/unmap may be able to just
implicitly invalidate the TLB also, since TLB invalidation often follows
map/unmap. What are your thoughts?
Thanks
Steve
^ permalink raw reply [flat|nested] 47+ messages in thread
* Re: [PATCH 1/2] arm: msm: Add System MMU support.
2010-08-03 18:43 ` Stepan Moskovchenko
@ 2010-08-04 9:52 ` Roedel, Joerg
0 siblings, 0 replies; 47+ messages in thread
From: Roedel, Joerg @ 2010-08-04 9:52 UTC (permalink / raw)
To: Stepan Moskovchenko
Cc: Zach Pfeffer, FUJITA Tomonori, arnd@arndb.de,
linux-arm-kernel@lists.infradead.org,
linux-arm-msm@vger.kernel.org, dwalker@codeaurora.org,
linux-kernel@vger.kernel.org
On Tue, Aug 03, 2010 at 02:43:20PM -0400, Stepan Moskovchenko wrote:
> On 8/3/2010 2:23 AM, Roedel, Joerg wrote:
> > A domain is defined by a single page-table which can be modified using
> > the iommu_map/iommu_unmap function calls. I am not completly sure what
> > you mean by an iommu_context. Can you describe what it means in your
> > context?
>
> Joerg,
> I think with some rework, all my use cases can be handled by your
> existing iommu API. If the domain is treated basically a page table,
> there will be some changes, but I think it can be done. I will push a
> new version of my driver in a few days.
>
> One thing that may be helpful for the future, however, is maybe
> something like adding iommu_tlb_flush to the ops. I suppose this would
> either have to take a device, or the domain would need to keep a list of
> devices it had been attached to (so that their TLBs can be invalidated).
> But I suppose on the other hand, iommu_map/unmap may be able to just
> implicitly invalidate the TLB also, since TLB invalidation often follows
> map/unmap. What are your thoughts?
Sounds good. I am curious for your patches :-)
For the TLB-flush question, I think it would make sense to add iommu
tlb flushing functions to the IOMMU-API. We currently flush the TLB
implicitly in the map/unmap calls but thats very inefficient. It would
be better to have a seperate function for it in the API. The right
parameter for such a function is a domain. The IOMMU driver knows which
devices are attached to a domain an could easily flush all TLBs.
One alternative I can think of: An iommu_domain_commit() function which
syncs software changes of a domain to the hardware. The map/unmap calls
have to save which parts of the tlb need to be flushed and commit does
flush those parts then (or flush everything).
Joerg
--
AMD Operating System Research Center
Advanced Micro Devices GmbH Einsteinring 24 85609 Dornach
General Managers: Alberto Bozzo, Andrew Bowd
Registration: Dornach, Landkr. Muenchen; Registerger. Muenchen, HRB Nr. 43632
^ permalink raw reply [flat|nested] 47+ messages in thread
end of thread, other threads:[~2010-08-04 9:49 UTC | newest]
Thread overview: 47+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <1280270466-13503-1-git-send-email-stepanm@codeaurora.org>
2010-07-27 22:43 ` [PATCH 1/2] arm: msm: Add System MMU support Daniel Walker
2010-07-28 8:39 ` Arnd Bergmann
2010-07-28 17:39 ` stepanm
2010-07-28 17:50 ` Arnd Bergmann
2010-07-28 21:21 ` Russell King - ARM Linux
2010-07-29 4:15 ` FUJITA Tomonori
2010-07-29 8:12 ` Arnd Bergmann
2010-07-29 11:47 ` Russell King - ARM Linux
2010-07-30 6:14 ` FUJITA Tomonori
2010-07-29 0:58 ` stepanm
2010-07-29 3:35 ` FUJITA Tomonori
2010-07-29 8:26 ` Arnd Bergmann
2010-07-29 8:35 ` FUJITA Tomonori
2010-07-29 8:40 ` Roedel, Joerg
2010-07-29 8:46 ` FUJITA Tomonori
2010-07-29 9:06 ` Roedel, Joerg
2010-07-29 9:14 ` FUJITA Tomonori
2010-07-29 9:25 ` Roedel, Joerg
2010-07-29 9:28 ` Roedel, Joerg
2010-07-29 9:44 ` FUJITA Tomonori
2010-07-29 10:01 ` Roedel, Joerg
2010-07-29 11:25 ` Arnd Bergmann
2010-07-29 12:12 ` Roedel, Joerg
2010-07-29 13:01 ` Arnd Bergmann
2010-07-30 5:19 ` stepanm
2010-07-30 8:01 ` Arnd Bergmann
2010-07-30 16:25 ` stepanm
2010-07-30 21:59 ` Arnd Bergmann
2010-07-30 22:58 ` stepanm
2010-07-31 9:37 ` Arnd Bergmann
2010-08-02 7:58 ` Roedel, Joerg
2010-08-02 20:29 ` Zach Pfeffer
2010-08-03 9:23 ` Roedel, Joerg
2010-08-03 18:43 ` Stepan Moskovchenko
2010-08-04 9:52 ` Roedel, Joerg
2010-07-31 3:15 ` Benjamin Herrenschmidt
2010-08-02 7:48 ` Roedel, Joerg
2010-08-02 8:03 ` Benjamin Herrenschmidt
2010-08-02 8:10 ` Roedel, Joerg
2010-08-02 8:30 ` FUJITA Tomonori
2010-08-02 9:03 ` Russell King - ARM Linux
2010-08-02 9:20 ` FUJITA Tomonori
2010-08-02 10:04 ` Russell King - ARM Linux
2010-08-02 15:26 ` FUJITA Tomonori
2010-08-02 9:45 ` Roedel, Joerg
2010-08-02 8:35 ` Roedel, Joerg
2010-07-31 2:30 ` Benjamin Herrenschmidt
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).