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
*/
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) |