summaryrefslogtreecommitdiff
path: root/asm/entry.s
diff options
context:
space:
mode:
authorProjectRevoTPP <projectrevotpp@hotmail.com>2020-04-15 11:57:58 -0400
committerProjectRevoTPP <projectrevotpp@hotmail.com>2020-04-15 11:57:58 -0400
commit5343a230feb59f4de659e90c325f5417f65b823c (patch)
tree05dc2db9d693bdc19daab7c8fc0d444468a41cc1 /asm/entry.s
parent2b7b8d7174a2ea6f84db3b5917b0bf068213a85e (diff)
parentf9b7d7411b74e29e048ea7d48cf6d8302e50d2d4 (diff)
merge
Diffstat (limited to 'asm/entry.s')
-rw-r--r--asm/entry.s259
1 files changed, 160 insertions, 99 deletions
diff --git a/asm/entry.s b/asm/entry.s
index f0d4adda..48263edf 100644
--- a/asm/entry.s
+++ b/asm/entry.s
@@ -3,15 +3,15 @@
.text
- arm_func_start Main
-Main: ; 0x02000800
- mov r12, #0x4000000
- str r12, [r12, #0x208]
+ arm_func_start Entry
+Entry: ; 0x02000800
+ mov ip, #0x4000000
+ str ip, [ip, #0x208]
_02000808:
- ldrh r0, [r12, #0x6]
- cmp r0, #0x0
+ ldrh r0, [ip, #6]
+ cmp r0, #0
bne _02000808
- bl sub_02000A78
+ bl init_cp15
mov r0, #0x13
msr cpsr_c, r0
ldr r0, _02000918 ; =0x027E0000
@@ -22,175 +22,236 @@ _02000808:
ldr r0, _02000918 ; =0x027E0000
add r0, r0, #0x3fc0
sub r0, r0, #0x40
- sub sp, r0, #0x4
- tst sp, #0x4
- subeq sp, sp, #0x4
+ sub sp, r0, #4
+ tst sp, #4
+ subeq sp, sp, #4
ldr r1, _0200091C ; =0x00000400
sub r1, r0, r1
mov r0, #0x1f
msr cpsr_fsxc, r0
- sub sp, r1, #0x4
- mov r0, #0x0
+ sub sp, r1, #4
+ mov r0, #0
ldr r1, _02000918 ; =0x027E0000
mov r2, #0x4000
- bl _0200093C
-_02000870:
- .byte 0x00, 0x00, 0xA0, 0xE3, 0xA4, 0x10, 0x9F, 0xE5, 0x01, 0x2B, 0xA0, 0xE3, 0x2E, 0x00, 0x00, 0xEB
- .byte 0x02, 0x0C, 0xA0, 0xE3, 0x98, 0x10, 0x9F, 0xE5, 0x01, 0x2B, 0xA0, 0xE3, 0x2A, 0x00, 0x00, 0xEB
- .byte 0x90, 0x10, 0x9F, 0xE5, 0x14, 0x00, 0x91, 0xE5, 0x2C, 0x00, 0x00, 0xEB, 0x56, 0x00, 0x00, 0xEB
- .byte 0x80, 0x00, 0x9F, 0xE5, 0x0C, 0x10, 0x90, 0xE5, 0x10, 0x20, 0x90, 0xE5, 0x01, 0x30, 0xA0, 0xE1
- .byte 0x00, 0x00, 0xA0, 0xE3, 0x02, 0x00, 0x51, 0xE1, 0x04, 0x00, 0x81, 0x34, 0xFC, 0xFF, 0xFF, 0x3A
- .byte 0x1F, 0x10, 0xC3, 0xE3, 0x9A, 0x0F, 0x07, 0xEE, 0x35, 0x1F, 0x07, 0xEE, 0x3E, 0x1F, 0x07, 0xEE
- .byte 0x20, 0x10, 0x81, 0xE2, 0x02, 0x00, 0x51, 0xE1, 0xF9, 0xFF, 0xFF, 0xBA, 0x48, 0x10, 0x9F, 0xE5
- .byte 0x00, 0x00, 0x81, 0xE5, 0x2C, 0x10, 0x9F, 0xE5, 0xFF, 0x1D, 0x81, 0xE2, 0x3C, 0x10, 0x81, 0xE2
- .byte 0x38, 0x00, 0x9F, 0xE5, 0x00, 0x00, 0x81, 0xE5, 0x33, 0xAF, 0x03, 0xEB, 0x98, 0x00, 0x00, 0xEB
- .byte 0x63, 0xAF, 0x03, 0xEB, 0x28, 0x10, 0x9F, 0xE5, 0x28, 0xE0, 0x9F, 0xE5, 0x04, 0x00, 0x1D, 0xE3
- .byte 0x04, 0xD0, 0x4D, 0x12, 0x11, 0xFF, 0x2F, 0xE1
+ bl INITi_CpuClear32
+ mov r0, #0
+ ldr r1, _02000920 ; =0x05000000
+ mov r2, #1024
+ bl INITi_CpuClear32
+ mov r0, #512
+ ldr r1, _02000924 ; =0x07000000
+ mov r2, #1024
+ bl INITi_CpuClear32
+ ldr r1, _02000928 ; =_02000B68
+ ldr r0, [r1, #20]
+ bl MIi_UncompressBackward
+ bl do_autoload
+ ldr r0, _02000928 ; =_02000B68
+ ldr r1, [r0, #12]
+ ldr r2, [r0, #16]
+ mov r3, r1
+ mov r0, #0
+_020008B4:
+ cmp r1, r2
+ strcc r0, [r1], #4
+ bcc _020008B4
+ bic r1, r3, #31
+_020008C4:
+ mcr p15, 0x0, r0, cr7, cr10, 4
+ mcr p15, 0x0, r1, cr7, cr5, 1
+ mcr p15, 0x0, r1, cr7, cr14, 1
+ add r1, r1, #32
+ cmp r1, r2
+ blt _020008C4
+ ldr r1, _0200092C ; =0x027FFF9C
+ str r0, [r1]
+ ldr r1, _02000918 ; =0x027E0000
+ add r1, r1, #16320
+ add r1, r1, #60
+ ldr r0, _02000930 ; =0x01FF8000
+ str r0, [r1]
+ bl sub_020EC5CC
+ bl sub_02000B64_dummy
+ bl sub_020EC694
+ ldr r1, _02000934 ; =0x02000C55
+ ldr lr, _02000938 ; =0xFFFF0000
+ tst sp, #4
+ subne sp, sp, #4
+ bx r1
_02000918: .word 0x027E0000
_0200091C: .word 0x00000400
-_02000920:
- .byte 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0x07, 0x68, 0x0B, 0x00, 0x02, 0x9C, 0xFF, 0x7F, 0x02
- .byte 0x00, 0x80, 0xFF, 0x01, 0x55, 0x0C, 0x00, 0x02, 0x00, 0x00, 0xFF, 0xFF
-_0200093C:
- add r12, r1, r2
+_02000920: .word 0x05000000
+_02000924: .word 0x07000000
+_02000928: .word _02000B68
+_0200092C: .word 0x027FFF9C
+_02000930: .word 0x01FF8000
+_02000934: .word NitroMain+1
+_02000938: .word 0xFFFF0000
+ arm_func_end Entry
+
+ arm_func_start INITi_CpuClear32
+INITi_CpuClear32:
+ add ip, r1, r2
_02000940:
- cmp r1, r12
+ cmp r1, ip
stmltia r1!, {r0}
blt _02000940
bx lr
+ arm_func_end INITi_CpuClear32
- arm_func_start sub_02000950
-sub_02000950: ; 0x02000950
- cmp r0, #0x0
+ arm_func_start MIi_UncompressBackward
+MIi_UncompressBackward:
+ cmp r0, #0
beq _020009F8
stmdb sp!, {r4-r7}
- ldmdb r0, {r1-r2}
+ ldmdb r0, {r1, r2}
add r2, r0, r2
- sub r3, r0, r1, lsr #0x18
- bic r1, r1, #0xff000000
+ sub r3, r0, r1, lsr #24
+ bic r1, r1, #-16777216
sub r1, r0, r1
mov r4, r2
_02000974:
cmp r3, r1
ble _020009D4
- ldrb r5, [r3, #-0x1]!
- mov r6, #0x8
+ ldrb r5, [r3, #-1]!
+ mov r6, #8
_02000984:
- subs r6, r6, #0x1
+ subs r6, r6, #1
blt _02000974
- tst r5, #0x80
+ tst r5, #128
bne _020009A0
- ldrb r0, [r3, #-0x1]!
- strb r0, [r2, #-0x1]!
+ ldrb r0, [r3, #-1]!
+ strb r0, [r2, #-1]!
b _020009C8
_020009A0:
- ldrb r12, [r3, #-0x1]!
- ldrb r7, [r3, #-0x1]!
- orr r7, r7, r12, lsl #0x8
- bic r7, r7, #0xf000
- add r7, r7, #0x2
- add r12, r12, #0x20
+ ldrb ip, [r3, #-1]!
+ ldrb r7, [r3, #-1]!
+ orr r7, r7, ip, lsl #8
+ bic r7, r7, #61440
+ add r7, r7, #2
+ add ip, ip, #32
_020009B8:
ldrb r0, [r2, r7]
- strb r0, [r2, #-0x1]!
- subs r12, r12, #0x10
+ strb r0, [r2, #-1]!
+ subs ip, ip, #16
bge _020009B8
_020009C8:
cmp r3, r1
mov r5, r5, lsl #0x1
bgt _02000984
_020009D4:
- mov r0, #0x0
- bic r3, r1, #0x1f
+ mov r0, #0
+ bic r3, r1, #31
_020009DC:
- mcr p15, 0x0, r0, c7, c10, 0x4
- mcr p15, 0x0, r3, c7, c5, 0x1
- mcr p15, 0x0, r3, c7, c14, 0x1
- add r3, r3, #0x20
+ mcr p15, 0x0, r0, cr7, cr10, 4
+ mcr p15, 0x0, r3, cr7, cr5, 1
+ mcr p15, 0x0, r3, cr7, cr14, 1
+ add r3, r3, #32
cmp r3, r4
blt _020009DC
ldmia sp!, {r4-r7}
_020009F8:
bx lr
-_020009FC:
- .byte 0x6C, 0x00, 0x9F, 0xE5
- .byte 0x00, 0x10, 0x90, 0xE5, 0x04, 0x20, 0x90, 0xE5, 0x08, 0x30, 0x90, 0xE5, 0x02, 0x00, 0x51, 0xE1
- .byte 0x15, 0x00, 0x00, 0x0A, 0x04, 0x50, 0x91, 0xE4, 0x04, 0x70, 0x91, 0xE4, 0x07, 0x60, 0x85, 0xE0
- .byte 0x05, 0x40, 0xA0, 0xE1, 0x06, 0x00, 0x54, 0xE1, 0x04, 0x70, 0x93, 0x44, 0x04, 0x70, 0x84, 0x44
- .byte 0xFB, 0xFF, 0xFF, 0x4A, 0x04, 0x70, 0x91, 0xE4, 0x07, 0x60, 0x84, 0xE0, 0x00, 0x70, 0xA0, 0xE3
- .byte 0x06, 0x00, 0x54, 0xE1, 0x04, 0x70, 0x84, 0x34, 0xFC, 0xFF, 0xFF, 0x3A, 0x1F, 0x40, 0xC5, 0xE3
- .byte 0x9A, 0x7F, 0x07, 0xEE, 0x35, 0x4F, 0x07, 0xEE, 0x3E, 0x4F, 0x07, 0xEE, 0x20, 0x40, 0x84, 0xE2
- .byte 0x06, 0x00, 0x54, 0xE1, 0xF9, 0xFF, 0xFF, 0xBA, 0xE7, 0xFF, 0xFF, 0xEA, 0x00, 0x00, 0x00, 0xEA
- .byte 0x68, 0x0B, 0x00, 0x02, 0x1E, 0xFF, 0x2F, 0xE1
+ arm_func_end MIi_UncompressBackward
+
+ arm_func_start do_autoload
+do_autoload:
+ ldr r0, =_02000B68
+ ldr r1, [r0]
+ ldr r2, [r0, #4]
+ ldr r3, [r0, #8]
+_02000A0C:
+ cmp r1, r2
+ beq _02000A6C
+ ldr r5, [r1], #4
+ ldr r7, [r1], #4
+ add r6, r5, r7
+ mov r4, r5
+_02000A24:
+ cmp r4, r6
+ ldrmi r7, [r3], #4
+ strmi r7, [r4], #4
+ bmi _02000A24
+ ldr r7, [r1], #4
+ add r6, r4, r7
+ mov r7, #0
+_02000A40:
+ cmp r4, r6
+ strcc r7, [r4], #4
+ bcc _02000A40
+ bic r4, r5, #31
+_02000A50:
+ mcr p15, 0x0, r7, cr7, cr10, 4
+ mcr p15, 0x0, r4, cr7, cr5, 1
+ mcr p15, 0x0, r4, cr7, cr14, 1
+ add r4, r4, #32
+ cmp r4, r6
+ blt _02000A50
+ b _02000A0C
+_02000A6C:
+ b _2000A74
+ .pool
+_2000A74:
+ bx lr
+ arm_func_end do_autoload
- arm_func_start sub_02000A78
-sub_02000A78: ; 0x02000A78
+ arm_func_start init_cp15
+init_cp15: ; 0x02000A78
mrc p15, 0x0, r0, c1, c0, 0x0
- ldr r1, _02000B30 ; =0x000F9005
+ ldr r1, =0x000F9005
bic r0, r0, r1
mcr p15, 0x0, r0, c1, c0, 0x0
- mov r0, #0x0
+ mov r0, #0
mcr p15, 0x0, r0, c7, c5, 0x0
mcr p15, 0x0, r0, c7, c6, 0x0
mcr p15, 0x0, r0, c7, c10, 0x4
- ldr r0, _02000B34 ; =0x04000033
+ ldr r0, =0x04000033
mcr p15, 0x0, r0, c6, c0, 0x0
- ldr r0, _02000B38 ; =0x0200002D
+ ldr r0, =0x0200002D
mcr p15, 0x0, r0, c6, c1, 0x0
- ldr r0, _02000B3C ; =0x027E0021
+ ldr r0, =0x027E0021
mcr p15, 0x0, r0, c6, c2, 0x0
- ldr r0, _02000B40 ; =0x08000035
+ ldr r0, =0x08000035
mcr p15, 0x0, r0, c6, c3, 0x0
- ldr r0, _02000B44 ; =0x027E0000
+ ldr r0, =0x027E0000
orr r0, r0, #0x1a
- orr r0, r0, #0x1
+ orr r0, r0, #1
mcr p15, 0x0, r0, c6, c4, 0x0
- ldr r0, _02000B48 ; =0x0100002F
+ ldr r0, =0x0100002F
mcr p15, 0x0, r0, c6, c5, 0x0
- ldr r0, _02000B4C ; =0xFFFF001D
+ ldr r0, =0xFFFF001D
mcr p15, 0x0, r0, c6, c6, 0x0
- ldr r0, _02000B50 ; =0x027FF017
+ ldr r0, =0x027FF017
mcr p15, 0x0, r0, c6, c7, 0x0
mov r0, #0x20
mcr p15, 0x0, r0, c9, c1, 0x1
- ldr r0, _02000B44 ; =0x027E0000
+ ldr r0, =0x027E0000
orr r0, r0, #0xa
mcr p15, 0x0, r0, c9, c1, 0x0
mov r0, #0x42
mcr p15, 0x0, r0, c2, c0, 0x1
mov r0, #0x42
mcr p15, 0x0, r0, c2, c0, 0x0
- mov r0, #0x2
+ mov r0, #2
mcr p15, 0x0, r0, c3, c0, 0x0
- ldr r0, _02000B54 ; =0x05100011
+ ldr r0, =0x05100011
mcr p15, 0x0, r0, c5, c0, 0x3
- ldr r0, _02000B58 ; =0x15111011
+ ldr r0, =0x15111011
mcr p15, 0x0, r0, c5, c0, 0x2
mrc p15, 0x0, r0, c1, c0, 0x0
- ldr r1, _02000B5C ; =0x0005707D
+ ldr r1, =0x0005707D
orr r0, r0, r1
mcr p15, 0x0, r0, c1, c0, 0x0
bx lr
.align 2, 0
-_02000B30: .word 0x000F9005
-_02000B34: .word 0x04000033
-_02000B38: .word 0x0200002D
-_02000B3C: .word 0x027E0021
-_02000B40: .word 0x08000035
-_02000B44: .word 0x027E0000
-_02000B48: .word 0x0100002F
-_02000B4C: .word 0xFFFF001D
-_02000B50: .word 0x027FF017
-_02000B54: .word 0x05100011
-_02000B58: .word 0x15111011
-_02000B5C: .word 0x0005707D
+ .pool
arm_func_start sub_02000B60_dummy
-sub_02000B60_dummy:
+sub_02000B60_dummy: ; 0x02000B60
bx lr
arm_func_start sub_02000B64_dummy
-sub_02000B64_dummy:
+sub_02000B64_dummy: ; 0x02000B64
bx lr
_02000B68: