diff options
author | ProjectRevoTPP <projectrevotpp@hotmail.com> | 2020-04-15 11:57:58 -0400 |
---|---|---|
committer | ProjectRevoTPP <projectrevotpp@hotmail.com> | 2020-04-15 11:57:58 -0400 |
commit | 5343a230feb59f4de659e90c325f5417f65b823c (patch) | |
tree | 05dc2db9d693bdc19daab7c8fc0d444468a41cc1 | |
parent | 2b7b8d7174a2ea6f84db3b5917b0bf068213a85e (diff) | |
parent | f9b7d7411b74e29e048ea7d48cf6d8302e50d2d4 (diff) |
merge
-rw-r--r-- | asm/arm7_rom.s | 6 | ||||
-rw-r--r-- | asm/entry.s | 259 | ||||
-rw-r--r-- | asm/filenametable.s | 5 | ||||
-rw-r--r-- | asm/gap1.s | 4 | ||||
-rw-r--r-- | asm/gap2.s | 4 | ||||
-rw-r--r-- | asm/main.s | 2 | ||||
-rw-r--r-- | asm/rom.s | 5 | ||||
-rw-r--r-- | asm/rom3.s | 4 | ||||
-rw-r--r-- | asm/rom_header.s | 147 | ||||
-rw-r--r-- | global.inc | 3 | ||||
-rw-r--r-- | ld_script.txt | 27 | ||||
-rw-r--r-- | pokediamond.lcf | 20 |
12 files changed, 323 insertions, 163 deletions
diff --git a/asm/arm7_rom.s b/asm/arm7_rom.s new file mode 100644 index 00000000..1a02882d --- /dev/null +++ b/asm/arm7_rom.s @@ -0,0 +1,6 @@ +/* arm7_rom.s TODO: Disassemble */ + + .section .text + .global Entry_ARM7 +Entry_ARM7: + .incbin "baserom.nds", 0x30D000, 0x2931C 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: diff --git a/asm/filenametable.s b/asm/filenametable.s new file mode 100644 index 00000000..4e793e76 --- /dev/null +++ b/asm/filenametable.s @@ -0,0 +1,5 @@ + .section .text + + .global FileNameTable +FileNameTable: + .incbin "baserom.nds", 0x336400, 0x3cc9c00 ; 0x157F diff --git a/asm/gap1.s b/asm/gap1.s new file mode 100644 index 00000000..b71ccde3 --- /dev/null +++ b/asm/gap1.s @@ -0,0 +1,4 @@ + .section .text + .rept 0x1E0 + .byte 0xFF + .endr diff --git a/asm/gap2.s b/asm/gap2.s new file mode 100644 index 00000000..4af77b6d --- /dev/null +++ b/asm/gap2.s @@ -0,0 +1,4 @@ + .text + .rept 0x336400-0x33631c + .byte 255 + .endr @@ -1,7 +1,7 @@ .include "asm/macros.inc" .include "global.inc" - .text + .section .text thumb_func_start NitroMain NitroMain: ; 0x02000C54 diff --git a/asm/rom.s b/asm/rom.s deleted file mode 100644 index 0025dec1..00000000 --- a/asm/rom.s +++ /dev/null @@ -1,5 +0,0 @@ -/* rom.s TODO: Disassemble */ - -.section .text - -.incbin "baserom.nds", 0x4C54, 0x1A0 @@ -1,5 +1,5 @@ /* rom3.s TODO: Disassemble */ -.section .text + .section .text -.incbin "baserom.nds", 0x10B724, 0x3EF48DC + .incbin "baserom.nds", 0x10B724, 0x2016FC diff --git a/asm/rom_header.s b/asm/rom_header.s index d4657a48..d28ecb4f 100644 --- a/asm/rom_header.s +++ b/asm/rom_header.s @@ -1,113 +1,150 @@ /* ROM HEADER for Pokemon Diamond (US) */ -.section .text + .section .text -.balign 4 + .balign 4 + .global GameTitle GameTitle: -.asciz "POKEMON D" + .asciz "POKEMON D" -.balign 4 + .balign 4 + .global GameCode GameCode: -.ascii "ADAE" + .ascii "ADAE" + .global MakerCode MakerCode: -.ascii "01" + .ascii "01" + .global UnitCode UnitCode: -.byte 0 + .byte 0 + .global DeviceType DeviceType: -.byte 0 + .byte 0 + .global DeviceCapacity DeviceCapacity: -.byte 9 + .byte 9 /*reserved*/ -.space 9 + .space 9 + .global RomVersion RomVersion: -.byte 5 + .byte 5 /*reserved*/ -.space 1 + .space 1 + .global ARM9ROMOffset ARM9ROMOffset: -.word 0x00004000 + .word 0x00004000 + .global ARM9EntryAddress ARM9EntryAddress: -.word 0x02000800 + .word 0x02000800 + .global ARM9RAMAddress ARM9RAMAddress: -.word 0x02000000 + .word 0x02000000 + .global ARM9CodeSize ARM9CodeSize: -.word 0x00107724 + .word 0x00107724 + .global ARM7ROMOffset ARM7ROMOffset: -.word 0x0030D000 + .word 0x0030D000 + .global ARM7EntryAddress ARM7EntryAddress: -.word 0x02380000 + .word 0x02380000 + .global ARM7RAMAddress ARM7RAMAddress: -.word 0x02380000 + .word 0x02380000 + .global ARM7CodeSize ARM7CodeSize: -.word 0x0002931C + .word 0x0002931C + .global FileNameTableOffset FileNameTableOffset: -.word 0x00336400 + .word 0x00336400 + .global FileNameTableSize FileNameTableSize: -.word 0x0000157F + .word 0x0000157F + .global FATOffset FATOffset: -.word 0x00337A00 + .word 0x00337A00 + .global FATSize FATSize: -.word 0x00000B20 + .word 0x00000B20 + .global ARM9OverlayOffset ARM9OverlayOffset: -.word 0x0010B800 + .word 0x0010B800 + .global ARM9OverlaySize ARM9OverlaySize: -.word 0x00000AE0 + .word 0x00000AE0 + .global ARM7OverlayOffset ARM7OverlayOffset: -.word 0x00000000 + .word 0x00000000 + .global ARM7OverlaySize ARM7OverlaySize: -.word 0x00000000 + .word 0x00000000 + .global ROMControlInfo1 ROMControlInfo1: -.word 0x00416657 + .word 0x00416657 + .global ROMControlInfo2 ROMControlInfo2: -.word 0x081808F8 + .word 0x081808F8 + .global IconTitleOffset IconTitleOffset: -.word 0x00338600 + .word 0x00338600 + .global SecureAreaCC SecureAreaCC: -.short 0x5931 + .short 0x5931 + .global ROMControlInfo3 ROMControlInfo3: -.short 0x0D7E + .short 0x0D7E + .global ARM9AutoLoadHook ARM9AutoLoadHook: -.word 0x02000A74 + .word 0x02000A74 + .global ARM7AutoLoadHook ARM7AutoLoadHook: -.word 0x02380158 + .word 0x02380158 + .global SecureAreaDisable SecureAreaDisable: -.byte 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 + .byte 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 + .global ApplicationEndOffset ApplicationEndOffset: -.word 0x03A55EC0 + .word 0x03A55EC0 + .global ROMHeaderSize ROMHeaderSize: -.word 0x00004000 + .word 0x00004000 /* should be 36 bytes here but again theres stuff here. TODO: Identify */ -.byte 0x68, 0x4B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 -.byte 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 -.byte 0x00, 0x00, 0x00, 0x00 + .byte 0x68, 0x4B, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 + .byte 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 + .byte 0x00, 0x00, 0x00, 0x00 + .global PassMeAutobootDetect PassMeAutobootDetect: -.word 0x00000000 + .word 0x00000000 /* reserved */ -.space 16 + .space 16 + .global NintendoLogo NintendoLogo: -.byte 0x24, 0xFF, 0xAE, 0x51, 0x69, 0x9A, 0xA2, 0x21, 0x3D, 0x84, 0x82, 0x0A, 0x84, 0xE4, 0x09, 0xAD -.byte 0x11, 0x24, 0x8B, 0x98, 0xC0, 0x81, 0x7F, 0x21, 0xA3, 0x52, 0xBE, 0x19, 0x93, 0x09, 0xCE, 0x20 -.byte 0x10, 0x46, 0x4A, 0x4A, 0xF8, 0x27, 0x31, 0xEC, 0x58, 0xC7, 0xE8, 0x33, 0x82, 0xE3, 0xCE, 0xBF -.byte 0x85, 0xF4, 0xDF, 0x94, 0xCE, 0x4B, 0x09, 0xC1, 0x94, 0x56, 0x8A, 0xC0, 0x13, 0x72, 0xA7, 0xFC -.byte 0x9F, 0x84, 0x4D, 0x73, 0xA3, 0xCA, 0x9A, 0x61, 0x58, 0x97, 0xA3, 0x27, 0xFC, 0x03, 0x98, 0x76 -.byte 0x23, 0x1D, 0xC7, 0x61, 0x03, 0x04, 0xAE, 0x56, 0xBF, 0x38, 0x84, 0x00, 0x40, 0xA7, 0x0E, 0xFD -.byte 0xFF, 0x52, 0xFE, 0x03, 0x6F, 0x95, 0x30, 0xF1, 0x97, 0xFB, 0xC0, 0x85, 0x60, 0xD6, 0x80, 0x25 -.byte 0xA9, 0x63, 0xBE, 0x03, 0x01, 0x4E, 0x38, 0xE2, 0xF9, 0xA2, 0x34, 0xFF, 0xBB, 0x3E, 0x03, 0x44 -.byte 0x78, 0x00, 0x90, 0xCB, 0x88, 0x11, 0x3A, 0x94, 0x65, 0xC0, 0x7C, 0x63, 0x87, 0xF0, 0x3C, 0xAF -.byte 0xD6, 0x25, 0xE4, 0x8B, 0x38, 0x0A, 0xAC, 0x72, 0x21, 0xD4, 0xF8, 0x07 + .byte 0x24, 0xFF, 0xAE, 0x51, 0x69, 0x9A, 0xA2, 0x21, 0x3D, 0x84, 0x82, 0x0A, 0x84, 0xE4, 0x09, 0xAD + .byte 0x11, 0x24, 0x8B, 0x98, 0xC0, 0x81, 0x7F, 0x21, 0xA3, 0x52, 0xBE, 0x19, 0x93, 0x09, 0xCE, 0x20 + .byte 0x10, 0x46, 0x4A, 0x4A, 0xF8, 0x27, 0x31, 0xEC, 0x58, 0xC7, 0xE8, 0x33, 0x82, 0xE3, 0xCE, 0xBF + .byte 0x85, 0xF4, 0xDF, 0x94, 0xCE, 0x4B, 0x09, 0xC1, 0x94, 0x56, 0x8A, 0xC0, 0x13, 0x72, 0xA7, 0xFC + .byte 0x9F, 0x84, 0x4D, 0x73, 0xA3, 0xCA, 0x9A, 0x61, 0x58, 0x97, 0xA3, 0x27, 0xFC, 0x03, 0x98, 0x76 + .byte 0x23, 0x1D, 0xC7, 0x61, 0x03, 0x04, 0xAE, 0x56, 0xBF, 0x38, 0x84, 0x00, 0x40, 0xA7, 0x0E, 0xFD + .byte 0xFF, 0x52, 0xFE, 0x03, 0x6F, 0x95, 0x30, 0xF1, 0x97, 0xFB, 0xC0, 0x85, 0x60, 0xD6, 0x80, 0x25 + .byte 0xA9, 0x63, 0xBE, 0x03, 0x01, 0x4E, 0x38, 0xE2, 0xF9, 0xA2, 0x34, 0xFF, 0xBB, 0x3E, 0x03, 0x44 + .byte 0x78, 0x00, 0x90, 0xCB, 0x88, 0x11, 0x3A, 0x94, 0x65, 0xC0, 0x7C, 0x63, 0x87, 0xF0, 0x3C, 0xAF + .byte 0xD6, 0x25, 0xE4, 0x8B, 0x38, 0x0A, 0xAC, 0x72, 0x21, 0xD4, 0xF8, 0x07 + .global LogoCRC LogoCRC: -.short 0xCF56 + .short 0xCF56 + .global HeaderCRC HeaderCRC: -.short 0xCA37 + .short 0xCA37 /* reserved */ .space 160 /* hack so it builds */ @@ -1,4 +1,5 @@ .extern sub_0200019E
+.extern NitroMain
.extern sub_02000DF4
.extern sub_02000E0C
.extern sub_02000E7C
@@ -1648,6 +1649,8 @@ .extern sub_020EBE8C
.extern sub_020EBE8C
.extern sub_020EBE8C
+.extern sub_020EC5CC
+.extern sub_020EC694
.extern sub_021D78FC
.extern sub_021D78FC
.extern sub_021D79B4
diff --git a/ld_script.txt b/ld_script.txt index 09a5986b..10692643 100644 --- a/ld_script.txt +++ b/ld_script.txt @@ -24,7 +24,7 @@ SECTIONS { BEGIN_SEG(arm9, 0x2000000) { build/asm/secure.o(.text); - build/asm/entry.o(.text); + build/asm/entry.o(.text); build/asm/main.o(.text); build/src/sub_02000DF4.o(.text); build/asm/arm9_thumb.o(.text); @@ -37,4 +37,29 @@ SECTIONS { build/asm/rom3.o(.text); } END_SEG(rom3) + + BEGIN_SEG(gap1, 0x2000000 + SIZEOF(rom3) + SIZEOF(arm9)) + { + build/asm/gap1.o(.text); + } + END_SEG(gap1) + + BEGIN_SEG(arm7, 0x02380000) + { + build/asm/arm7_rom.o(.text); + } + END_SEG(arm7) + + BEGIN_SEG(gap2, 0x02380000 + SIZEOF(arm7)) + { + build/asm/gap2.o(.text) + } + END_SEG(gap2) + + . = 0x336400; + BEGIN_SEG(FileNameTable, 0x02400000) + { + build/asm/filenametable.o(.text); + } + END_SEG(FileNameTable) } diff --git a/pokediamond.lcf b/pokediamond.lcf index ff392ac0..40677860 100644 --- a/pokediamond.lcf +++ b/pokediamond.lcf @@ -3,6 +3,10 @@ MEMORY { header (RWX) : ORIGIN=0, LENGTH=0 arm9 (RWX) : ORIGIN=0x2000000, LENGTH=0 rom3 (RWX) : ORIGIN=0, LENGTH=0 + gap1 (RWX) : ORIGIN=0, LENGTH=0 + arm7 (RWX) : ORIGIN=0, LENGTH=0 + gap2 (RWX) : ORIGIN=0, LENGTH=0 + filenametable (RWX) : ORIGIN=0, LENGTH=0 } SECTIONS { @@ -23,4 +27,20 @@ SECTIONS { .rom3 : AT (0x10B724) { rom3.o (.text) } > rom3 + + .gap1 : AT(0x30CE20) { + gap1.o (.text) + } > gap1 + + .arm7 : AT(0x30D000) { + arm7_rom.o(.text) + } > arm7 + + .gap2 : AT(0x33631C) { + gap2.o (.text) + } > gap2 + + .filenametable : AT(0x336400) { + filenametable.o(.text) + } > filenametable } |