2023-09-04 23:31:19 +02:00
|
|
|
#define IPL3_ENTRY 0xA4000040
|
|
|
|
#define REBOOT_ADDRESS 0xA4001000
|
|
|
|
#define STACK_ADDRESS 0xA4001FF0
|
|
|
|
|
2023-08-03 17:18:55 +02:00
|
|
|
|
2023-08-27 18:52:03 +02:00
|
|
|
.set noat
|
2023-08-03 17:18:55 +02:00
|
|
|
.section .text.reboot, "ax", %progbits
|
|
|
|
.type reboot, %object
|
|
|
|
reboot_start:
|
|
|
|
.global reboot_start
|
|
|
|
|
|
|
|
# NOTE: CIC x105 requirement
|
|
|
|
ipl2:
|
|
|
|
.set noreorder
|
|
|
|
lui $t5, 0xBFC0
|
|
|
|
1:
|
|
|
|
lw $t0, 0x7FC($t5)
|
|
|
|
addiu $t5, $t5, 0x7C0
|
|
|
|
andi $t0, $t0, 0x80
|
|
|
|
bnel $t0, $zero, 1b
|
|
|
|
lui $t5, 0xBFC0
|
|
|
|
lw $t0, 0x24($t5)
|
|
|
|
lui $t3, 0xB000
|
|
|
|
.set reorder
|
|
|
|
|
|
|
|
reboot_entry:
|
2023-09-04 23:31:19 +02:00
|
|
|
.set reboot, REBOOT_ADDRESS + (. - reboot_start)
|
|
|
|
.global reboot
|
|
|
|
|
|
|
|
li $sp, STACK_ADDRESS
|
2023-08-03 17:18:55 +02:00
|
|
|
|
2023-10-10 21:12:53 +02:00
|
|
|
detect_console_region:
|
|
|
|
li $t0, 1
|
|
|
|
beq $s4, $zero, pal_console
|
|
|
|
beq $s4, $t0, ntsc_console
|
|
|
|
b mpal_console
|
2023-08-27 18:52:03 +02:00
|
|
|
|
2023-10-10 21:12:53 +02:00
|
|
|
pal_console:
|
|
|
|
li $ra, 0xA4001554
|
|
|
|
b reset_registers
|
2023-08-03 17:18:55 +02:00
|
|
|
|
2023-10-10 21:12:53 +02:00
|
|
|
ntsc_console:
|
|
|
|
li $ra, 0xA4001550
|
|
|
|
b reset_registers
|
2023-08-20 22:03:14 +02:00
|
|
|
|
2023-10-10 21:12:53 +02:00
|
|
|
mpal_console:
|
|
|
|
li $ra, 0xA4001554
|
2023-09-04 23:31:19 +02:00
|
|
|
|
2023-10-10 21:12:53 +02:00
|
|
|
reset_registers:
|
2023-08-27 18:52:03 +02:00
|
|
|
move $at, $zero
|
|
|
|
move $v0, $zero
|
|
|
|
move $v1, $zero
|
|
|
|
move $a0, $zero
|
|
|
|
move $a1, $zero
|
|
|
|
move $a2, $zero
|
|
|
|
move $a3, $zero
|
|
|
|
move $t0, $zero
|
|
|
|
move $t1, $zero
|
|
|
|
move $t2, $zero
|
|
|
|
move $t4, $zero
|
|
|
|
move $t5, $zero
|
|
|
|
move $t6, $zero
|
|
|
|
move $t7, $zero
|
|
|
|
move $s0, $zero
|
|
|
|
move $s1, $zero
|
|
|
|
move $s2, $zero
|
|
|
|
move $t8, $zero
|
|
|
|
move $t9, $zero
|
|
|
|
move $k0, $zero
|
|
|
|
move $k1, $zero
|
|
|
|
move $gp, $zero
|
2023-10-10 21:12:53 +02:00
|
|
|
move $fp, $zero
|
2023-08-27 18:52:03 +02:00
|
|
|
|
2023-08-03 17:18:55 +02:00
|
|
|
run_ipl3:
|
|
|
|
li $t3, IPL3_ENTRY
|
|
|
|
jr $t3
|
|
|
|
|
2023-09-04 23:31:19 +02:00
|
|
|
.set reboot_size, (. - reboot_start)
|
2023-08-03 17:18:55 +02:00
|
|
|
.global reboot_size
|