Line 8:
Line 8:
{{hwstub}}
{{hwstub}}
{{yagcd}}
{{yagcd}}
+
+
==Interrupt Cause (0x0C003000)==
+
{| style="border: 1px solid #bbb; border-collapse: collapse; background-color: #eef; padding: 0.2em 0.2em 0.2em 0.2em;" border="1" cellpadding="2"
+
|- style="background-color: #ddd;"
+
! IRQ
+
! Description
+
|-
+
| 0 || GP Runtime Error
+
|-
+
| 1 || Reset Switch
+
|-
+
| 2 || DVD
+
|-
+
| 3 || Serial
+
|-
+
| 4 || EXI
+
|-
+
| 5 || AI (Audio Interface)
+
|-
+
| 6 || DSP
+
|-
+
| 7 || MEM (Memory Interface)
+
|-
+
| 8 || VI (Video Interface)
+
|-
+
| 9 || PE Token
+
|-
+
| 10 || PE Finish
+
|-
+
| 11 || CP (Command Processor) FIFO
+
|-
+
| 12 || Debugger
+
|-
+
| 13 || Highspeed Port
+
|-
+
| 14 || {{hw|Hollywood IRQs}}
+
|-
+
| 15 || Unused/reserved
+
|-
+
| 16 || Reset Switch State
+
|-
+
| 17-31 || Unused/reserved
+
|}
+
+
==Interrupt Mask (0x0C003004)==
+
{| style="border: 1px solid #bbb; border-collapse: collapse; background-color: #eef; padding: 0.2em 0.2em 0.2em 0.2em;" border="1" cellpadding="2"
+
|- style="background-color: #ddd;"
+
! IRQ
+
! Description
+
|-
+
| 0 || GP Runtime Error
+
|-
+
| 1 || Reset Switch
+
|-
+
| 2 || DVD
+
|-
+
| 3 || Serial
+
|-
+
| 4 || EXI
+
|-
+
| 5 || AI (Audio Interface)
+
|-
+
| 6 || DSP
+
|-
+
| 7 || MEM (Memory Interface)
+
|-
+
| 8 || VI (Video Interface)
+
|-
+
| 9 || PE Token
+
|-
+
| 10 || PE Finish
+
|-
+
| 11 || CP (Command Processor) FIFO
+
|-
+
| 12 || Debugger
+
|-
+
| 13 || Highspeed Port
+
|-
+
| 14 || {{hw|Hollywood IRQs}}
+
|-
+
| 15-31 || Unused/reserved
+
|}
+
+
{{reg32 | PI_FIFO_WP | addr = 0x0C003014 | hifields = 3 | lofields = 2 |
+
|2 |1 | 13 |
+
|U |R |R/W |
+
| |WRAPPED|ADDR ||
+
|11 |5 |
+
|R/W |U |
+
|ADDR | |
+
}}
+
This register holds the current address and state of the CPU FIFO write pointer.
+
{{regdesc
+
|WRAPPED|Indicates the write pointer reached the end of the FIFO and wrapped to the start. Note that it is in a different location from the gamecube to allow for MEM2 addresses.
+
|ADDR|Word address that will be written to next.
+
}}