Hardware Registers: Difference between revisions
Line 1,410: | Line 1,410: | ||
= 0xBE240000: GPIO = | = 0xBE240000: GPIO = | ||
{| class="wikitable" | |||
|- | |||
! Address | |||
! Size | |||
! Read/write | |||
! Description | |||
|- | |||
| 0xBE240000 || 4 || RW || Unknown | |||
|- | |||
| 0xBE240004 || 4 || R || GPIO read pin (1 bit = 1 pin) | |||
|- | |||
| 0xBE240008 || 4 || W || GPIO set pin (1 bit = 1 pin) | |||
|- | |||
| 0xBE24000C || 4 || W|| GPIO clear pin (1 bit = 1 pin) | |||
|- | |||
| 0xBE240010 || 4 || ? || Unknown | |||
|- | |||
| 0xBE240014 || 4 || ? || Unknown | |||
|- | |||
| 0xBE240018 || 4 || ? || Unknown | |||
|- | |||
| 0xBE24001C || 4 || ? || Unknown | |||
|- | |||
| 0xBE240020 || 4 || ? || Unknown | |||
|- | |||
| 0xBE240030 || 4 || ? || Unknown | |||
|- | |||
| 0xBE240040 || 4 || ? || Unknown | |||
|- | |||
| 0xBE240048 || 4 || ? || Unknown | |||
|- | |||
|} | |||
= 0xBE300000: Power management? = | = 0xBE300000: Power management? = |
Revision as of 22:46, 23 January 2023
0x07F00000: L2 cache
If we believe in the sysmem NIDs, 04g+ seem to have a "L2" cache we can send commands (writeback/invalidate/probe) to through this address.
0x07F80000~ also exists.
TODO need more info.
0xBC000000: Memory management
Physical Address | Size | R/W | Description |
---|---|---|---|
0xBC000000 | 4 | RW | Memory Protection 0x08000000 -> 0x081FFFFFF |
Bit(s) | Usage |
---|---|
31 | 0x081C0000 -> 0x081FFFFFF Kernel Write Enable |
30 | 0x081C0000 -> 0x081FFFFFF Kernel Read Enable |
29 | 0x081C0000 -> 0x081FFFFFF User Write Enable |
28 | 0x081C0000 -> 0x081FFFFFF User Read Enable |
27 | 0x08180000 -> 0x081BFFFFF Kernel Write Enable |
26 | 0x08180000 -> 0x081BFFFFF Kernel Read Enable |
25 | 0x08180000 -> 0x081BFFFFF User Write Enable |
24 | 0x08180000 -> 0x081BFFFFF User Read Enable |
23 | 0x08140000 -> 0x0817FFFFF Kernel Write Enable |
22 | 0x08140000 -> 0x0817FFFFF Kernel Read Enable |
21 | 0x08140000 -> 0x0817FFFFF User Write Enable |
20 | 0x08140000 -> 0x0817FFFFF User Read Enable |
19 | 0x08100000 -> 0x0813FFFFF Kernel Write Enable |
18 | 0x08100000 -> 0x0813FFFFF Kernel Read Enable |
17 | 0x08100000 -> 0x0813FFFFF User Write Enable |
16 | 0x08100000 -> 0x0813FFFFF User Read Enable |
15 | 0x080C0000 -> 0x080FFFFFF Kernel Write Enable |
14 | 0x080C0000 -> 0x080FFFFFF Kernel Read Enable |
13 | 0x080C0000 -> 0x080FFFFFF User Write Enable |
12 | 0x080C0000 -> 0x080FFFFFF User Read Enable |
11 | 0x08080000 -> 0x080BFFFFF Kernel Write Enable |
10 | 0x08080000 -> 0x080BFFFFF Kernel Read Enable |
9 | 0x08080000 -> 0x080BFFFFF User Write Enable |
8 | 0x08080000 -> 0x080BFFFFF User Read Enable |
7 | 0x08040000 -> 0x0807FFFFF Kernel Write Enable |
6 | 0x08040000 -> 0x0807FFFFF Kernel Read Enable |
5 | 0x08040000 -> 0x0807FFFFF User Write Enable |
4 | 0x08040000 -> 0x0807FFFFF User Read Enable |
3 | 0x08000000 -> 0x08003FFFF Kernel Write Enable |
2 | 0x08000000 -> 0x08003FFFF Kernel Read Enable |
1 | 0x08000000 -> 0x08003FFFF User Write Enable |
0 | 0x08000000 -> 0x08003FFFF User Read Enable |
Physical Address | Size | R/W | Description |
---|---|---|---|
0xBC000004 | 4 | RW | Memory Protection 0x08200000 -> 0x083FFFFFF |
Bit(s) | Usage |
---|---|
31 | 0x083C0000 -> 0x083FFFFFF Kernel Write Enable |
30 | 0x083C0000 -> 0x083FFFFFF Kernel Read Enable |
29 | 0x083C0000 -> 0x083FFFFFF User Write Enable |
28 | 0x083C0000 -> 0x083FFFFFF User Read Enable |
27 | 0x083C0000 -> 0x083BFFFFF Kernel Write Enable |
26 | 0x083C0000 -> 0x083BFFFFF Kernel Read Enable |
25 | 0x08380000 -> 0x083BFFFFF User Write Enable |
24 | 0x08380000 -> 0x083BFFFFF User Read Enable |
23 | 0x08340000 -> 0x0837FFFFF Kernel Write Enable |
22 | 0x08340000 -> 0x0837FFFFF Kernel Read Enable |
21 | 0x08340000 -> 0x0837FFFFF User Write Enable |
20 | 0x08340000 -> 0x0837FFFFF User Read Enable |
19 | 0x08300000 -> 0x0833FFFFF Kernel Write Enable |
18 | 0x08300000 -> 0x0833FFFFF Kernel Read Enable |
17 | 0x08300000 -> 0x0833FFFFF User Write Enable |
16 | 0x08300000 -> 0x0833FFFFF User Read Enable |
15 | 0x082C0000 -> 0x082FFFFFF Kernel Write Enable |
14 | 0x082C0000 -> 0x082FFFFFF Kernel Read Enable |
13 | 0x082C0000 -> 0x082FFFFFF User Write Enable |
12 | 0x082C0000 -> 0x082FFFFFF User Read Enable |
11 | 0x08280000 -> 0x082BFFFFF Kernel Write Enable |
10 | 0x08280000 -> 0x082BFFFFF Kernel Read Enable |
9 | 0x08280000 -> 0x082BFFFFF User Write Enable |
8 | 0x08280000 -> 0x082BFFFFF User Read Enable |
7 | 0x08240000 -> 0x0827FFFFF Kernel Write Enable |
6 | 0x08240000 -> 0x0827FFFFF Kernel Read Enable |
5 | 0x08240000 -> 0x0827FFFFF User Write Enable |
4 | 0x08240000 -> 0x0827FFFFF User Read Enable |
3 | 0x08200000 -> 0x08203FFFF Kernel Write Enable |
2 | 0x08200000 -> 0x08203FFFF Kernel Read Enable |
1 | 0x08200000 -> 0x08203FFFF User Write Enable |
0 | 0x08200000 -> 0x08203FFFF User Read Enable |
Physical Address | Size | R/W | Description |
---|---|---|---|
0xBC000008 | 4 | RW | Memory Protection 0x08400000 -> 0x085FFFFFF |
Bit(s) | Usage |
---|---|
31 | 0x085c0000 -> 0x085FFFFFF Kernel Write Enable |
30 | 0x085c0000 -> 0x085FFFFFF Kernel Read Enable |
29 | 0x085c0000 -> 0x085FFFFFF User Write Enable |
28 | 0x085c0000 -> 0x085FFFFFF User Read Enable |
27 | 0x08580000 -> 0x085BFFFFF Kernel Write Enable |
26 | 0x08580000 -> 0x085BFFFFF Kernel Read Enable |
25 | 0x08580000 -> 0x085BFFFFF User Write Enable |
24 | 0x08580000 -> 0x085BFFFFF User Read Enable |
23 | 0x08540000 -> 0x0857FFFFF Kernel Write Enable |
22 | 0x08540000 -> 0x0857FFFFF Kernel Read Enable |
21 | 0x08540000 -> 0x0857FFFFF User Write Enable |
20 | 0x08540000 -> 0x0857FFFFF User Read Enable |
19 | 0x08500000 -> 0x0853FFFFF Kernel Write Enable |
18 | 0x08500000 -> 0x0853FFFFF Kernel Read Enable |
17 | 0x08500000 -> 0x0853FFFFF User Write Enable |
16 | 0x08500000 -> 0x0853FFFFF User Read Enable |
15 | 0x084c0000 -> 0x084FFFFFF Kernel Write Enable |
14 | 0x084c0000 -> 0x084FFFFFF Kernel Read Enable |
13 | 0x084c0000 -> 0x084FFFFFF User Write Enable |
12 | 0x084c0000 -> 0x084FFFFFF User Read Enable |
11 | 0x08480000 -> 0x084BFFFFF Kernel Write Enable |
10 | 0x08480000 -> 0x084BFFFFF Kernel Read Enable |
9 | 0x08480000 -> 0x084BFFFFF User Write Enable |
8 | 0x08480000 -> 0x084BFFFFF User Read Enable |
7 | 0x08440000 -> 0x0847FFFFF Kernel Write Enable |
6 | 0x08440000 -> 0x0847FFFFF Kernel Read Enable |
5 | 0x08440000 -> 0x0847FFFFF User Write Enable |
4 | 0x08440000 -> 0x0847FFFFF User Read Enable |
3 | 0x08400000 -> 0x08403FFFF Kernel Write Enable |
2 | 0x08400000 -> 0x08403FFFF Kernel Read Enable |
1 | 0x08400000 -> 0x08403FFFF User Write Enable |
0 | 0x08400000 -> 0x08403FFFF User Read Enable |
Physical Address | Size | R/W | Description |
---|---|---|---|
0xBC00000C | 4 | RW | Memory Protection 0x08600000 -> 0x087FFFFFF |
Bit(s) | Usage |
---|---|
31 | 0x087c0000 -> 0x087FFFFFF Kernel Write Enable |
30 | 0x087c0000 -> 0x087FFFFFF Kernel Read Enable |
29 | 0x087c0000 -> 0x087FFFFFF User Write Enable |
28 | 0x087c0000 -> 0x087FFFFFF User Read Enable |
27 | 0x08780000 -> 0x087BFFFFF Kernel Write Enable |
26 | 0x08780000 -> 0x087BFFFFF Kernel Read Enable |
25 | 0x08780000 -> 0x087BFFFFF User Write Enable |
24 | 0x08780000 -> 0x087BFFFFF User Read Enable |
23 | 0x08740000 -> 0x0877FFFFF Kernel Write Enable |
22 | 0x08740000 -> 0x0877FFFFF Kernel Read Enable |
21 | 0x08740000 -> 0x0877FFFFF User Write Enable |
20 | 0x08740000 -> 0x0877FFFFF User Read Enable |
19 | 0x08700000 -> 0x0873FFFFF Kernel Write Enable |
18 | 0x08700000 -> 0x0873FFFFF Kernel Read Enable |
17 | 0x08700000 -> 0x0873FFFFF User Write Enable |
16 | 0x08700000 -> 0x0873FFFFF User Read Enable |
15 | 0x086c0000 -> 0x086FFFFFF Kernel Write Enable |
14 | 0x086c0000 -> 0x086FFFFFF Kernel Read Enable |
13 | 0x086c0000 -> 0x086FFFFFF User Write Enable |
12 | 0x086c0000 -> 0x086FFFFFF User Read Enable |
11 | 0x08680000 -> 0x086BFFFFF Kernel Write Enable |
10 | 0x08680000 -> 0x086BFFFFF Kernel Read Enable |
9 | 0x08680000 -> 0x086BFFFFF User Write Enable |
8 | 0x08680000 -> 0x086BFFFFF User Read Enable |
7 | 0x08640000 -> 0x0867FFFFF Kernel Write Enable |
6 | 0x08640000 -> 0x0867FFFFF Kernel Read Enable |
5 | 0x08640000 -> 0x0867FFFFF User Write Enable |
4 | 0x08640000 -> 0x0867FFFFF User Read Enable |
3 | 0x08600000 -> 0x08603FFFF Kernel Write Enable |
2 | 0x08600000 -> 0x08603FFFF Kernel Read Enable |
1 | 0x08600000 -> 0x08603FFFF User Write Enable |
0 | 0x08600000 -> 0x08603FFFF User Read Enable |
Physical Address | Size | R/W | Description |
---|---|---|---|
0xBC000030 | 32 | RW | Hardware register user read/write enable (range unknown). Used to access profiler from an user. |
0xBC000034 | 32 | RW | Hardware register user read/write enable (range unknown) |
0xBC000038 | 32 | RW | Hardware register user read/write enable (range unknown) |
0xBC00003C | 32 | RW | Hardware register user read/write enable (range unknown) |
0xBC000040 | 32 | RW | Hardware register user read/write enable (range unknown) |
0xBC000044 | 32 | RW | Hardware register user read/write enable (range unknown) |
0xBC000048 | 32 | RW | Hardware register user read/write enable (range unknown) |
0xBC00004C | 32 | RW | Hardware register user read/write enable (range unknown) |
Granularity that these work on is not known. For each 1 bit an IO range is exposed to usermode for Read/Write. To find the usermode address, subtract 0x60000000 from the kernelmode one.
Physical Address | Size | R/W | Description |
---|---|---|---|
0xBC000050 | 32 | ? | Reads 0x07EFFFFF |
0xBC100000: System Controller
Address | Size | Read/write | Description |
---|---|---|---|
0xBC100000 | 4 | RW | NMI enable mask
Bits 0-15 = user NMI enable mask? Bits 16-31 = kernel NMI enable mask? |
0xBC100004 | 4 | RW | NMI flags (15 bits for NMI0 ~ NMI15) |
0xBC10000C | 4 | RW? | NMI12 control registers? |
0xBC100010 | 4 | RW? | NMI8 control registers? |
0xBC100014 | 4 | RW? | NMI9 control registers? |
0xBC100018 | 4 | RW? | NMI7 control registers? |
0xBC10001C | 4 | RW? | NMI6 control registers? |
0xBC100020 | 4 | RW? | NMI5 control registers? |
0xBC100024 | 4 | RW? | NMI4 control registers? |
0xBC100028 | 4 | RW? | NMI3 control registers? |
0xBC10002C | 4 | RW? | NMI2 control registers? |
0xBC100030 | 4 | RW? | NMI1 control registers? |
0xBC100034 | 4 | RW? | NMI0 control registers? |
0xBC10003C | 4 | RW | Unknown - used by sceSysreg_driver_0x4841B2D2, sceSysreg_driver_0x4E5C86AA, sceSysregDoTimerEvent |
0xBC100040 | 4 | RW | Bits 0-1 = RAM size (0=16MB, 1=32MB, 2=64MB, 3=128MB)
Bit 11 = ? (read-only) Bits 24-31 = tachyon version |
0xBC100044 | 4 | RW | SC/ME RPC interrupt. Writing 1 to bit 0 posts an interrupt to the opposite CPU |
0xBC100048 | 4 | RW | SC/ME semaphore. Appears to be a shared lock for both CPUs. Can be used as a spinlock |
0xBC10004C | 4 | RW | Reset enable (set bit to assert RESET, clear to clear RESET)
Bit 0 = Top Bit 1 = SC Bit 2 = ME Bit 3 = AW Bit 4 = VME Bit 5 = AVC Bit 6 = USB Bit 7 = ATA Bits 8-9 = Memstick Interface Bit 10 = KIRK Bit 12 = ATA HDD Bit 13 = USB Host Bits 14-15 = Memstick related? Bit 16 = ? |
0xBC100050 | 4 | RW | Bus clock enable (set a bit to enable clocking to the device, clear it to disable clocking)
Bit 0 = ME Bit 1 = AW RegA Bus Bit 2 = AW RegB Bus Bit 3 = AW Edram Bus Bit 4 = DMACPlus Bits 5-6 = DMAC Bit 7 = KIRK Bit 8 = ATA Bit 9 = USB Bits 10-11 = Memstick Interface Bit 12 = NAND (EMCDDR) Bit 13 = NAND (EMCSM) Bit 14 = APB (?) Bits 15-16 = Audio Bit 17 = ATA HDD Bit 18 = USB host Bits 19-20 = ? |
0xBC100054 | 4 | RW | Clock enable
Bit 0 = ATA Bit 1 = ATA HDD Bit 4 = ? Bit 7 = ? Bits 8-9 = Memstick interface Bit 12 = EMCDDR (NAND) Bit 16 = USB host Bits 20-21 = ? Bit 22 = ? |
0xBC100058 | 4 | RW | Clock enable
Bits 0-5 = SPI 0-5 Bits 6-11 = UART 0-5 Bits 12-15 = APB (?) 0-3 Bits 16-17 = Audio 0-1 Bit 22 = SIRCS (?) Bit 23 = GPIO Bit 24 = Audio clock out Bit 25 = ? |
0xBC10005C | 4 | RW | Clock select
Bits 0-1 = 1st Memorystick interface Bits 2-3 = 2nd Memorystick interface Bits 4-5 = ATA HDD Bits 6-7 = ATA |
0xBC100060 | 4 | RW | Clock select
Bits 0-2 = APB timer 0 Bits 4-6 = APB timer 1 Bits 8-10 = APB timer 2 Bits 12-14 = APB timer 3 Bit 18 = Audio clock out Bit 24 = ? |
0xBC100064 | 4 | RW | SPI clock select |
0xBC100068 | 4 | RW | 0xF - PLL get/set out select |
0xBC100074 | 4 | RW | Unknown |
0xBC100078 | 4 | RW | I/O enable (?) (TODO: verify indices)
Bit 0 = NAND Bit 1 = USB Bit 2 = ATA Bits 3-4 = Memstick Interface Bit 5 = LCDC Bit 6-7 = Audio Bit 8 = IIC Bit 9 = SIRCS Bit 10 = Audio? Bit 11 = KEY Bit 12 = PWM Bits 13-18 = UART Bits 19-24 = SPI |
0xBC10007C | 4 | RW | Either GPIO pin enable, or GPIO pin direction |
0xBC100080 | 4 | RW |
Bit 0 = USB connect status Bits 1-3 = USB interrupt Bits 4-7: MemoryStick0 connect intr Bits 8-11: MemoryStick1 connect intr |
0xBC100088 | 4 | RW | NMI13 control register? |
0xBC100090 | 4 | R? | Related to fuse Id |
0xBC100094 | 4 | R? | Related to fuse Id |
0xBC100098 | 4 | R? | Related to fuse config |
0xBC1000A0 | 4 | RW | NMI10 control register? |
0xBC1000A4 | 4 | RW | NMI11 control register? |
0xBC1000B0 | 4 | RW | Bits 0-2 = USB host intr |
0xBC1000E0 | 4 | RW | NMI14 control register? |
0xBC1000E4 | 4 | RW | NMI15 control register? |
0xBC1000E8 | 4 | RW | Unknown |
0xBC100100 | 4 | RW | Unknown |
0xBC200000: System Controller?
Address | Size | Read/write | Description |
---|---|---|---|
0xBC200000 | 4 | RW | Unknown (used by sceSysreg_driver) |
0xBC200004 | 4 | RW | Unknown (used by sceSysreg_driver) |
0xBC300000: Interrupt Manager
Address | Size | Read/write | Description |
---|---|---|---|
0xBC300000 | 4 | RW | Unknown |
0xBC300004 | 4 | RW | Flags for the first 32 interrupts (see below for the list of interrupts) |
0xBC300008 | 4 | RW | Mask for the first 32 interrupts (see below for the list of interrupts) |
0xBC300010 | 4 | RW | Unknown |
0xBC300014 | 4 | RW | Flags for the next 32 interrupts |
0xBC300018 | 4 | RW | Mask for the next 32 interrupts |
0xBC300020 | 4 | RW | Unknown |
0xBC300024 | 4 | RW | Flags for other interrupts? |
0xBC300028 | 4 | RW | Mask for other interrupts? |
Interrupt ID | Description |
---|---|
0 | All UARTs |
1 | All SPIs |
2 | All timer expirations |
3 | All USBs |
4 | GPIO |
5 | ATA/ATAPI |
6 | UMD Manager |
7 | Memstick (MSCM0) |
8 | WLAN |
9 | MG |
10 | AUDIO1 |
11 | AUDIO2 |
12 | I2C |
13 | KEY |
14 | IrDA |
15 | Systimer 0 |
16 | Systimer 1 |
17 | Systimer 2 |
18 | Systimer 3 |
19 | Thread0? |
20 | NAND |
21 | DMAC+ |
22 | DMA0 |
23 | DMA1 |
24 | MEMLMD? |
25 | GE |
26 | USB_MAIN |
30 | Display VSync |
31 | MediaEngine |
32 | UART1 |
33 | UART2 |
34 | UART3 |
35 | UART4 |
36 | HP Remote |
37 | UART6 |
40 | SPI1 |
41 | SPI2 |
42 | SPI3 |
43 | SPI4 |
44 | SPI5 |
45 | SPI6 |
48 | TIM1_PERI |
49 | TIM2_PERI |
50 | TIM3_PERI |
51 | TIM4_PERI |
56 | USB Resume |
57 | USB Ready |
58 | USB Connect |
59 | USB Disconnect |
60 | Memstick Insert (MSCM1) |
61 | Memstick Insert (MSCM1) |
62 | WLAN |
63 | WLAN |
64 | SOFT1 |
65 | SOFT2 |
66 | CPUTIMER |
0xBC400000: Profiler
Address | Size | R/W | Description |
---|---|---|---|
0xBC400000 | 4 | RW | Profiler enable (bit 0 = enabled status) |
0xBC400004 | 4 | RW | System clock cycles |
0xBC400008 | 4 | RW | CPU clock cycles |
0xBC40000C | 4 | RW | Total stalled cycles |
0xBC400010 | 4 | RW | Internal stalled cycles |
0xBC400014 | 4 | RW | Memory stalled cycles |
0xBC400018 | 4 | RW | Coprocessor stalled cycles |
0xBC40001C | 4 | RW | VFPU stalled cycles |
0xBC400020 | 4 | RW | Sleep cycles |
0xBC400024 | 4 | RW | Bus access cycles |
0xBC400028 | 4 | RW | Uncached load count |
0xBC40002C | 4 | RW | Uncached store count |
0xBC400030 | 4 | RW | Cached load count |
0xBC400034 | 4 | RW | Cached store count |
0xBC400038 | 4 | RW | I-cache miss count |
0xBC40003C | 4 | RW | D-cache miss count |
0xBC400040 | 4 | RW | D-cache writeback count |
0xBC400044 | 4 | RW | Coprocessor 0 instruction count |
0xBC400048 | 4 | RW | FPU instruction count |
0xBC40004C | 4 | RW | VFPU instruction count |
0xBC400050 | 4 | RW | Local bus cycles |
0xBC500000: Hardware Timer
Physical Address | Size | R/W | Description |
---|---|---|---|
0xBC500000 | 4 | RW | Timer data for hardware timer 0. Bits 31-22: the current timer mode. Bits 21-0: The system time when the timer was stopped. It is overwritten every time the timer is stopped. |
0xBC500004 | 4 | R? | The base time of the hardware timer 0 (assumed) |
0xBC500008 | 4 | RW | The numerator of the timer's prescale |
0xBC50000C | 4 | RW | The denominator of the timer's prescale |
0xBC500010 | 4 | RW | Same as above, for hardware timer 1 |
0xBC500014 | 4 | R? | Same as above, for hardware timer 1 |
0xBC500018 | 4 | RW | Same as above, for hardware timer 1 |
0xBC50001C | 4 | RW | Same as above, for hardware timer 1 |
0xBC500020 | 4 | RW | Same as above, for hardware timer 2 |
0xBC500024 | 4 | R? | Same as above, for hardware timer 2 |
0xBC500028 | 4 | RW | Same as above, for hardware timer 2 |
0xBC50002C | 4 | RW | Same as above, for hardware timer 2 |
0xBC500030 | 4 | RW | Same as above, for hardware timer 3 |
0xBC500034 | 4 | R? | Same as above, for hardware timer 3 |
0xBC500038 | 4 | RW | Same as above, for hardware timer 3 |
0xBC50003C | 4 | RW | Same as above, for hardware timer 3 |
0xBC5003D0 | 4 | RW | Same as 0xBC500000, but with the current PSP's system time value. A timer's current count is computed by subtracting the timer's base time (the init time point) from this value. |
0xBC5003E0 | 4 | RW | Same as above, for hardware timer 1 |
0xBC5003F0 | 4 | RW | Same as above, for hardware timer 2 |
0xBC500400 | 4 | RW | Same as above, for hardware timer 3 |
0xBC600000: System time
Physical Address | Size | R/W | Description |
---|---|---|---|
0xBC600000 | 32 | RW | System time in microseconds. Wraps around every 1.1 hours? |
0xBC600004 | 32 | RW | Alarm time, raises interrupt (19?) when system time hits this number |
0xBC600008 | 32 | RW | Unknown, typically 0x30 but can be written |
0xBC60000C | 32 | RW | Unknown, typically 1 but can be written. (Writing 0 caused a hang, maybe disables timer incrementing?) |
0xBC600010 | 32 | RW | Unknown, typically 0 |
0xBC700000: ?
0xBC800000: DMACPlus
DMACPlus general registers
Address | Size | Read/write | Description |
---|---|---|---|
0xBC800004 | 4 | RW | Pending "operation success" interrupts |
0xBC800008 | 4 | RW | Clear "operation success" interrupts |
0xBC80000C | 4 | RW | Pending "operation error" interrupts |
0xBC800010 | 4 | RW | Clear "operation error" interrupts |
0xBC800014 | 4 | RW | Enable "operation success" interrupts |
0xBC800018 | 4 | RW | Enable "operation error" interrupts |
Interrupt bits
Bit | Interrupt |
---|---|
0 | DmacplusLcdc |
1 | AVC |
2 | Sc2Me |
3 | Me2Sc |
4 | Sc128 |
Framebuffer scanout registers (DmacplusLcdc)
Address | Size | Read/write | Description |
---|---|---|---|
0xBC800100 | 4 | RW | Framebuffer address (bits[28:0]) |
0xBC800104 | 4 | RW | Framebuffer pixelformat (0 = RGBA8888, 1 = RGB565, 2 = RGBA5551, 3 = RGBA4444) |
0xBC800108 | 4 | RW | Framebuffer width |
0xBC80010C | 4 | RW | Framebuffer stride |
0xBC800110 | 4 | RW | Framebuffer scanout configuration: Bit[0] = Enable framebuffer scanout to LCD controller, Bits[31:29] = ?? |
CSC registers
Address | Size | Read/write | Description |
---|---|---|---|
0xBC800120 | 4 | RW | CSC source buffer pYBuffer address |
0xBC800124 | 4 | RW | CSC source buffer pYBuffer2 address |
0xBC800128 | 4 | RW | CSC source buffer pCrBuffer address |
0xBC80012C | 4 | RW | CSC source buffer pCbBuffer address |
0xBC800130 | 4 | RW | CSC source buffer pCrBuffer2 address |
0xBC800134 | 4 | RW | CSC source buffer pCbBuffer2 address |
0xBC800138 | 4 | RW | CSC source buffer height |
0xBC80013C | 4 | RW | CSC source buffer width |
0xBC800140 | 4 | RW | Buffer size: Bits[22:16] = height/16, Bits[13:8] = width/16, Bit[2] = unk, Bit[1] = unk, Bit[0] = use VME or AVC (AVC = 0, VME = 1) |
0xBC800144 | 4 | RW | CSC destination RGB buffer address |
0xBC800148 | 4 | RW | CSC destination RGB2 buffer address |
0xBC80014C | 4 | RW | CSC parameters: Bit[0] = has RGB2 buffer, Bits[7:1] = pixelformat, Bits[31:8] = buffer stride |
0xBC800150 | 4 | RW | First row (3 values) of the 3x3 CSC matrix. Each value is 10 bits long, Q3.7 fixed-point format, starting at bit i * 16 of the register. |
0xBC800154 | 4 | RW | Second row (3 values) of the 3x3 CSC matrix. Each value is 10 bits long, Q3.7 fixed-point format, starting at bit i * 16 of the register. |
0xBC800158 | 4 | RW | Third row (3 values) of the 3x3 CSC matrix. Each value is 10 bits long, Q3.7 fixed-point format, starting at bit i * 16 of the register. |
0xBC80015C | 4 | RW | Other parameters of CSC matrix (post matrix multiplication addition coefficients, etc). Bits[7:0] = footroom, Bit[8] = unk. |
0xBC800160 | 4 | RW | Start CSC? 0xD is written here. |
CSC source buffer valid ranges
Note: It seems the CSC source buffer address can only be inside one of the following ranges in the following table (otherwise AVC "operation error" interrupt is triggered). The destination buffer doesn't have such limitations.
Start | End | Notes |
---|---|---|
0x00000000 | 0x00400000 | |
0x04000000 | 0x04200000 | VRAM? always read as 0s |
0x08300000 | 0x0C000000 |
Unknown
Address | Size | Read/write | Description |
---|---|---|---|
0xBC800180 | ? | ? | Unknown |
0xBCC00000: VME Control
These can only be accessed from the ME CPU.
Address | Size | Read/write | Description |
---|---|---|---|
0xBCC00010 | 4 | RW | VME reset: writing anything here causes the VME to reset; it reads 0xFFFFFFFF while resetting, and 0 when reset is complete |
0xBCC00030 | 4 | W? | Unknown, 8 is stored there when the ME boots |
0xBCC00040 | 4 | W? | Unknown, 2 is stored there when the ME boots |
0xBCC00070 | 4 | W? | Unknown, 1 is stored there when the ME boots |
0xBD000000: DDR?
0xBD100000: NAND Flash
Address | Size | Read/write | Description |
---|---|---|---|
0xBD101000 | 4 | R | NAND control
Bit 16 = read ECC (0 = don't calculate, 1 = calculate) Bit 17 = write ECC (0 = don't calculate, 1 = calculate) |
0xBD101004 | 4 | R | NAND status
Bit 0 = status (0 = busy, 1 = ready) Bit 7 = write protection (1 = write protected) |
0xBD101008 | 4 | W | NAND command
0x00/0x01 = read (1?) 0x50 = read (2?) 0x90 = read ID 0xFF = reset 0x80, or 0x10 at 2nd cycle = page program 0x00, or 0x8A at 2nd cycle = copy-back program 0x60, or 0xD0 at 2nd cycle = block erase 0x70 = read status |
0xBD10100C | 4 | W | NAND address.
Bits 10-26: page to access. Possibly just LBA >> 1? |
0xBD101014 | 4 | W | NAND reset? (bit 0) |
0xBD101020 | 4 | W | NAND DMA address
Bits 10-26: page to access during DMA. Possibly just LBA >> 1? |
0xBD101024 | 4 | RW | NAND DMA control
Bit 0 = DMA transfer progress (0 = stopped, 1 = running) Bit 1 = transfer direction (0 = NAND -> MEM, 1 = MEM -> NAND) Bit 8 = page data transfer enabled Bit 9 = spare data transfer enabled |
0xBD101028 | 4 | R | NAND DMA status |
0xBD101038 | 4 | RW | NAND DMA intr? |
0xBD101200 | 4 | RW | NAND resume? (0x0B040205 to resume) |
0xBD101300 | 4 | RW | NAND serial data |
0xBD200000: MemoryStick
0xBD300000: WLAN
0xBD400000: Graphics Engine
Physical Address | Size | R/W | Description |
---|---|---|---|
0xBD400000 | 4 | RW | RW bit 1: set to 1 to reset, wait until bit is 0 to know the GE has been reset |
0xBD400004 | 4 | RW? | Unknown (accessible through sceGeSet/GetReg() and passed to the interrupt handlers but unused) |
0xBD400008 | 4 | R | RO bits 0x0000FFFF: shifted left by 10, gives the EDRAM hardware size (sceGeEdramGetHwSize()) (only used for tachyon < 0x00500000) |
0xBD400100 | 4 | RW | RW bit 0x001: 0 = stopped, 1 = running
R bit 0x002: 0 = branching condition true, 1 = false R bit 0x100: 1 = is at depth 1 (or 2) of calls R bit 0x200: 1 = is at depth 2 of calls |
0xBD400104 | 4 | RW? | Unknown (accessible through sceGeSet/GetReg() but unused) |
0xBD400108 | 4 | RW | Address of the display list currently being run |
0xBD40010C | 4 | RW | Stall address of the display list (0 = no stall address) |
0xBD400110 | 4 | RW | First return address (after the first CALL command) |
0xBD400114 | 4 | RW | Second return address (after the second CALL command) |
0xBD400118 | 4 | RW | Address of vertices (for bezier etc) |
0xBD40011C | 4 | RW | Address of indices (for bezier etc) |
0xBD400120 | 4 | RW | Address of the origin (set by ORIGIN, destination address for JUMP/BJUMP/CALL after adding BASE and the address specified in the command) |
0xBD400124 | 4 | RW | Same as above, for the first call |
0xBD400128 | 4 | RW | Same as above, for the second call |
0xBD400200 | 4 | RW | Bit 1 set by sceGeSetGeometryClock(), exact usage unknown |
0xBD400300 | 4 | RW | Unknown (accessible through sceGeSet/GetReg() but unused) |
0xBD400304 | 4 | R | Current interrupt status? |
0xBD400308 | 4 | RW | Currently accepted interrupts? (1 = SIGNAL, 2 = END, 4 = FINISH, 8 = ERROR) |
0xBD40030C | 4 | W? | Set to the value of 0xBD400308 on init & reset |
0xBD400310 | 4 | W? | Set current interrupt status? Set to the value of 0xBD400308 on init & reset |
0xBD400400 | 4 | RW | Set to 4 when the used edram size is 0x00200000 and 2 when it's 0x00400000 (!) |
0xBD400800 | 1024 | R | Each type a command is executed by the GE, its value, including arguments, is saved here (4 bytes per command) |
0xBD400C00 | 384 | R | BONE matrices |
0xBD400D80 | 48 | R | WORLD matrices |
0xBD400DB0 | 48 | R | VIEW matrices |
0xBD400DE0 | 48 | R | PROJ matrices |
0xBD400E20 | 48 | R | TGEN matrices |
0xBD400E50 | 48 | R | COUNT matrices (probably) |
0xBD500000: Graphics Engine EDRAM
Address | Size | Read/write | Description |
---|---|---|---|
0xBD500000 | 4 | RW | Unknown, bits 0x00F00000 set by sceGeEdramSetRefreshParam's 4th argument |
0xBD500010 | 4 | RW | Set to 2 before reset and 0 after reset is done, bit 1 seems to be initialization (used by sceGeEdramInit()) |
0xBD500020 | 4 | RW | Set to 0x6C4 by default and bits 0x007FFFFF set by sceGeEdramSetRefreshParam's second argument |
0xBD500030 | 4 | RW | Bits 0x000003FF set by sceGeEdramSetRefreshParam's third argument |
0xBD500040 | 4 | RW | Set to 1 in sceGeEdramInit(), and to 3 if sceGeEdramSetRefreshParam's first argument (mode) is 1 and the bit 2 isn't set |
0xBD500050 | 4 | RW | Unknown, accessible through sceGeSetReg/GetReg() |
0xBD500060 | 4 | RW | Unknown, accessible through sceGeSetReg/GetReg() |
0xBD500070 | 4 | RW | Bit 1: disable address translation |
0xBD500080 | 4 | RW | The address translation value |
0xBD500090 | 4 | RW | Unknown, set to 3 in sceGeEdramInit(), accessible through sceGeSetReg/GetReg() |
0xBD5000A0 | 4 | RW | Unknown, accessible through sceGeSetReg/GetReg() |
0xBD600000: ATA/UMD
0xBD700000: ATA/UMD
0xBD800000: USB
0xBDE00000: KIRK
Address | Size | Read/write | Description |
---|---|---|---|
0xBDE00000 | 4 | R | KIRK signature 'KIRK' (or 1?) |
0xBDE00004 | 4 | R | KIRK version '0010' (or 1?) |
0xBDE00008 | 4 | RW | Set to 1 on error by the command subroutine |
0xBDE0000C | 4 | RW | Set to 1 to start processing |
0xBDE00010 | 4 | RW | KIRK command
0x01 = Private decrypt 0x02 = Encrypt (type2) 0x03 = Decrypt (type2) 0x04 = Encrypt (type3) (IV = 0) 0x05 = Encrypt (type3) (IV = Fuse) 0x06 = Encrypt (type3) (IV = User) 0x07 = Decrypt (type3) (IV = 0) 0x08 = Decrypt (type3) (IV = Fuse) 0x09 = Decrypt (type3) (IV = User) 0x0A = Private Signature Check 0x0B = SHA-1 Hash 0x0C = ECDSA Key Generate 0x0D = ECDSA Point Multiply 0x0E = Pseudo-random Number Generator 0x0F = PRNG Seed? Init? 0x10 = ECDSA Sign 0x11 = ECDSA Signature Check |
0xBDE00014 | 4 | RW | Result of the command |
0xBDE00018 | 4 | RW | Unknown |
0xBDE0001C | 4 | RW | KIRK status
Bit 0 = phase finish Bit 1 = phase error? Bit 4 = phase 2 needed Bit 5 = ? (phase 1 error maybe?) This should be used for checking processing status, and will notify when the processing has finished. All bits are 0 while execution is still in progress. If the command has two phases, Phase 2 Needed will be set when Phase Finish gets set. Bit1 and bit5 are not well known, but it seems that bit1 is Error for Phase 1, and Success for Phase 2? Bit5 is only checked for Phase 1, and leads to the same error codepath as bit1. |
0xBDE00020 | 4 | RW | Unknown |
0xBDE00024 | 4 | RW | Unknown |
0xBDE00028 | 4 | RW | Set to the value of 0xBDE0001C at the end of the command subroutine |
0xBDE0002C | 4 | RW | KIRK source buffer (physical address) |
0xBDE00030 | 4 | RW | KIRK destination buffer (physical address) |
0xBDE0004C | 4 | RW | Unknown |
0xBDE00050 | 4 | RW | Unknown |
0xBDF00000: UMD?
0xBE000000: Audio
0xBE100000: MagicGate hardware for memory stick?
0xBE140000: LCDC
Address | Size | Read/write | Description |
---|---|---|---|
0xBE140000 | 4 | RW | First LCDC controller enable
Bits 0-1 = 3 to enable first LCDC controller (tachyon version < 0x800000; otherwise it's set to 0) |
0xBE140004 | 4 | RW | Synchronization difference: (xsync / zoom) - ysync |
0xBE140008 | 4 | RW | Unknown (fourth argument of sceLcdcCheckMode and sceLcdcSetMode) |
0xBE140010 | 4 | RW | X back porch |
0xBE140014 | 4 | RW | X sync width |
0xBE140018 | 4 | RW | X front porch |
0xBE14001C | 4 | RW | X resolution |
0xBE140020 | 4 | RW | Y back porch |
0xBE140024 | 4 | RW | Y sync width |
0xBE140028 | 4 | RW | Y front porch |
0xBE14002C | 4 | RW | Y resolution |
0xBE140030 | 4 | R | HPC (?), returned by sceLcdcReadHPC() |
0xBE140034 | 4 | R | VPC (?), returned by sceLcdcReadVPC() |
0xBE140040 | 4 | RW | Y shift (between hardware & software resolution) |
0xBE140044 | 4 | RW | X shift (between hardware & software resolution) |
0xBE140048 | 4 | RW | Scaled X resolution |
0xBE14004C | 4 | RW | Scaled Y resolution (same as the physical Y resolution) |
0xBE140050 | 4 | RW | Unknown, set to 1, maybe used by sceLcdcReadUnderflow (to be verified) |
0xBE140070 | 4 | W | Set to 1 when running sceLcdcResume() or sceLcdcInit() on tachyon version >= 0x5000000 |
The exact same registers are at 0xBE1401.., these ones being used for tachyon version >= 0x8000000 (PSP Go?).
These registers are only set on tachyo version >= 0x8000000:
Address | Size | Read/write | Description |
---|---|---|---|
0xBE140180 | 4 | RW | Always set to 1 when 0xBE140184 - 0xBE140198 are used |
0xBE140184 | 4 | RW | Scaled X resolution (read instead of the (real) X resolution above when enabled) |
0xBE140188 | 4 | RW | Y resolution (read instead of the (real) Y resolution above when enabled) |
0xBE14018C | 4 | RW | Unknown (0x580 - 0x678) |
0xBE140190 | 4 | RW | Unknown (0x4C4 - 0x71C) |
0xBE140194 | 4 | RW | Unknown (0xAFC - 0xCEC) |
0xBE140198 | 4 | RW | Unknown (0x910 - 0xE38) |
0xBE140200 | 4 | W | Set to 1 on initialization |
0xBE200000: I2c
0xBE240000: GPIO
Address | Size | Read/write | Description |
---|---|---|---|
0xBE240000 | 4 | RW | Unknown |
0xBE240004 | 4 | R | GPIO read pin (1 bit = 1 pin) |
0xBE240008 | 4 | W | GPIO set pin (1 bit = 1 pin) |
0xBE24000C | 4 | W | GPIO clear pin (1 bit = 1 pin) |
0xBE240010 | 4 | ? | Unknown |
0xBE240014 | 4 | ? | Unknown |
0xBE240018 | 4 | ? | Unknown |
0xBE24001C | 4 | ? | Unknown |
0xBE240020 | 4 | ? | Unknown |
0xBE240030 | 4 | ? | Unknown |
0xBE240040 | 4 | ? | Unknown |
0xBE240048 | 4 | ? | Unknown |
0xBE300000: Power management?
0xBE400000: UART 1-4
0xBE500000: UART 5-8
0xBE600000: ?
0xBE700000: Display
0xBFC00000: MIPS Reset Vector
0xBFF00000: NAND DMA buffer
Address | Size | Read/write | Description |
---|---|---|---|
0xBFF00000 | 512 | RW | NAND DMA data buffer. These 512 bytes contain the page data to be transferred to/from the NAND during DMA. This does not include spare nor ECC information |
0xBFF00800 | 4 | RW | Calculated ECC for DMA data |
0xBFF00900 | 16 | RW | Spare data to be transferred from/to the NAND during DMA. This does not include spare nor ECC information |