Skip to content

Latest commit

 

History

History
73 lines (64 loc) · 2.32 KB

intc.md

File metadata and controls

73 lines (64 loc) · 2.32 KB

non-pm interrupt controllers

ARM

According to a developer at MediaTek this is the same IP as is in some MediaTek chips. See this thread.

/* The MSC313 contains two interrupt controllers that are almost identical.
 * The first one handles "FIQ" interrupts and the second handles "IRQ"
 * interrupts. The only differences are the first one only has bits for 32
 * interrupts and needs irqs to be cleared.
 *
 * It's also worth noting that the GIC needs to be configured to disable
 * bypassing the GIC when delivering interrupts from the FIQ controller.
 * Currently this is being done by u-boot.
 *
 * 0x1f201310
 * GIC 96 - 127 - hardware fiq interrupts that go through the intc before the gic
 * mask bits
 * 0x0 0  - 15
 * 0x4 16 - 31
 *
 * polarity
 * 0x10 0 - 15
 * 0x14 16 - 31
 *
 * clear bits
 * 0x20
 * 0x24
 *
 * 0x1f201350
 * GIC 32 - 95 - hardware irq interrupts that go through the intc before the gic
 * mask bits
 * 0x0 - 0 - 15
 * 0x4 - 16 - 31
 * 0x8 - 31 - 47
 * 0xc - 48 - 63
 *
 * polarity
 * 0x10 - 0 - 15
 * 0x14 - 16 - 31
 * 0x18 - 31 - 47
 * 0x1c - 48 - 63
 *
 * raw interrupt status bits -- where did this come from?
 * 0x20
 * 0x24
 * 0x28
 * 0x2c
 */

MIPS

On MIPS platforms, the interupt controller is instanciated twice:

  • at 0xbf203340, connected to CPU interrupt 2; ACK/EOI writes are not needed
  • at 0xbf203300, connected to CPU interrupt 3; ACK/EOI writes are needed

Register map:

RIU phys description
0x08 0x10 interrupt mask, 0=allow, 1=block (0..15)
0x0a 0x14 interrupt mask, 0=allow, 1=block (16..31)
0x0c 0x18 interrupt mask, 0=allow, 1=block (32..47)
0x0e 0x1c interrupt mask, 0=allow, 1=block (48..63)
0x18 0x30 interrupt status, write 1 to ACK (0..15)
0x1a 0x34 interrupt status, write 1 to ACK (16..31)
0x1c 0x38 interrupt status, write 1 to ACK (32..47)
0x1e 0x3c interrupt status, write 1 to ACK (48..63)