From: stepanm@codeaurora.org (stepanm at codeaurora.org)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH 1/2] arm: msm: Add System MMU support.
Date: Thu, 29 Jul 2010 22:19:06 -0700 (PDT) [thread overview]
Message-ID: <d493494df33aaf65e526181b1dbafce3.squirrel@www.codeaurora.org> (raw)
In-Reply-To: <20100729090607.GN26098@amd.com>
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 at vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
>
next prev parent reply other threads:[~2010-07-30 5:19 UTC|newest]
Thread overview: 48+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-07-27 22:41 [PATCH 1/2] arm: msm: Add System MMU support Stepan Moskovchenko
2010-07-27 22:43 ` Daniel Walker
2010-07-28 8:39 ` Arnd Bergmann
2010-07-28 17:39 ` stepanm at codeaurora.org
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 at codeaurora.org
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 at codeaurora.org [this message]
2010-07-30 8:01 ` Arnd Bergmann
2010-07-30 16:25 ` stepanm at codeaurora.org
2010-07-30 21:59 ` Arnd Bergmann
2010-07-30 22:58 ` stepanm at codeaurora.org
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
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=d493494df33aaf65e526181b1dbafce3.squirrel@www.codeaurora.org \
--to=stepanm@codeaurora.org \
--cc=linux-arm-kernel@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is 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).