This repository has been archived on 2022-05-31. You can view files and clone it, but cannot push or open issues or pull requests.
Luma3DS-3GX/patches/reboot.s

126 lines
3.0 KiB
ArmAsm
Raw Normal View History

.arm.little
2016-02-08 03:37:03 +01:00
payload_addr equ 0x23F00000 ; Brahma payload address.
payload_maxsize equ 0x100000 ; Maximum size for the payload (maximum that CakeBrah supports).
2016-02-08 03:37:03 +01:00
.create "build/reboot.bin", 0
2016-02-08 03:37:03 +01:00
.arm
2016-08-27 18:10:51 +02:00
; Interesting registers and locations to keep in mind, set just before this code is ran:
; - r1: FIRM path in exefs.
2016-08-28 02:38:30 +02:00
; - r7: pointer to file object
2016-08-27 18:10:51 +02:00
; - *r7: vtable
; - *(vtable + 0x28): fread function
2016-08-28 02:38:30 +02:00
; - *(r7 + 8): file handle
2016-08-27 18:10:51 +02:00
mov r8, r1
pxi_wait_recv:
ldr r2, =0x44846
ldr r0, =0x10008000
readPxiLoop1:
ldrh r1, [r0, #4]
lsls r1, #0x17
bmi readPxiLoop1
ldr r0, [r0, #0xC]
cmp r0, r2
bne pxi_wait_recv
adr r1, sd_fname
mov r4, #0
open_payload:
; Open file
cmp r4, #2 ; Panic if both payloads don't exist
beq svcBreak
add r0, r7, #8
mov r2, #1
ldr r6, [fopen]
orr r6, 1
blx r6
cmp r0, #0
adrne r1, nand_fname
addne r4, #1
bne open_payload
; Read file
mov r0, r7
adr r1, bytes_read
ldr r2, =payload_addr
mov r3, payload_maxsize
ldr r6, [r7]
ldr r6, [r6, #0x28]
blx r6
; Copy the low TID (in UTF-16) of the wanted firm to the 5th byte of the payload
2016-08-27 18:10:51 +02:00
add r0, r8, 0x1A
add r1, r0, #0x10
ldr r2, =payload_addr + 4
copy_TID_low:
ldrh r3, [r0], #2
strh r3, [r2], #2
cmp r0, r1
blo copy_TID_low
2016-02-08 03:37:03 +01:00
; Set kernel state
mov r0, #0
mov r1, #0
mov r2, #0
mov r3, #0
swi 0x7C
goto_reboot:
; Jump to reboot code
ldr r0, =(kernelcode_start - goto_reboot - 12)
2016-08-27 18:10:51 +02:00
add r0, pc ; pc is two instructions ahead of the instruction being executed (12 = 2*4 + 4)
swi 0x7B
die:
b die
svcBreak:
swi 0x3C
b die
bytes_read: .word 0
fopen: .ascii "OPEN"
2016-02-08 03:37:03 +01:00
.pool
sd_fname: .dcw "sdmc:/arm9loaderhax.bin"
.word 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
.pool
nand_fname: .dcw "nand:/arm9loaderhax.bin"
.word 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
.align 4
kernelcode_start:
2016-07-01 20:27:28 +02:00
; Disable MPU
ldr r0, =0x42078 ; alt vector select, enable itcm
mcr p15, 0, r0, c1, c0, 0
2016-07-01 20:27:28 +02:00
; Clean and flush data cache
mov r1, #0 ; segment counter
outer_loop:
mov r0, #0 ; line counter
inner_loop:
orr r2, r1, r0 ; generate segment and line address
mcr p15, 0, r2, c7, c14, 2 ; clean and flush the line
add r0, #0x20 ; increment to next line
cmp r0, #0x400
bne inner_loop
add r1, #0x40000000
cmp r1, #0
bne outer_loop
mcr p15, 0, r1, c7, c10, 4 ; drain write buffer
; Flush instruction cache
mcr p15, 0, r1, c7, c5, 0
; Jump to payload
ldr r0, =payload_addr
bx r0
.pool
2016-08-28 13:49:15 +02:00
.close