linuxppc-dev.lists.ozlabs.org archive mirror
 help / color / mirror / Atom feed
* Shared Interrupts Question (2.4)
@ 2003-05-08 20:08 Kent Borg
  2003-05-08 20:20 ` bhupinder sahran
  2003-05-08 21:14 ` Dale Farnsworth
  0 siblings, 2 replies; 7+ messages in thread
From: Kent Borg @ 2003-05-08 20:08 UTC (permalink / raw)
  To: linuxppc-embedded


I am trying to understand "kinda shared" interrupts.

There are various interrupts in my not-yet-released CPU, and I have
interrupt code that knows how to talk to them.  So far so good.  I
also have an external interrupt controller that groups together 18
external interrupt sources and sends them in one CPU pin.  This
external controller has a register for enabling interrupts, and a
register for status/acknowledge.  Pretty standard.

The CPU code doesn't know about the external controller.  It seems
silly to rewrite the CPU-specific interrput code to accommodate this
board-specific detail (besides then my code won't match Dale's).  So I
figure I tell the kernel I am doing shared interrupts.

So where do I enable, disable, and acknowledge these external bits?
Specifically, I am trying to get a couple of serial ports working.  I
can put conditional code in serial.c startup() to enable these
interrupts, but how do I know which serial port?  Add a conditionally
compiled sub-IRQ number to serial_state structure?

Is there a cleaner way?


Thanks,

-kb


** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/

^ permalink raw reply	[flat|nested] 7+ messages in thread
* Re: Shared Interrupts Question (2.4)
@ 2003-05-08 21:48 Kent Borg
  0 siblings, 0 replies; 7+ messages in thread
From: Kent Borg @ 2003-05-08 21:48 UTC (permalink / raw)
  To: Dale Farnsworth, linuxppc-embedded


Dale Farnsworth wrote:
> Create and register a board-specific interrupt driver.  Assign it
> a range of irqs (non-conflicting with the main interrupt driver).
> When called with an irq outside its range, the board-specific driver
> routines forward the call to the main driver.  The board-specific driver
> does a request_irq at init time for the one main irq it is multiplexing.

Yes!  Flatten the cascaded interrupts to IRQs outside the CPU's, range,
and write a software multiplexer that registers for the one IRQ the CPU
knows. Right?

That's much better than what I had in mind.


Thanks,

-kb

** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2003-05-10  2:00 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2003-05-08 20:08 Shared Interrupts Question (2.4) Kent Borg
2003-05-08 20:20 ` bhupinder sahran
2003-05-08 20:28   ` Kent Borg
2003-05-08 21:14 ` Dale Farnsworth
2003-05-09 17:34   ` Kent Borg
2003-05-10  2:00     ` Dale Farnsworth
  -- strict thread matches above, loose matches on Subject: below --
2003-05-08 21:48 Kent Borg

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).