From: Felipe Balbi <balbi@ti.com>
To: Thomas Gleixner <tglx@linutronix.de>
Cc: Jason Cooper <jason@lakedaemon.net>,
linux-kernel@vger.kernel.org, linux-omap@vger.kernel.org,
Suman Anna <s-anna@ti.com>, Roger Quadros <rogerq@ti.com>
Subject: Re: Routable IRQs
Date: Wed, 30 Dec 2015 12:41:37 -0600 [thread overview]
Message-ID: <87ziwrixsu.fsf@ti.com> (raw)
In-Reply-To: <alpine.DEB.2.11.1512301903450.28591@nanos>
[-- Attachment #1: Type: text/plain, Size: 4387 bytes --]
Hi Thomas,
Thomas Gleixner <tglx@linutronix.de> writes:
> On Tue, 29 Dec 2015, Felipe Balbi wrote:
>> Anyway, the interesting part is that PRUSS has 64 events (on current
>> incarnations at least) and PRUSS has 10 physical IRQ lines to the ARM
>> land. Each of these 64 events can be routed to any of these 10 IRQ
>> lines. This might not be very useful on UP (AM335x & AM437x) other than
>> the fact that soft-IP drivers running on Linux would need to guarantee
>> they are the ones who should handle the IRQ. However, on SMP (AM57xx) we
>> could have real tangible benefits by means of IRQ affinity, etc.
>>
>> So, the question is, what is there in IRQ subsystem today for routable
>> IRQ support ?
>>
>> If a Diagram helps here's a simple one. Note that I'm not showing
>> details on the PRUSS side, but that side can also map events pretty much
>> any way it wants.
>>
>> .--------------------. .--------------------.
>> | HOST CPU | | PRUSS |
>> |--------------------| |--------------------|
>> | | | |
>> | irq0 |<-.----------|evt0 |
>> | | | | |
>> | irq1 | | .-------|evt1 |
>> | | | | | |
>> | irq2 | '----------|evt2 |
>> | | | | |
>> | irq3 | | | |
>> | | | | |
>> | irq4 | | | . |
>> | | | | |
>> | irq5 | | | . |
>> | | | | |
>> | irq6 | | | . |
>> | | | | |
>> | irq7 |<----' | |
>> | | | |
>> | irq8 | | |
>> | | | |
>> | irq9 |<------------|evtN |
>> '--------------------' '--------------------'
>>
>> Given this setup, what I want to do, is let soft-IP drivers running on
>> linux rely on standard *request_*irq() calls and DTS descrition. But I'm
>> still considering how/if we should describe the routing itself or just
>> go round-robin (i.o.w. irq0 -> evt0, irq1 -> evt1, ..., irq9 -> evt9,
>> irq0 -> evt10, ...).
>>
>> Thoughts ?
>
> I have a few questions:
>
> - Is there a "mapping" block between PRUSS and the host interrupt controller
> or is this "mapping" block part of PRUSS?
The description in TRM is a bit "poor", but from what I can gather, the
mapping is done on an interrupt controller inside the PRUSS. However,
Linux is the one who's got the driver for that INTC (well, Linux will be
the one with the soft ethernet/uart/whatever IP to talk to). All of its
(INTC's) registers are memory mapped to the ARM side.
> - We all know how well shared interrupts work. Is there a point of supporting
> 64 interrupts when you only have 10 irq lines available?
I'm looking at these 64 events more like MSI kind of events. It's just
that the events themselves can be routed to any of the 10 available HW
IRQ lines.
> - I assume that the PRUSS interrupt mapping is more or less a question of the
> firmware implementation. So you either have a fixed association in the
> firmware which is reflected in the DT description of the IP block or you
> need an interface to tell the PRUSS firmware which event it should map to
> which irq line. Is there actually a value in doing the latter?
right, I'd say the mapping is pretty static. Unless Suman has some extra
information which I don't. I guess the question was really to see if
there was an easy way for doing this so we don't have to mess with DTS
for every other FW and their neighbor.
Chances are (or at least I'm speculating) in most cases we won't use
more than 10 events anyway (Suman ?) so we might not run into any
troubles.
--
balbi
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 818 bytes --]
next prev parent reply other threads:[~2015-12-30 18:41 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-12-29 20:11 Routable IRQs Felipe Balbi
2015-12-30 18:17 ` Thomas Gleixner
2015-12-30 18:41 ` Felipe Balbi [this message]
2015-12-30 19:49 ` Thomas Gleixner
2015-12-30 20:10 ` Felipe Balbi
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=87ziwrixsu.fsf@ti.com \
--to=balbi@ti.com \
--cc=jason@lakedaemon.net \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-omap@vger.kernel.org \
--cc=rogerq@ti.com \
--cc=s-anna@ti.com \
--cc=tglx@linutronix.de \
/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).