FreeCalypso > hg > freecalypso-reveng
changeset 206:11761eaf712c
old Calypso F741979B boot ROM analyzed
author | Mychaela Falconia <falcon@ivan.Harhan.ORG> |
---|---|
date | Wed, 30 Dec 2015 08:27:46 +0000 |
parents | 8bdc87c0fc03 |
children | d12a3207b1aa |
files | .hgignore bootrom-old/Makefile bootrom-old/bootrom-f741979b.bin bootrom-old/bootrom-old.disasm |
diffstat | 4 files changed, 1846 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- a/.hgignore Thu Dec 10 07:29:35 2015 +0000 +++ b/.hgignore Wed Dec 30 08:27:46 2015 +0000 @@ -5,6 +5,10 @@ ^arm7dis/armdis$ ^arm7dis/thumbdis$ +^bootrom-old/bootrom-old\.dis16 +^bootrom-old/bootrom-old\.dis32 +^bootrom-old/bootrom-old\.hex + ^compal/c118-newboot\. ^compal/c123-boot\. ^compal/c139-boot\.
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bootrom-old/Makefile Wed Dec 30 08:27:46 2015 +0000 @@ -0,0 +1,18 @@ +BIN= bootrom-f741979b.bin +GEN= bootrom-old.dis16 bootrom-old.dis32 bootrom-old.hex +ARMDIS= ../arm7dis/armdis +THUMBDIS=../arm7dis/thumbdis + +all: ${GEN} + +bootrom-old.dis16: ${BIN} ${THUMBDIS} + ${THUMBDIS} ${BIN} > $@ + +bootrom-old.dis32: ${BIN} ${ARMDIS} + ${ARMDIS} ${BIN} > $@ + +bootrom-old.hex: ${BIN} + hd ${BIN} > $@ + +clean: + rm -f ${GEN}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bootrom-old/bootrom-old.disasm Wed Dec 30 08:27:46 2015 +0000 @@ -0,0 +1,1824 @@ +RESET entry and exception vectors: + 0: ea0005c1 b 0x170c + 4: ea00052a b 0x14b4 + 8: ea00052e b 0x14c8 + c: ea000532 b 0x14dc + 10: ea000536 b 0x14f0 + 14: ea00053a b 0x1504 + 18: ea00053e b 0x1518 + 1c: ea000542 b 0x152c + +; matches C035 version + 20: e24dd004 sub sp, sp, #4 + 24: e59f20b8 ldr r2, =0xfffffb10 ; via 0xe4 + 28: e1d2c0b0 ldrh r12, [r2] + 2c: e20c10ff and r1, r12, #255 ; 0xff + 30: e20ccb3f and r12, r12, #64512 ; 0xfc00 + 34: e181c00c orr r12, r1, r12 + 38: e1a0c80c mov r12, r12, lsl #16 + 3c: e1a0c82c mov r12, r12, lsr #16 + 40: e3500001 cmp r0, #1 + 44: 0a000005 beq 0x60 + 48: e3500000 cmp r0, #0 + 4c: 1a000006 bne 0x6c + 50: e38ccc01 orr r12, r12, #256 ; 0x100 + 54: e1a0c80c mov r12, r12, lsl #16 + 58: e1a0c82c mov r12, r12, lsr #16 + 5c: ea000002 b 0x6c + 60: e38ccc03 orr r12, r12, #768 ; 0x300 + 64: e1a0c80c mov r12, r12, lsl #16 + 68: e1a0c82c mov r12, r12, lsr #16 + 6c: e1c2c0b0 strh r12, [r2] + 70: e3a0cfc3 mov r12, #780 ; 0x30c + 74: e59f006c ldr r0, =0x80f5 ; via 0xe8 + 78: e10200bc strh r0, [r2, -r12] + 7c: e3a0c000 mov r12, #0 + 80: e1cdc0b0 strh r12, [sp] + 84: ea000002 b 0x94 + 88: e1ddc0b0 ldrh r12, [sp] + 8c: e28cc001 add r12, r12, #1 + 90: e1cdc0b0 strh r12, [sp] + 94: e1dd10b0 ldrh r1, [sp] + 98: e3a0c902 mov r12, #32768 ; 0x8000 + 9c: e24ccead sub r12, r12, #2768 ; 0xad0 + a0: e151000c cmp r1, r12 + a4: bafffff7 blt 0x88 + a8: e3a0cfc3 mov r12, #780 ; 0x30c + ac: e10200bc strh r0, [r2, -r12] + b0: e3a0c000 mov r12, #0 + b4: e1cdc0b0 strh r12, [sp] + b8: ea000002 b 0xc8 + bc: e1ddc0b0 ldrh r12, [sp] + c0: e28cc001 add r12, r12, #1 + c4: e1cdc0b0 strh r12, [sp] + c8: e1ddc0b0 ldrh r12, [sp] + cc: e3a00902 mov r0, #32768 ; 0x8000 + d0: e2400ead sub r0, r0, #2768 ; 0xad0 + d4: e15c0000 cmp r12, r0 + d8: bafffff7 blt 0xbc + dc: e28dd004 add sp, sp, #4 + e0: e12fff1e bx lr + +; literal pool matches C035 version + e4: fffffb10 + e8: 000080f5 + +; 0xec routine matches C035 version +; the data structure that lives at 0x800518 in the C035 version +; appears to reside at 0x800504 in this version + ec: e92d4010 stmdb sp!, {r4, lr} + f0: e59fcd0c ldr r12, =0x800504 ; via 0xe04 + f4: e59c4014 ldr r4, [r12, #20] ; 0x14 + f8: e59f0d08 ldr r0, =0x1fe8 ; via 0xe08 + fc: e5dcc008 ldrb r12, [r12, #8] + 100: e790c10c ldr r12, [r0, r12, lsl #2] + 104: e28c0005 add r0, r12, #5 + 108: e5d0c000 ldrb r12, [r0] + 10c: e31c0040 tst r12, #64 ; 0x40 + 110: 0afffffc beq 0x108 + 114: eb000585 bl 0x1730 ; IND_CALL + 118: eafffffe b 0x118 + +; 0x11c routine matches C035 version + 11c: e3a0c004 mov r12, #4 + 120: e5c0c000 strb r12, [r0] + 124: e3a0c000 mov r12, #0 + 128: e1c0c0be strh r12, [r0, #14] ; 0xe + 12c: e1c0c1b0 strh r12, [r0, #16] ; 0x10 + 130: e580c014 str r12, [r0, #20] ; 0x14 + 134: e5c0c018 strb r12, [r0, #24] ; 0x18 + 138: e12fff1e bx lr + +; 0x13c routine matches C035 version + 13c: e92d4000 stmdb sp!, {lr} + 140: e1a0c000 mov r12, r0 + 144: e59f0cc0 ldr r0, =0x8000f8 ; via 0xe0c + 148: e3a0103e mov r1, #62 ; 0x3e + 14c: e5c01000 strb r1, [r0] + 150: e35c0009 cmp r12, #9 + 154: 88bd8000 ldmhiia sp!, {pc} + 158: e28f1000 add r1, pc, #0 + 15c: e791f10c ldr pc, [r1, r12, lsl #2] +; switch table, absolute addresses + 160: 000002ac + 164: 00000280 + 168: 00000264 + 16c: 00000248 + 170: 00000224 + 174: 00000200 + 178: 000001dc + 17c: 000001c0 + 180: 000001a4 + 184: 00000188 +; code appears to match C035 version + 188: e3a0c042 mov r12, #66 ; 0x42 + 18c: e5c0c001 strb r12, [r0, #1] + 190: e3a01002 mov r1, #2 + 194: e59fcc74 ldr r12, =0x80050c ; via 0xe10 + 198: e5dc2000 ldrb r2, [r12] + 19c: eb000458 bl 0x1304 + 1a0: e8bd8000 ldmia sp!, {pc} + 1a4: e3a0c062 mov r12, #98 ; 0x62 + 1a8: e5c0c001 strb r12, [r0, #1] + 1ac: e3a01002 mov r1, #2 + 1b0: e59fcc58 ldr r12, =0x80050c ; via 0xe10 + 1b4: e5dc2000 ldrb r2, [r12] + 1b8: eb000451 bl 0x1304 + 1bc: e8bd8000 ldmia sp!, {pc} + 1c0: e3a0c061 mov r12, #97 ; 0x61 + 1c4: e5c0c001 strb r12, [r0, #1] + 1c8: e3a01002 mov r1, #2 + 1cc: e59fcc3c ldr r12, =0x80050c ; via 0xe10 + 1d0: e5dc2000 ldrb r2, [r12] + 1d4: eb00044a bl 0x1304 + 1d8: e8bd8000 ldmia sp!, {pc} + 1dc: e3a0c043 mov r12, #67 ; 0x43 + 1e0: e5c0c001 strb r12, [r0, #1] + 1e4: e59fcc18 ldr r12, =0x800504 ; via 0xe04 + 1e8: e5dc1010 ldrb r1, [r12, #16] ; 0x10 + 1ec: e5c01002 strb r1, [r0, #2] + 1f0: e5dc2008 ldrb r2, [r12, #8] + 1f4: e3a01003 mov r1, #3 + 1f8: eb000441 bl 0x1304 + 1fc: e8bd8000 ldmia sp!, {pc} + 200: e3a0c063 mov r12, #99 ; 0x63 + 204: e5c0c001 strb r12, [r0, #1] + 208: e59fcbf4 ldr r12, =0x800504 ; via 0xe04 + 20c: e5dc1010 ldrb r1, [r12, #16] ; 0x10 + 210: e5c01002 strb r1, [r0, #2] + 214: e5dc2008 ldrb r2, [r12, #8] + 218: e3a01003 mov r1, #3 + 21c: eb000438 bl 0x1304 + 220: e8bd8000 ldmia sp!, {pc} + 224: e3a0c057 mov r12, #87 ; 0x57 + 228: e5c0c001 strb r12, [r0, #1] + 22c: e59fcbd0 ldr r12, =0x800504 ; via 0xe04 + 230: e5dc1019 ldrb r1, [r12, #25] ; 0x19 + 234: e5c01002 strb r1, [r0, #2] + 238: e5dc2008 ldrb r2, [r12, #8] + 23c: e3a01003 mov r1, #3 + 240: eb00042f bl 0x1304 + 244: e8bd8000 ldmia sp!, {pc} + 248: e3a0c077 mov r12, #119 ; 0x77 + 24c: e5c0c001 strb r12, [r0, #1] + 250: e3a01002 mov r1, #2 + 254: e59fcbb4 ldr r12, =0x80050c ; via 0xe10 + 258: e5dc2000 ldrb r2, [r12] + 25c: eb000428 bl 0x1304 + 260: e8bd8000 ldmia sp!, {pc} + 264: e3a0c050 mov r12, #80 ; 0x50 + 268: e5c0c001 strb r12, [r0, #1] + 26c: e3a01002 mov r1, #2 + 270: e59fcb98 ldr r12, =0x80050c ; via 0xe10 + 274: e5dc2000 ldrb r2, [r12] + 278: eb000421 bl 0x1304 + 27c: e8bd8000 ldmia sp!, {pc} + 280: e3a0c070 mov r12, #112 ; 0x70 + 284: e5c0c001 strb r12, [r0, #1] + 288: e3a0c000 mov r12, #0 + 28c: e5c0c002 strb r12, [r0, #2] + 290: e3a0c004 mov r12, #4 + 294: e5c0c003 strb r12, [r0, #3] + 298: e3a01004 mov r1, #4 + 29c: e59fcb6c ldr r12, =0x80050c ; via 0xe10 + 2a0: e5dc2000 ldrb r2, [r12] + 2a4: eb000416 bl 0x1304 + 2a8: e8bd8000 ldmia sp!, {pc} + 2ac: e3a0c069 mov r12, #105 ; 0x69 + 2b0: e5c0c001 strb r12, [r0, #1] + 2b4: e3a01002 mov r1, #2 + 2b8: e59fcb50 ldr r12, =0x80050c ; via 0xe10 + 2bc: e5dc2000 ldrb r2, [r12] + 2c0: eb00040f bl 0x1304 + 2c4: e8bd8000 ldmia sp!, {pc} + +; 0x2c8 routine matches C035 version + 2c8: e92d4ff0 stmdb sp!, {r4, r5, r6, r7, r8, r9, r10, r11, lr} + 2cc: e24dd004 sub sp, sp, #4 + 2d0: e1a0b000 mov r11, r0 + 2d4: e3a05000 mov r5, #0 + 2d8: e5cb5000 strb r5, [r11] + 2dc: e59f7b30 ldr r7, =0x8000f0 ; via 0xe14 + 2e0: e59f4b1c ldr r4, =0x800504 ; via 0xe04 + 2e4: e5d40008 ldrb r0, [r4, #8] + 2e8: e5971000 ldr r1, [r7] + 2ec: e28d2002 add r2, sp, #2 + 2f0: eb00044c bl 0x1428 + 2f4: e3500000 cmp r0, #0 + 2f8: 0a0000fc beq 0x6f0 + 2fc: e5ddc002 ldrb r12, [sp, #2] + 300: e25cc061 subs r12, r12, #97 ; 0x61 + 304: 0a000104 beq 0x71c + 308: e25cc001 subs r12, r12, #1 + 30c: 0a0000ee beq 0x6cc + 310: e25cc001 subs r12, r12, #1 + 314: 0a0000e1 beq 0x6a0 + 318: e25cc006 subs r12, r12, #6 + 31c: 0a0000dc beq 0x694 + 320: e25cc007 subs r12, r12, #7 + 324: 0a0000b8 beq 0x60c + 328: e25cc007 subs r12, r12, #7 + 32c: 1a0000fc bne 0x724 + 330: e5c45018 strb r5, [r4, #24] ; 0x18 + 334: e3a0a000 mov r10, #0 + 338: e3a06000 mov r6, #0 + 33c: ea000015 b 0x398 + 340: e5d40008 ldrb r0, [r4, #8] + 344: e5971000 ldr r1, [r7] + 348: e28d2002 add r2, sp, #2 + 34c: eb000435 bl 0x1428 + 350: e3500000 cmp r0, #0 + 354: 0a0000e5 beq 0x6f0 + 358: e5ddc002 ldrb r12, [sp, #2] + 35c: e35c003c cmp r12, #60 ; 0x3c + 360: 0a000001 beq 0x36c + 364: e3a0c001 mov r12, #1 + 368: e5c4c018 strb r12, [r4, #24] ; 0x18 + 36c: e5d40008 ldrb r0, [r4, #8] + 370: e5971000 ldr r1, [r7] + 374: e28d2002 add r2, sp, #2 + 378: eb00042a bl 0x1428 + 37c: e3500000 cmp r0, #0 + 380: 0a0000da beq 0x6f0 + 384: e5ddc002 ldrb r12, [sp, #2] + 388: e35c0077 cmp r12, #119 ; 0x77 + 38c: 0a000001 beq 0x398 + 390: e3a0c001 mov r12, #1 + 394: e5c4c018 strb r12, [r4, #24] ; 0x18 + 398: e5d40008 ldrb r0, [r4, #8] + 39c: e5971000 ldr r1, [r7] + 3a0: e1a0200d mov r2, sp + 3a4: eb00041f bl 0x1428 + 3a8: e3500000 cmp r0, #0 + 3ac: 0a0000cf beq 0x6f0 + 3b0: e5d40008 ldrb r0, [r4, #8] + 3b4: e5971000 ldr r1, [r7] + 3b8: e28d2001 add r2, sp, #1 + 3bc: eb000419 bl 0x1428 + 3c0: e3500000 cmp r0, #0 + 3c4: 0a0000c9 beq 0x6f0 + 3c8: e5dd0000 ldrb r0, [sp] + 3cc: e5ddc001 ldrb r12, [sp, #1] + 3d0: e150000c cmp r0, r12 + 3d4: 1a000000 bne 0x3dc + 3d8: e3a0a001 mov r10, #1 + 3dc: e5dd0000 ldrb r0, [sp] + 3e0: e5ddc001 ldrb r12, [sp, #1] + 3e4: e150000c cmp r0, r12 + 3e8: ca00007c bgt 0x5e0 + 3ec: e5ddc001 ldrb r12, [sp, #1] + 3f0: e35c0000 cmp r12, #0 + 3f4: 0a000079 beq 0x5e0 + 3f8: e5ddc000 ldrb r12, [sp] + 3fc: e35c0000 cmp r12, #0 + 400: 0a000076 beq 0x5e0 + 404: e3a08002 mov r8, #2 + 408: e3a05000 mov r5, #0 + 40c: e5d40008 ldrb r0, [r4, #8] + 410: e5971000 ldr r1, [r7] + 414: e28d2002 add r2, sp, #2 + 418: eb000402 bl 0x1428 + 41c: e3500000 cmp r0, #0 + 420: 0a0000b2 beq 0x6f0 + 424: e5ddc002 ldrb r12, [sp, #2] + 428: e18cc405 orr r12, r12, r5, lsl #8 + 42c: e1a0c80c mov r12, r12, lsl #16 + 430: e1a0582c mov r5, r12, lsr #16 + 434: e2588001 subs r8, r8, #1 + 438: 1afffff3 bne 0x40c + 43c: e3a09004 mov r9, #4 + 440: e3a08000 mov r8, #0 + 444: e5d40008 ldrb r0, [r4, #8] + 448: e5971000 ldr r1, [r7] + 44c: e28d2002 add r2, sp, #2 + 450: eb0003f4 bl 0x1428 + 454: e3500000 cmp r0, #0 + 458: 0a0000a4 beq 0x6f0 + 45c: e5ddc002 ldrb r12, [sp, #2] + 460: e18c8408 orr r8, r12, r8, lsl #8 + 464: e2599001 subs r9, r9, #1 + 468: 1afffff5 bne 0x444 + 46c: e59fc9a4 ldr r12, =0x80073c ; via 0xe18 + 470: e158000c cmp r8, r12 + 474: 3a00004e bcc 0x5b4 + 478: e59f099c ldr r0, =0x7f8c3 ; via 0xe1c + 47c: e080c00c add r12, r0, r12 + 480: e158000c cmp r8, r12 + 484: 8a00004a bhi 0x5b4 + 488: e085c006 add r12, r5, r6 + 48c: e35c0ffe cmp r12, #1016 ; 0x3f8 + 490: aa000037 bge 0x574 + 494: e59fc970 ldr r12, =0x8000f8 ; via 0xe0c + 498: e5dd0000 ldrb r0, [sp] + 49c: e7c6000c strb r0, [r6, r12] + 4a0: e2860001 add r0, r6, #1 + 4a4: e1a00800 mov r0, r0, lsl #16 + 4a8: e1a06820 mov r6, r0, lsr #16 + 4ac: e5dd0001 ldrb r0, [sp, #1] + 4b0: e7c6000c strb r0, [r6, r12] + 4b4: e2860001 add r0, r6, #1 + 4b8: e1a00800 mov r0, r0, lsl #16 + 4bc: e1a06820 mov r6, r0, lsr #16 + 4c0: e1a00425 mov r0, r5, lsr #8 + 4c4: e7c6000c strb r0, [r6, r12] + 4c8: e2860001 add r0, r6, #1 + 4cc: e1a00800 mov r0, r0, lsl #16 + 4d0: e1a06820 mov r6, r0, lsr #16 + 4d4: e7c6500c strb r5, [r6, r12] + 4d8: e2860001 add r0, r6, #1 + 4dc: e1a00800 mov r0, r0, lsl #16 + 4e0: e1a06820 mov r6, r0, lsr #16 + 4e4: e1a00c28 mov r0, r8, lsr #24 + 4e8: e7c6000c strb r0, [r6, r12] + 4ec: e2860001 add r0, r6, #1 + 4f0: e1a00800 mov r0, r0, lsl #16 + 4f4: e1a06820 mov r6, r0, lsr #16 + 4f8: e1a00828 mov r0, r8, lsr #16 + 4fc: e7c6000c strb r0, [r6, r12] + 500: e2860001 add r0, r6, #1 + 504: e1a00800 mov r0, r0, lsl #16 + 508: e1a06820 mov r6, r0, lsr #16 + 50c: e1a00428 mov r0, r8, lsr #8 + 510: e7c6000c strb r0, [r6, r12] + 514: e2860001 add r0, r6, #1 + 518: e1a00800 mov r0, r0, lsl #16 + 51c: e1a06820 mov r6, r0, lsr #16 + 520: e086900c add r9, r6, r12 + 524: e5c98000 strb r8, [r9] + 528: e286c001 add r12, r6, #1 + 52c: e1a0c80c mov r12, r12, lsl #16 + 530: e1a0682c mov r6, r12, lsr #16 + 534: e3550000 cmp r5, #0 + 538: 0a000018 beq 0x5a0 + 53c: e085c006 add r12, r5, r6 + 540: e1a0c80c mov r12, r12, lsl #16 + 544: e1a0682c mov r6, r12, lsr #16 + 548: e2899001 add r9, r9, #1 + 54c: e5d40008 ldrb r0, [r4, #8] + 550: e5971000 ldr r1, [r7] + 554: e1a02009 mov r2, r9 + 558: eb0003b2 bl 0x1428 + 55c: e3500000 cmp r0, #0 + 560: 0a000062 beq 0x6f0 + 564: e2899001 add r9, r9, #1 + 568: e2555001 subs r5, r5, #1 + 56c: 1afffff6 bne 0x54c + 570: ea00000a b 0x5a0 + 574: e285c001 add r12, r5, #1 + 578: e1a0c80c mov r12, r12, lsl #16 + 57c: e1a0582c mov r5, r12, lsr #16 + 580: e5d40008 ldrb r0, [r4, #8] + 584: e5971000 ldr r1, [r7] + 588: e28d2002 add r2, sp, #2 + 58c: eb0003a5 bl 0x1428 + 590: e3500000 cmp r0, #0 + 594: 0a000055 beq 0x6f0 + 598: e2555001 subs r5, r5, #1 + 59c: 1afffff7 bne 0x580 + 5a0: e35a0000 cmp r10, #0 + 5a4: 0affff65 beq 0x340 + 5a8: e3a0c003 mov r12, #3 + 5ac: e5cbc000 strb r12, [r11] + 5b0: ea00005b b 0x724 + 5b4: e3a0c001 mov r12, #1 + 5b8: e5c4c018 strb r12, [r4, #24] ; 0x18 + 5bc: e3a0c003 mov r12, #3 + 5c0: e5cbc000 strb r12, [r11] + 5c4: e5d40008 ldrb r0, [r4, #8] + 5c8: e59f1850 ldr r1, =0xfffff ; via 0xe20 + 5cc: e28d2002 add r2, sp, #2 + 5d0: eb000394 bl 0x1428 + 5d4: e3500001 cmp r0, #1 + 5d8: 0afffff9 beq 0x5c4 + 5dc: ea000050 b 0x724 + 5e0: e3a0c001 mov r12, #1 + 5e4: e5c4c018 strb r12, [r4, #24] ; 0x18 + 5e8: e3a0c003 mov r12, #3 + 5ec: e5cbc000 strb r12, [r11] + 5f0: e5d40008 ldrb r0, [r4, #8] + 5f4: e59f1824 ldr r1, =0xfffff ; via 0xe20 + 5f8: e28d2002 add r2, sp, #2 + 5fc: eb000389 bl 0x1428 + 600: e3500001 cmp r0, #1 + 604: 0afffff9 beq 0x5f0 + 608: ea000045 b 0x724 + 60c: e59f67f8 ldr r6, =0x8000f8 ; via 0xe0c + 610: e3a08009 mov r8, #9 + 614: e5d40008 ldrb r0, [r4, #8] + 618: e5971000 ldr r1, [r7] + 61c: e1a02006 mov r2, r6 + 620: eb000380 bl 0x1428 + 624: e3500000 cmp r0, #0 + 628: 0a000030 beq 0x6f0 + 62c: e2866001 add r6, r6, #1 + 630: e2588001 subs r8, r8, #1 + 634: 1afffff6 bne 0x614 + 638: e59fc7cc ldr r12, =0x8000f8 ; via 0xe0c + 63c: e5dc0000 ldrb r0, [r12] + 640: e5c40000 strb r0, [r4] + 644: e5dc0001 ldrb r0, [r12, #1] + 648: e5c40009 strb r0, [r4, #9] + 64c: e1c450ba strh r5, [r4, #10] ; 0xa + 650: e5dc1003 ldrb r1, [r12, #3] + 654: e5dc0002 ldrb r0, [r12, #2] + 658: e1810400 orr r0, r1, r0, lsl #8 + 65c: e1c400ba strh r0, [r4, #10] ; 0xa + 660: e5dc0004 ldrb r0, [r12, #4] + 664: e5c4000d strb r0, [r4, #13] ; 0xd + 668: e5dc0006 ldrb r0, [r12, #6] + 66c: e5dc1005 ldrb r1, [r12, #5] + 670: e1801401 orr r1, r0, r1, lsl #8 + 674: e5dc0007 ldrb r0, [r12, #7] + 678: e1800401 orr r0, r0, r1, lsl #8 + 67c: e5dcc008 ldrb r12, [r12, #8] + 680: e18cc400 orr r12, r12, r0, lsl #8 + 684: e584c004 str r12, [r4, #4] + 688: e3a0c002 mov r12, #2 + 68c: e5cbc000 strb r12, [r11] + 690: ea000023 b 0x724 + 694: e3a0c001 mov r12, #1 + 698: e5cbc000 strb r12, [r11] + 69c: ea000020 b 0x724 + 6a0: e5d40008 ldrb r0, [r4, #8] + 6a4: e5971000 ldr r1, [r7] + 6a8: e28d2002 add r2, sp, #2 + 6ac: eb00035d bl 0x1428 + 6b0: e3500000 cmp r0, #0 + 6b4: 0a00000d beq 0x6f0 + 6b8: e5ddc002 ldrb r12, [sp, #2] + 6bc: e1c4c0be strh r12, [r4, #14] ; 0xe + 6c0: e3a0c004 mov r12, #4 + 6c4: e5cbc000 strb r12, [r11] + 6c8: ea000015 b 0x724 + 6cc: e3a0c000 mov r12, #0 + 6d0: e584c014 str r12, [r4, #20] ; 0x14 + 6d4: e3a05004 mov r5, #4 + 6d8: e5d40008 ldrb r0, [r4, #8] + 6dc: e5971000 ldr r1, [r7] + 6e0: e28d2002 add r2, sp, #2 + 6e4: eb00034f bl 0x1428 + 6e8: e3500000 cmp r0, #0 + 6ec: 1a000001 bne 0x6f8 + 6f0: e3a00000 mov r0, #0 + 6f4: ea00000b b 0x728 + 6f8: e5dd0002 ldrb r0, [sp, #2] + 6fc: e594c014 ldr r12, [r4, #20] ; 0x14 + 700: e180c40c orr r12, r0, r12, lsl #8 + 704: e584c014 str r12, [r4, #20] ; 0x14 + 708: e2555001 subs r5, r5, #1 + 70c: 1afffff1 bne 0x6d8 + 710: e3a0c006 mov r12, #6 + 714: e5cbc000 strb r12, [r11] + 718: ea000001 b 0x724 + 71c: e3a0c005 mov r12, #5 + 720: e5cbc000 strb r12, [r11] + 724: e3a00001 mov r0, #1 + 728: e28dd004 add sp, sp, #4 + 72c: e8bd8ff0 ldmia sp!, {r4, r5, r6, r7, r8, r9, r10, r11, pc} + +; 0x730 routine matches C035 version + 730: e92d43f0 stmdb sp!, {r4, r5, r6, r7, r8, r9, lr} + 734: e59f46c8 ldr r4, =0x800504 ; via 0xe04 + 738: e5d4c018 ldrb r12, [r4, #24] ; 0x18 + 73c: e35c0001 cmp r12, #1 + 740: 0a00004a beq 0x870 + 744: e59f56c0 ldr r5, =0x8000f8 ; via 0xe0c + 748: e59f66c8 ldr r6, =0x80073c ; via 0xe18 + 74c: e3a07000 mov r7, #0 + 750: e3a00000 mov r0, #0 + 754: e080c005 add r12, r0, r5 + 758: e28cc001 add r12, r12, #1 + 75c: e7d02005 ldrb r2, [r0, r5] + 760: e5dc1000 ldrb r1, [r12] + 764: e1520001 cmp r2, r1 + 768: 1a000000 bne 0x770 + 76c: e3a07001 mov r7, #1 + 770: e5dc2002 ldrb r2, [r12, #2] + 774: e5dc1001 ldrb r1, [r12, #1] + 778: e0821401 add r1, r2, r1, lsl #8 + 77c: e1a01801 mov r1, r1, lsl #16 + 780: e1a01821 mov r1, r1, lsr #16 + 784: e5dc3004 ldrb r3, [r12, #4] + 788: e5dc2003 ldrb r2, [r12, #3] + 78c: e0832402 add r2, r3, r2, lsl #8 + 790: e5dc3005 ldrb r3, [r12, #5] + 794: e0832402 add r2, r3, r2, lsl #8 + 798: e5dcc006 ldrb r12, [r12, #6] + 79c: e08c2402 add r2, r12, r2, lsl #8 + 7a0: e202c0ff and r12, r2, #255 ; 0xff + 7a4: e081300c add r3, r1, r12 + 7a8: e1a0c422 mov r12, r2, lsr #8 + 7ac: e20cc0ff and r12, r12, #255 ; 0xff + 7b0: e08c3003 add r3, r12, r3 + 7b4: e1a0c822 mov r12, r2, lsr #16 + 7b8: e20cc0ff and r12, r12, #255 ; 0xff + 7bc: e08cc003 add r12, r12, r3 + 7c0: e08ccc22 add r12, r12, r2, lsr #24 + 7c4: e28cc005 add r12, r12, #5 + 7c8: e1a0c80c mov r12, r12, lsl #16 + 7cc: e1a0882c mov r8, r12, lsr #16 + 7d0: e3a03000 mov r3, #0 + 7d4: e1520006 cmp r2, r6 + 7d8: 3a000003 bcc 0x7ec + 7dc: e59fc638 ldr r12, =0x7f8c3 ; via 0xe1c + 7e0: e08cc006 add r12, r12, r6 + 7e4: e152000c cmp r2, r12 + 7e8: 9a000001 bls 0x7f4 + 7ec: e383c001 orr r12, r3, #1 + 7f0: e20c30ff and r3, r12, #255 ; 0xff + 7f4: e3530000 cmp r3, #0 + 7f8: 1a00001d bne 0x874 + 7fc: e3a09000 mov r9, #0 + 800: e3510000 cmp r1, #0 + 804: 0a00000b beq 0x838 + 808: e089c000 add r12, r9, r0 + 80c: e085c00c add r12, r5, r12 + 810: e5dcc008 ldrb r12, [r12, #8] + 814: e4c2c001 strb r12, [r2], #1 + 818: e08cc008 add r12, r12, r8 + 81c: e1a0c80c mov r12, r12, lsl #16 + 820: e1a0882c mov r8, r12, lsr #16 + 824: e289c001 add r12, r9, #1 + 828: e1a0c80c mov r12, r12, lsl #16 + 82c: e1a0982c mov r9, r12, lsr #16 + 830: e2511001 subs r1, r1, #1 + 834: 1afffff3 bne 0x808 + 838: e3a0c0ff mov r12, #255 ; 0xff + 83c: e1ccc008 bic r12, r12, r8 + 840: e1a0c80c mov r12, r12, lsl #16 + 844: e1a0882c mov r8, r12, lsr #16 + 848: e1d4c1b0 ldrh r12, [r4, #16] ; 0x10 + 84c: e088c00c add r12, r8, r12 + 850: e1c4c1b0 strh r12, [r4, #16] ; 0x10 + 854: e080c009 add r12, r0, r9 + 858: e28cc008 add r12, r12, #8 + 85c: e1a0c80c mov r12, r12, lsl #16 + 860: e1a0082c mov r0, r12, lsr #16 + 864: e3570000 cmp r7, #0 + 868: 0affffb9 beq 0x754 + 86c: ea000000 b 0x874 + 870: e3a03002 mov r3, #2 + 874: e5c43019 strb r3, [r4, #25] ; 0x19 + 878: e3530000 cmp r3, #0 + 87c: 0a000008 beq 0x8a4 + 880: e3a00004 mov r0, #4 + 884: ebfffe2c bl 0x13c + 888: e5d41008 ldrb r1, [r4, #8] + 88c: e3a00004 mov r0, #4 + 890: eb0002d0 bl 0x13d8 + 894: e1a00004 mov r0, r4 + 898: ebfffe1f bl 0x11c + 89c: e3a00001 mov r0, #1 + 8a0: e8bd83f0 ldmia sp!, {r4, r5, r6, r7, r8, r9, pc} + 8a4: e3a00003 mov r0, #3 + 8a8: ebfffe23 bl 0x13c + 8ac: e3a00000 mov r0, #0 + 8b0: e8bd83f0 ldmia sp!, {r4, r5, r6, r7, r8, r9, pc} + +; 0x8b4 routine matches C035 version + 8b4: e92d4070 stmdb sp!, {r4, r5, r6, lr} + 8b8: e24dd008 sub sp, sp, #8 + 8bc: e59f4560 ldr r4, =0x8000f4 ; via 0xe24 + 8c0: e5d4c000 ldrb r12, [r4] + 8c4: e25cc001 subs r12, r12, #1 + 8c8: 0a000102 beq 0xcd8 + 8cc: e25cc001 subs r12, r12, #1 + 8d0: 0a00008a beq 0xb00 + 8d4: e25cc001 subs r12, r12, #1 + 8d8: 0a000047 beq 0x9fc + 8dc: e25cc001 subs r12, r12, #1 + 8e0: 1a000145 bne 0xdfc + 8e4: e250c001 subs r12, r0, #1 + 8e8: 0a00003c beq 0x9e0 + 8ec: e25cc002 subs r12, r12, #2 + 8f0: 0a00002f beq 0x9b4 + 8f4: e25cc001 subs r12, r12, #1 + 8f8: 0a000022 beq 0x988 + 8fc: e25cc001 subs r12, r12, #1 + 900: 0a000017 beq 0x964 + 904: e25cc001 subs r12, r12, #1 + 908: 1a00013b bne 0xdfc + 90c: e59f54f0 ldr r5, =0x800504 ; via 0xe04 + 910: e59f0500 ldr r0, =0x80073c ; via 0xe18 + 914: e595c014 ldr r12, [r5, #20] ; 0x14 + 918: e15c0000 cmp r12, r0 + 91c: 3a000006 bcc 0x93c + 920: e59f14f4 ldr r1, =0x7f8c3 ; via 0xe1c + 924: e0810000 add r0, r1, r0 + 928: e15c0000 cmp r12, r0 + 92c: 8a000002 bhi 0x93c + 930: e3a00008 mov r0, #8 + 934: ebfffe00 bl 0x13c + 938: ebfffdeb bl 0xec + 93c: e3a00009 mov r0, #9 + 940: ebfffdfd bl 0x13c + 944: e5d51008 ldrb r1, [r5, #8] + 948: e3a00004 mov r0, #4 + 94c: eb0002a1 bl 0x13d8 + 950: e1a00005 mov r0, r5 + 954: ebfffdf0 bl 0x11c + 958: e3a0c001 mov r12, #1 + 95c: e5c4c000 strb r12, [r4] + 960: ea000125 b 0xdfc + 964: e59f5498 ldr r5, =0x800504 ; via 0xe04 + 968: e1a00005 mov r0, r5 + 96c: ebfffdea bl 0x11c + 970: e5d51008 ldrb r1, [r5, #8] + 974: e3a00004 mov r0, #4 + 978: eb000296 bl 0x13d8 + 97c: e3a0c001 mov r12, #1 + 980: e5c4c000 strb r12, [r4] + 984: ea00011c b 0xdfc + 988: e3a00006 mov r0, #6 + 98c: ebfffdea bl 0x13c + 990: e59f546c ldr r5, =0x800504 ; via 0xe04 + 994: e5d51008 ldrb r1, [r5, #8] + 998: e3a00004 mov r0, #4 + 99c: eb00028d bl 0x13d8 + 9a0: e1a00005 mov r0, r5 + 9a4: ebfffddc bl 0x11c + 9a8: e3a0c001 mov r12, #1 + 9ac: e5c4c000 strb r12, [r4] + 9b0: ea000111 b 0xdfc + 9b4: e3a00004 mov r0, #4 + 9b8: ebfffddf bl 0x13c + 9bc: e59f5440 ldr r5, =0x800504 ; via 0xe04 + 9c0: e5d51008 ldrb r1, [r5, #8] + 9c4: e3a00004 mov r0, #4 + 9c8: eb000282 bl 0x13d8 + 9cc: e1a00005 mov r0, r5 + 9d0: ebfffdd1 bl 0x11c + 9d4: e3a0c001 mov r12, #1 + 9d8: e5c4c000 strb r12, [r4] + 9dc: ea000106 b 0xdfc + 9e0: e59f041c ldr r0, =0x800504 ; via 0xe04 + 9e4: ebfffdcc bl 0x11c + 9e8: e3a00000 mov r0, #0 + 9ec: ebfffdd2 bl 0x13c + 9f0: e3a0c004 mov r12, #4 + 9f4: e5c4c000 strb r12, [r4] + 9f8: ea0000ff b 0xdfc + 9fc: e250c001 subs r12, r0, #1 + a00: 0a000037 beq 0xae4 + a04: e25cc002 subs r12, r12, #2 + a08: 0a000031 beq 0xad4 + a0c: e25cc001 subs r12, r12, #1 + a10: 0a000017 beq 0xa74 + a14: e25cc001 subs r12, r12, #1 + a18: 0a00000c beq 0xa50 + a1c: e25cc001 subs r12, r12, #1 + a20: 1a0000f5 bne 0xdfc + a24: e3a00009 mov r0, #9 + a28: ebfffdc3 bl 0x13c + a2c: e59f53d0 ldr r5, =0x800504 ; via 0xe04 + a30: e5d51008 ldrb r1, [r5, #8] + a34: e3a00004 mov r0, #4 + a38: eb000266 bl 0x13d8 + a3c: e1a00005 mov r0, r5 + a40: ebfffdb5 bl 0x11c + a44: e3a0c001 mov r12, #1 + a48: e5c4c000 strb r12, [r4] + a4c: ea0000ea b 0xdfc + a50: e59f53ac ldr r5, =0x800504 ; via 0xe04 + a54: e1a00005 mov r0, r5 + a58: ebfffdaf bl 0x11c + a5c: e5d51008 ldrb r1, [r5, #8] + a60: e3a00004 mov r0, #4 + a64: eb00025b bl 0x13d8 + a68: e3a0c001 mov r12, #1 + a6c: e5c4c000 strb r12, [r4] + a70: ea0000e1 b 0xdfc + a74: e59fc388 ldr r12, =0x800504 ; via 0xe04 + a78: e3a010ff mov r1, #255 ; 0xff + a7c: e1dc01b0 ldrh r0, [r12, #16] ; 0x10 + a80: e1c10000 bic r0, r1, r0 + a84: e1dcc0be ldrh r12, [r12, #14] ; 0xe + a88: e20cc0ff and r12, r12, #255 ; 0xff + a8c: e150000c cmp r0, r12 + a90: 1a000004 bne 0xaa8 + a94: e3a00005 mov r0, #5 + a98: ebfffda7 bl 0x13c + a9c: e3a0c004 mov r12, #4 + aa0: e5c4c000 strb r12, [r4] + aa4: ea0000d4 b 0xdfc + aa8: e3a00006 mov r0, #6 + aac: ebfffda2 bl 0x13c + ab0: e59f534c ldr r5, =0x800504 ; via 0xe04 + ab4: e1a00005 mov r0, r5 + ab8: ebfffd97 bl 0x11c + abc: e5d51008 ldrb r1, [r5, #8] + ac0: e3a00004 mov r0, #4 + ac4: eb000243 bl 0x13d8 + ac8: e3a0c001 mov r12, #1 + acc: e5c4c000 strb r12, [r4] + ad0: ea0000c9 b 0xdfc + ad4: ebffff15 bl 0x730 + ad8: e3500000 cmp r0, #0 + adc: 0a000038 beq 0xbc4 + ae0: ea00003a b 0xbd0 + ae4: e59f0318 ldr r0, =0x800504 ; via 0xe04 + ae8: ebfffd8b bl 0x11c + aec: e3a00000 mov r0, #0 + af0: ebfffd91 bl 0x13c + af4: e3a0c003 mov r12, #3 + af8: e5c4c000 strb r12, [r4] + afc: ea0000be b 0xdfc + b00: e250c001 subs r12, r0, #1 + b04: 0a00006c beq 0xcbc + b08: e25cc001 subs r12, r12, #1 + b0c: 0a000032 beq 0xbdc + b10: e25cc001 subs r12, r12, #1 + b14: 0a000024 beq 0xbac + b18: e25cc001 subs r12, r12, #1 + b1c: 0a000017 beq 0xb80 + b20: e25cc001 subs r12, r12, #1 + b24: 0a00000c beq 0xb5c + b28: e25cc001 subs r12, r12, #1 + b2c: 1a0000b2 bne 0xdfc + b30: e3a00009 mov r0, #9 + b34: ebfffd80 bl 0x13c + b38: e59f52c4 ldr r5, =0x800504 ; via 0xe04 + b3c: e5d51008 ldrb r1, [r5, #8] + b40: e3a00004 mov r0, #4 + b44: eb000223 bl 0x13d8 + b48: e1a00005 mov r0, r5 + b4c: ebfffd72 bl 0x11c + b50: e3a0c001 mov r12, #1 + b54: e5c4c000 strb r12, [r4] + b58: ea0000a7 b 0xdfc + b5c: e59f52a0 ldr r5, =0x800504 ; via 0xe04 + b60: e1a00005 mov r0, r5 + b64: ebfffd6c bl 0x11c + b68: e5d51008 ldrb r1, [r5, #8] + b6c: e3a00004 mov r0, #4 + b70: eb000218 bl 0x13d8 + b74: e3a0c001 mov r12, #1 + b78: e5c4c000 strb r12, [r4] + b7c: ea00009e b 0xdfc + b80: e3a00006 mov r0, #6 + b84: ebfffd6c bl 0x13c + b88: e59f5274 ldr r5, =0x800504 ; via 0xe04 + b8c: e5d51008 ldrb r1, [r5, #8] + b90: e3a00004 mov r0, #4 + b94: eb00020f bl 0x13d8 + b98: e1a00005 mov r0, r5 + b9c: ebfffd5e bl 0x11c + ba0: e3a0c001 mov r12, #1 + ba4: e5c4c000 strb r12, [r4] + ba8: ea000093 b 0xdfc + bac: e59f0274 ldr r0, =0x800514 ; via 0xe28 + bb0: e3a0c000 mov r12, #0 + bb4: e1c0c0b0 strh r12, [r0] + bb8: ebfffedc bl 0x730 + bbc: e3500000 cmp r0, #0 + bc0: 1a000002 bne 0xbd0 + bc4: e3a0c003 mov r12, #3 + bc8: e5c4c000 strb r12, [r4] + bcc: ea00008a b 0xdfc + bd0: e3a0c001 mov r12, #1 + bd4: e5c4c000 strb r12, [r4] + bd8: ea000087 b 0xdfc + bdc: e59f6220 ldr r6, =0x800504 ; via 0xe04 + be0: e5d6c000 ldrb r12, [r6] + be4: e35c0000 cmp r12, #0 + be8: 0a000011 beq 0xc34 + bec: e35c0001 cmp r12, #1 + bf0: 0a00000f beq 0xc34 + bf4: e35c0002 cmp r12, #2 + bf8: 0a00000d beq 0xc34 + bfc: e35c0003 cmp r12, #3 + c00: 0a00000b beq 0xc34 + c04: e35c0004 cmp r12, #4 + c08: 0a000009 beq 0xc34 + c0c: e3a00002 mov r0, #2 + c10: ebfffd49 bl 0x13c + c14: e5d61008 ldrb r1, [r6, #8] + c18: e3a00004 mov r0, #4 + c1c: eb0001ed bl 0x13d8 + c20: e1a00006 mov r0, r6 + c24: ebfffd3c bl 0x11c + c28: e3a0c001 mov r12, #1 + c2c: e5c4c000 strb r12, [r4] + c30: ea000071 b 0xdfc + c34: e5d6500d ldrb r5, [r6, #13] ; 0xd + c38: e1d6c0ba ldrh r12, [r6, #10] ; 0xa + c3c: e20c001f and r0, r12, #31 ; 0x1f + c40: e20000ff and r0, r0, #255 ; 0xff + c44: e1a012ac mov r1, r12, lsr #5 + c48: e201101f and r1, r1, #31 ; 0x1f + c4c: e20110ff and r1, r1, #255 ; 0xff + c50: e1a0c52c mov r12, r12, lsr #10 + c54: e20cc01f and r12, r12, #31 ; 0x1f + c58: e20c20ff and r2, r12, #255 ; 0xff + c5c: e205c00f and r12, r5, #15 ; 0xf + c60: e20c30ff and r3, r12, #255 ; 0xff + c64: e1a0c225 mov r12, r5, lsr #4 + c68: e5cdc000 strb r12, [sp] + c6c: eb00006e bl 0xe2c + c70: e5d6c009 ldrb r12, [r6, #9] + c74: e5d6000c ldrb r0, [r6, #12] ; 0xc + c78: e20c1003 and r1, r12, #3 + c7c: e20110ff and r1, r1, #255 ; 0xff + c80: e1a0c12c mov r12, r12, lsr #2 + c84: e20cc01f and r12, r12, #31 ; 0x1f + c88: e20c20ff and r2, r12, #255 ; 0xff + c8c: eb000098 bl 0xef4 + c90: e3a00001 mov r0, #1 + c94: ebfffd28 bl 0x13c + c98: e5d60000 ldrb r0, [r6] + c9c: e5d61008 ldrb r1, [r6, #8] + ca0: eb0001cc bl 0x13d8 + ca4: e59fc168 ldr r12, =0x8000f0 ; via 0xe14 + ca8: e5960004 ldr r0, [r6, #4] + cac: e58c0000 str r0, [r12] + cb0: e3a0c002 mov r12, #2 + cb4: e5c4c000 strb r12, [r4] + cb8: ea00004f b 0xdfc + cbc: e59f0140 ldr r0, =0x800504 ; via 0xe04 + cc0: ebfffd15 bl 0x11c + cc4: e3a00000 mov r0, #0 + cc8: ebfffd1b bl 0x13c + ccc: e3a0c002 mov r12, #2 + cd0: e5c4c000 strb r12, [r4] + cd4: ea000048 b 0xdfc + cd8: e250c001 subs r12, r0, #1 + cdc: 0a000040 beq 0xde4 + ce0: e25cc001 subs r12, r12, #1 + ce4: 0a00000b beq 0xd18 + ce8: e24cc001 sub r12, r12, #1 + cec: e35c0003 cmp r12, #3 + cf0: 8a000041 bhi 0xdfc + cf4: e59f5108 ldr r5, =0x800504 ; via 0xe04 + cf8: e1a00005 mov r0, r5 + cfc: ebfffd06 bl 0x11c + d00: e5d51008 ldrb r1, [r5, #8] + d04: e3a00004 mov r0, #4 + d08: eb0001b2 bl 0x13d8 + d0c: e3a0c001 mov r12, #1 + d10: e5c4c000 strb r12, [r4] + d14: ea000038 b 0xdfc + d18: e59f60e4 ldr r6, =0x800504 ; via 0xe04 + d1c: e5d6c000 ldrb r12, [r6] + d20: e35c0000 cmp r12, #0 + d24: 0a00000c beq 0xd5c + d28: e35c0001 cmp r12, #1 + d2c: 0a00000a beq 0xd5c + d30: e35c0002 cmp r12, #2 + d34: 0a000008 beq 0xd5c + d38: e35c0003 cmp r12, #3 + d3c: 0a000006 beq 0xd5c + d40: e35c0004 cmp r12, #4 + d44: 0a000004 beq 0xd5c + d48: e3a00002 mov r0, #2 + d4c: ebfffcfa bl 0x13c + d50: e3a0c001 mov r12, #1 + d54: e5c4c000 strb r12, [r4] + d58: ea000027 b 0xdfc + d5c: e5d6500d ldrb r5, [r6, #13] ; 0xd + d60: e1d6c0ba ldrh r12, [r6, #10] ; 0xa + d64: e20c001f and r0, r12, #31 ; 0x1f + d68: e20000ff and r0, r0, #255 ; 0xff + d6c: e1a012ac mov r1, r12, lsr #5 + d70: e201101f and r1, r1, #31 ; 0x1f + d74: e20110ff and r1, r1, #255 ; 0xff + d78: e1a0c52c mov r12, r12, lsr #10 + d7c: e20cc01f and r12, r12, #31 ; 0x1f + d80: e20c20ff and r2, r12, #255 ; 0xff + d84: e205c00f and r12, r5, #15 ; 0xf + d88: e20c30ff and r3, r12, #255 ; 0xff + d8c: e1a0c225 mov r12, r5, lsr #4 + d90: e5cdc000 strb r12, [sp] + d94: eb000024 bl 0xe2c + d98: e5d6c009 ldrb r12, [r6, #9] + d9c: e5d6000c ldrb r0, [r6, #12] ; 0xc + da0: e20c1003 and r1, r12, #3 + da4: e20110ff and r1, r1, #255 ; 0xff + da8: e1a0c12c mov r12, r12, lsr #2 + dac: e20cc01f and r12, r12, #31 ; 0x1f + db0: e20c20ff and r2, r12, #255 ; 0xff + db4: eb00004e bl 0xef4 + db8: e3a00001 mov r0, #1 + dbc: ebfffcde bl 0x13c + dc0: e5d60000 ldrb r0, [r6] + dc4: e5d61008 ldrb r1, [r6, #8] + dc8: eb000182 bl 0x13d8 + dcc: e59f0040 ldr r0, =0x8000f0 ; via 0xe14 + dd0: e596c004 ldr r12, [r6, #4] + dd4: e580c000 str r12, [r0] + dd8: e3a0c002 mov r12, #2 + ddc: e5c4c000 strb r12, [r4] + de0: ea000005 b 0xdfc + de4: e59f0018 ldr r0, =0x800504 ; via 0xe04 + de8: ebfffccb bl 0x11c + dec: e3a00000 mov r0, #0 + df0: ebfffcd1 bl 0x13c + df4: e3a0c001 mov r12, #1 + df8: e5c4c000 strb r12, [r4] + dfc: e28dd008 add sp, sp, #8 + e00: e8bd8070 ldmia sp!, {r4, r5, r6, pc} + +; literal pool + e04: 00800504 + e08: 00001fe8 + e0c: 008000f8 + e10: 0080050c + e14: 008000f0 + e18: 0080073c + e1c: 0007f8c3 + e20: 000fffff + e24: 008000f4 + e28: 00800514 + +; 0xe2c routine matches C035 version + e2c: e92d4070 stmdb sp!, {r4, r5, r6, lr} + e30: e5dd5010 ldrb r5, [sp, #16] ; 0x10 + e34: e59fc48c ldr r12, =0xffff ; via 0x12c8 + e38: e59f4484 ldr r4, =0xfffffa08 ; via 0x12c4 + e3c: e1c4c0b0 strh r12, [r4] + e40: e59f4484 ldr r4, =0xfffffa0a ; via 0x12cc + e44: e1c4c0b0 strh r12, [r4] + e48: e59f4480 ldr r4, =0xfffff804 ; via 0x12d0 + e4c: e3a0c0f5 mov r12, #245 ; 0xf5 + e50: e1c4c0b0 strh r12, [r4] + e54: e3a0c0a0 mov r12, #160 ; 0xa0 + e58: e1c4c0b0 strh r12, [r4] + e5c: e59f4470 ldr r4, =0xfffffb10 ; via 0x12d4 + e60: e3a0cc01 mov r12, #256 ; 0x100 + e64: e1c4c0b0 strh r12, [r4] + e68: e59f6468 ldr r6, =0xfffffd00 ; via 0x12d8 + e6c: e3a04b01 mov r4, #1024 ; 0x400 + e70: e3a0c801 mov r12, #65536 ; 0x10000 + e74: e24cc0de sub r12, r12, #222 ; 0xde + e78: e106c0b4 strh r12, [r6, -r4] + e7c: e59fc45c ldr r12, =0x2002 ; via 0x12e0 + e80: e59f4454 ldr r4, =0xffff9800 ; via 0x12dc + e84: e1c4c0b0 strh r12, [r4] + e88: e1b04f8c movs r4, r12, lsl #31 + e8c: 1afffffd bne 0xe88 + e90: e3a0c083 mov r12, #131 ; 0x83 + e94: e28cca01 add r12, r12, #4096 ; 0x1000 + e98: e1c6c0b0 strh r12, [r6] + e9c: e1d6c0b2 ldrh r12, [r6, #2] + ea0: e20c40bf and r4, r12, #191 ; 0xbf + ea4: e20cccff and r12, r12, #65280 ; 0xff00 + ea8: e184c00c orr r12, r4, r12 + eac: e1c6c0b2 strh r12, [r6, #2] + eb0: e3a0cc02 mov r12, #512 ; 0x200 + eb4: e200001f and r0, r0, #31 ; 0x1f + eb8: e3800e2a orr r0, r0, #672 ; 0x2a0 + ebc: e10600bc strh r0, [r6, -r12] + ec0: e3a0cf7d mov r12, #500 ; 0x1f4 + ec4: e201001f and r0, r1, #31 ; 0x1f + ec8: e38000c0 orr r0, r0, #192 ; 0xc0 + ecc: e10600bc strh r0, [r6, -r12] + ed0: e3a0cf7e mov r12, #504 ; 0x1f8 + ed4: e202001f and r0, r2, #31 ; 0x1f + ed8: e38000c0 orr r0, r0, #192 ; 0xc0 + edc: e10600bc strh r0, [r6, -r12] + ee0: e3a0cb01 mov r12, #1024 ; 0x400 + ee4: e1830205 orr r0, r3, r5, lsl #4 + ee8: e3800cff orr r0, r0, #65280 ; 0xff00 + eec: e10600bc strh r0, [r6, -r12] + ef0: e8bd8070 ldmia sp!, {r4, r5, r6, pc} + +; 0xef4 routine matches C035 version + ef4: e92d4070 stmdb sp!, {r4, r5, r6, lr} + ef8: e59fc3e4 ldr r12, =0xfffff900 ; via 0x12e4 + efc: e1dc40b0 ldrh r4, [r12] + f00: e59f33d0 ldr r3, =0xfffffd00 ; via 0x12d8 + f04: e3a05b01 mov r5, #1024 ; 0x400 + f08: e3a0c801 mov r12, #65536 ; 0x10000 + f0c: e24cc0de sub r12, r12, #222 ; 0xde + f10: e103c0b5 strh r12, [r3, -r5] + f14: e59f63c0 ldr r6, =0xffff9800 ; via 0x12dc + f18: e59fc3c0 ldr r12, =0x2002 ; via 0x12e0 + f1c: e1c6c0b0 strh r12, [r6] + f20: e1b05f8c movs r5, r12, lsl #31 + f24: 1afffffd bne 0xf20 + f28: e181c102 orr r12, r1, r2, lsl #2 + f2c: e1a0c28c mov r12, r12, lsl #5 + f30: e38cc002 orr r12, r12, #2 + f34: e38cca02 orr r12, r12, #8192 ; 0x2000 + f38: e1c6c0b0 strh r12, [r6] + f3c: e3500001 cmp r0, #1 + f40: 0a000009 beq 0xf6c + f44: e3500000 cmp r0, #0 + f48: 1a000006 bne 0xf68 + f4c: e1d3c0b2 ldrh r12, [r3, #2] + f50: e38cc040 orr r12, r12, #64 ; 0x40 + f54: e1c3c0b2 strh r12, [r3, #2] + f58: e3a0c0a1 mov r12, #161 ; 0xa1 + f5c: e28cca01 add r12, r12, #4096 ; 0x1000 + f60: e1c3c0b0 strh r12, [r3] + f64: ea000008 b 0xf8c + f68: eafffffe b 0xf68 + f6c: e1d3c0b2 ldrh r12, [r3, #2] + f70: e20c00bf and r0, r12, #191 ; 0xbf + f74: e20cccff and r12, r12, #65280 ; 0xff00 + f78: e180c00c orr r12, r0, r12 + f7c: e1c3c0b2 strh r12, [r3, #2] + f80: e3a0c081 mov r12, #129 ; 0x81 + f84: e28cca01 add r12, r12, #4096 ; 0x1000 + f88: e1c3c0b0 strh r12, [r3] + f8c: e1d6c0b0 ldrh r12, [r6] + f90: e38cc010 orr r12, r12, #16 ; 0x10 + f94: e1a0c80c mov r12, r12, lsl #16 + f98: e1a0c82c mov r12, r12, lsr #16 + f9c: e1c6c0b0 strh r12, [r6] + fa0: e1b00f8c movs r0, r12, lsl #31 + fa4: 1afffffd bne 0xfa0 + fa8: e3a0cb01 mov r12, #1024 ; 0x400 + fac: e10340bc strh r4, [r3, -r12] + fb0: e8bd8070 ldmia sp!, {r4, r5, r6, pc} + +; 0xfb4 routine matches C035 version except for different var location + fb4: e3a0c0ff mov r12, #255 ; 0xff + fb8: e5c0c000 strb r12, [r0] + fbc: e59fc324 ldr r12, =0xffff5000 ; via 0x12e8 + fc0: e5dc2805 ldrb r2, [r12, #2053] ; 0x805 + fc4: e1b02f82 movs r2, r2, lsl #31 + fc8: 1a000001 bne 0xfd4 + fcc: e3a02000 mov r2, #0 + fd0: ea000003 b 0xfe4 + fd4: e5dc2800 ldrb r2, [r12, #2048] ; 0x800 + fd8: e352003c cmp r2, #60 ; 0x3c + fdc: 0a000024 beq 0x1074 + fe0: e3a02001 mov r2, #1 + fe4: e5dc3005 ldrb r3, [r12, #5] + fe8: e1b03f83 movs r3, r3, lsl #31 + fec: 1a000002 bne 0xffc + ff0: e3520001 cmp r2, #1 + ff4: 0a000003 beq 0x1008 + ff8: ea000015 b 0x1054 + ffc: e5dcc000 ldrb r12, [r12] + 1000: e35c003c cmp r12, #60 ; 0x3c + 1004: 0a000017 beq 0x1068 +; 0x8005a8 var in this version seems to correspond to 0x800534 in C035 + 1008: e59fc2dc ldr r12, =0x8005a8 ; via 0x12ec + 100c: e5dc0000 ldrb r0, [r12] + 1010: e3500000 cmp r0, #0 + 1014: 1a000008 bne 0x103c + 1018: e3a00001 mov r0, #1 + 101c: e5cc0000 strb r0, [r12] + 1020: e59f02c8 ldr r0, =0xfffffd02 ; via 0x12f0 + 1024: e1d0c0b0 ldrh r12, [r0] + 1028: e20c20bf and r2, r12, #191 ; 0xbf + 102c: e20cccff and r12, r12, #65280 ; 0xff00 + 1030: e182c00c orr r12, r2, r12 + 1034: e1c0c0b0 strh r12, [r0] + 1038: ea000005 b 0x1054 + 103c: e3a00000 mov r0, #0 + 1040: e5cc0000 strb r0, [r12] + 1044: e59fc2a4 ldr r12, =0xfffffd02 ; via 0x12f0 + 1048: e1dc00b0 ldrh r0, [r12] + 104c: e3800040 orr r0, r0, #64 ; 0x40 + 1050: e1cc00b0 strh r0, [r12] + 1054: e59fc290 ldr r12, =0x8005a8 ; via 0x12ec + 1058: e5dcc000 ldrb r12, [r12] + 105c: e5c1c000 strb r12, [r1] + 1060: e3a00000 mov r0, #0 + 1064: e12fff1e bx lr + 1068: e3a0c001 mov r12, #1 + 106c: e5c0c000 strb r12, [r0] + 1070: ea000001 b 0x107c + 1074: e3a0c000 mov r12, #0 + 1078: e5c0c000 strb r12, [r0] + 107c: e59fc268 ldr r12, =0x8005a8 ; via 0x12ec + 1080: e5dcc000 ldrb r12, [r12] + 1084: e5c1c000 strb r12, [r1] + 1088: e3a00001 mov r0, #1 + 108c: e12fff1e bx lr + +; 0x1090 routine matches C035 version + 1090: e92d4070 stmdb sp!, {r4, r5, r6, lr} + 1094: e24dd00c sub sp, sp, #12 ; 0xc + 1098: e1a05000 mov r5, r0 + 109c: e59f4250 ldr r4, =0x800504 ; via 0x12f4 + 10a0: e2846008 add r6, r4, #8 + 10a4: e3a0c000 mov r12, #0 + 10a8: e5cdc008 strb r12, [sp, #8] + 10ac: e3550000 cmp r5, #0 + 10b0: 1a000009 bne 0x10dc + 10b4: e59f123c ldr r1, =0x800510 ; via 0x12f8 + 10b8: e1a00006 mov r0, r6 + 10bc: ebffffbc bl 0xfb4 + 10c0: e3500001 cmp r0, #1 + 10c4: 1a000004 bne 0x10dc + 10c8: e5d4000c ldrb r0, [r4, #12] ; 0xc + 10cc: e3a01001 mov r1, #1 + 10d0: e3a02002 mov r2, #2 + 10d4: ebffff86 bl 0xef4 + 10d8: ea000001 b 0x10e4 + 10dc: e3550001 cmp r5, #1 + 10e0: 1afffff1 bne 0x10ac + 10e4: e28d0008 add r0, sp, #8 + 10e8: ebfffc76 bl 0x2c8 + 10ec: e5ddc008 ldrb r12, [sp, #8] + 10f0: e35c0000 cmp r12, #0 + 10f4: 0a00000d beq 0x1130 + 10f8: e5dd0008 ldrb r0, [sp, #8] + 10fc: ebfffdec bl 0x8b4 + 1100: ea00000a b 0x1130 + 1104: e5d4000c ldrb r0, [r4, #12] ; 0xc + 1108: e3a01001 mov r1, #1 + 110c: e3a02002 mov r2, #2 + 1110: ebffff77 bl 0xef4 + 1114: e3a0c002 mov r12, #2 + 1118: e5cdc000 strb r12, [sp] + 111c: e3a00004 mov r0, #4 + 1120: e3a01000 mov r1, #0 + 1124: e3a02000 mov r2, #0 + 1128: e3a03002 mov r3, #2 + 112c: ebffff3e bl 0xe2c + 1130: e5d40008 ldrb r0, [r4, #8] + 1134: e59fc1c0 ldr r12, =0x8000f0 ; via 0x12fc + 1138: e59c1000 ldr r1, [r12] + 113c: e28d2009 add r2, sp, #9 + 1140: eb0000b8 bl 0x1428 + 1144: e3500001 cmp r0, #1 + 1148: 1afffff8 bne 0x1130 + 114c: e5ddc009 ldrb r12, [sp, #9] + 1150: e35c003c cmp r12, #60 ; 0x3c + 1154: 1afffff5 bne 0x1130 + 1158: e28d0008 add r0, sp, #8 + 115c: ebfffc59 bl 0x2c8 + 1160: e3500001 cmp r0, #1 + 1164: 1affffe6 bne 0x1104 + 1168: e5ddc008 ldrb r12, [sp, #8] + 116c: e35c0000 cmp r12, #0 + 1170: 1affffe0 bne 0x10f8 + 1174: eaffffed b 0x1130 + +; 0x1178 routine matches C035 version + 1178: e3a0ca02 mov r12, #8192 ; 0x2000 + 117c: e59cc000 ldr r12, [r12] + 1180: e35c0000 cmp r12, #0 + 1184: 0a000011 beq 0x11d0 + 1188: e35c0001 cmp r12, #1 + 118c: 1a00000d bne 0x11c8 + 1190: e3a0c018 mov r12, #24 ; 0x18 + 1194: e28cc403 add r12, r12, #50331648 ; 0x3000000 + 1198: e59cc000 ldr r12, [r12] + 119c: e20c04ff and r0, r12, #4278190080 ; 0xff000000 + 11a0: e3700416 cmn r0, #369098752 ; 0x16000000 + 11a4: 1a000007 bne 0x11c8 + 11a8: e3a00018 mov r0, #24 ; 0x18 + 11ac: e2800403 add r0, r0, #50331648 ; 0x3000000 + 11b0: e28cc002 add r12, r12, #2 + 11b4: e1a0c10c mov r12, r12, lsl #2 + 11b8: e3ccc4ff bic r12, r12, #4278190080 ; 0xff000000 + 11bc: e790c00c ldr r12, [r0, r12] + 11c0: e37c0001 cmn r12, #1 + 11c4: 1a000001 bne 0x11d0 + 11c8: e3a00000 mov r0, #0 + 11cc: e1a0f00e mov pc, lr + 11d0: e3a00001 mov r0, #1 + 11d4: e1a0f00e mov pc, lr + +; 0x11d8 (main) routine matches C035 version + 11d8: e92d4070 stmdb sp!, {r4, r5, r6, lr} + 11dc: e24dd008 sub sp, sp, #8 + 11e0: e3a0c002 mov r12, #2 + 11e4: e5cdc000 strb r12, [sp] + 11e8: e3a00004 mov r0, #4 + 11ec: e3a01000 mov r1, #0 + 11f0: e3a02000 mov r2, #0 + 11f4: e3a03002 mov r3, #2 + 11f8: ebffff0b bl 0xe2c + 11fc: eb00004f bl 0x1340 + 1200: e59f00f4 ldr r0, =0x8000f0 ; via 0x12fc + 1204: e3a0c802 mov r12, #131072 ; 0x20000 + 1208: e24ccdad sub r12, r12, #11072 ; 0x2b40 + 120c: e580c000 str r12, [r0] + 1210: e59f60d8 ldr r6, =0xfffffd02 ; via 0x12f0 + 1214: e1d6c0b0 ldrh r12, [r6] + 1218: e38cc040 orr r12, r12, #64 ; 0x40 + 121c: e1c6c0b0 strh r12, [r6] + 1220: ebffffd4 bl 0x1178 + 1224: e3500000 cmp r0, #0 + 1228: 1a000001 bne 0x1234 + 122c: e3a00000 mov r0, #0 + 1230: ebffff96 bl 0x1090 + 1234: e1d6c0b0 ldrh r12, [r6] + 1238: e38cc040 orr r12, r12, #64 ; 0x40 + 123c: e1c6c0b0 strh r12, [r6] + 1240: e59f10b0 ldr r1, =0x800510 ; via 0x12f8 + 1244: e2415004 sub r5, r1, #4 + 1248: e59f40b0 ldr r4, =0x373c ; via 0x1300 + 124c: e1a00005 mov r0, r5 + 1250: ebffff57 bl 0xfb4 + 1254: e3500000 cmp r0, #0 + 1258: 1a000001 bne 0x1264 + 125c: e2544001 subs r4, r4, #1 + 1260: 1afffff9 bne 0x124c + 1264: e3500001 cmp r0, #1 + 1268: 0a00000c beq 0x12a0 + 126c: e1d6c0b0 ldrh r12, [r6] + 1270: e20c00bf and r0, r12, #191 ; 0xbf + 1274: e20cccff and r12, r12, #65280 ; 0xff00 + 1278: e180c00c orr r12, r0, r12 + 127c: e1c6c0b0 strh r12, [r6] + 1280: e3a0ca02 mov r12, #8192 ; 0x2000 + 1284: e59c0000 ldr r0, [r12] + 1288: e1b010a0 movs r1, r0, lsr #1 + 128c: 1a000002 bne 0x129c + 1290: e59c1004 ldr r1, [r12, #4] + 1294: eb0000d2 bl 0x15e4 ; 0x158c in C035 + 1298: eafffffe b 0x1298 + 129c: eafffffe b 0x129c + 12a0: e59fc050 ldr r12, =0x800510 ; via 0x12f8 + 12a4: e5dc0000 ldrb r0, [r12] + 12a8: e3a01001 mov r1, #1 + 12ac: e3a02002 mov r2, #2 + 12b0: ebffff0f bl 0xef4 + 12b4: e3a00001 mov r0, #1 + 12b8: ebffff74 bl 0x1090 + 12bc: e28dd008 add sp, sp, #8 + 12c0: e8bd8070 ldmia sp!, {r4, r5, r6, pc} + +; literal pool + 12c4: fffffa08 + 12c8: 0000ffff + 12cc: fffffa0a + 12d0: fffff804 + 12d4: fffffb10 + 12d8: fffffd00 + 12dc: ffff9800 + 12e0: 00002002 + 12e4: fffff900 + 12e8: ffff5000 + 12ec: 008005a8 + 12f0: fffffd02 + 12f4: 00800504 + 12f8: 00800510 + 12fc: 008000f0 + 1300: 0000373c + +; 0x1304 routine matches C035 version + 1304: e3510000 cmp r1, #0 + 1308: 012fff1e bxeq lr + 130c: e59fc178 ldr r12, =0x1fe8 ; via 0x148c + 1310: e79cc102 ldr r12, [r12, r2, lsl #2] + 1314: e28c3005 add r3, r12, #5 + 1318: e5d32000 ldrb r2, [r3] + 131c: e3120020 tst r2, #32 ; 0x20 + 1320: 0afffffc beq 0x1318 + 1324: e4d02001 ldrb r2, [r0], #1 + 1328: e5cc2000 strb r2, [r12] + 132c: e2411001 sub r1, r1, #1 + 1330: e1a01801 mov r1, r1, lsl #16 + 1334: e1b01821 movs r1, r1, lsr #16 + 1338: 1afffff6 bne 0x1318 + 133c: e12fff1e bx lr + +; 0x1340 routine matches C035 version + 1340: e92d4ff0 stmdb sp!, {r4, r5, r6, r7, r8, r9, r10, r11, lr} + 1344: e59fc144 ldr r12, =0xffff6000 ; via 0x1490 + 1348: e5dc0000 ldrb r0, [r12] + 134c: e3800002 orr r0, r0, #2 + 1350: e5cc0000 strb r0, [r12] + 1354: e5dc0000 ldrb r0, [r12] + 1358: e20000fe and r0, r0, #254 ; 0xfe + 135c: e5cc0000 strb r0, [r12] + 1360: e5dc0000 ldrb r0, [r12] + 1364: e20000fd and r0, r0, #253 ; 0xfd + 1368: e5cc0000 strb r0, [r12] + 136c: e3a0b003 mov r11, #3 + 1370: e3a05000 mov r5, #0 + 1374: e3a0a02a mov r10, #42 ; 0x2a + 1378: e3a09080 mov r9, #128 ; 0x80 + 137c: e3a070bf mov r7, #191 ; 0xbf + 1380: e3a04007 mov r4, #7 + 1384: e3a02002 mov r2, #2 + 1388: e59f60fc ldr r6, =0x1fe8 ; via 0x148c + 138c: e496c004 ldr r12, [r6], #4 + 1390: e28c3008 add r3, r12, #8 + 1394: e5c34000 strb r4, [r3] + 1398: e28c0003 add r0, r12, #3 + 139c: e5c07000 strb r7, [r0] + 13a0: e28c1002 add r1, r12, #2 + 13a4: e5d18000 ldrb r8, [r1] + 13a8: e3888010 orr r8, r8, #16 ; 0x10 + 13ac: e5c18000 strb r8, [r1] + 13b0: e5c09000 strb r9, [r0] + 13b4: e5c14000 strb r4, [r1] + 13b8: e5c07000 strb r7, [r0] + 13bc: e5cca000 strb r10, [r12] + 13c0: e5cc5001 strb r5, [r12, #1] + 13c4: e5c0b000 strb r11, [r0] + 13c8: e5c35000 strb r5, [r3] + 13cc: e2522001 subs r2, r2, #1 + 13d0: 1affffed bne 0x138c + 13d4: e8bd8ff0 ldmia sp!, {r4, r5, r6, r7, r8, r9, r10, r11, pc} + +; 0x13d8 routine matches C035 version + 13d8: e59fc0ac ldr r12, =0x1fe8 ; via 0x148c + 13dc: e79c2101 ldr r2, [r12, r1, lsl #2] + 13e0: e282c005 add r12, r2, #5 + 13e4: e5dc1000 ldrb r1, [r12] + 13e8: e3110040 tst r1, #64 ; 0x40 + 13ec: 0afffffc beq 0x13e4 + 13f0: e282c003 add r12, r2, #3 + 13f4: e5dc1000 ldrb r1, [r12] + 13f8: e3811080 orr r1, r1, #128 ; 0x80 + 13fc: e5cc1000 strb r1, [r12] + 1400: e59f108c ldr r1, =0x1ff0 ; via 0x1494 + 1404: e7d13080 ldrb r3, [r1, r0, lsl #1] + 1408: e5c23001 strb r3, [r2, #1] + 140c: e0810080 add r0, r1, r0, lsl #1 + 1410: e5d00001 ldrb r0, [r0, #1] + 1414: e5c20000 strb r0, [r2] + 1418: e5dc0000 ldrb r0, [r12] + 141c: e200007f and r0, r0, #127 ; 0x7f + 1420: e5cc0000 strb r0, [r12] + 1424: e12fff1e bx lr + +; 0x1428 routine matches C035 version + 1428: e3510000 cmp r1, #0 + 142c: 1a000006 bne 0x144c + 1430: e59fc054 ldr r12, =0x1fe8 ; via 0x148c + 1434: e79cc100 ldr r12, [r12, r0, lsl #2] + 1438: e28c1005 add r1, r12, #5 + 143c: e5d10000 ldrb r0, [r1] + 1440: e1b00f80 movs r0, r0, lsl #31 + 1444: 0afffffc beq 0x143c + 1448: ea000009 b 0x1474 + 144c: e59fc038 ldr r12, =0x1fe8 ; via 0x148c + 1450: e79cc100 ldr r12, [r12, r0, lsl #2] + 1454: e28c3005 add r3, r12, #5 + 1458: e5d30000 ldrb r0, [r3] + 145c: e1b00f80 movs r0, r0, lsl #31 + 1460: 1a000001 bne 0x146c + 1464: e2511001 subs r1, r1, #1 + 1468: 1afffffa bne 0x1458 + 146c: e3510000 cmp r1, #0 + 1470: 0a000003 beq 0x1484 + 1474: e5dcc000 ldrb r12, [r12] + 1478: e5c2c000 strb r12, [r2] + 147c: e3a00001 mov r0, #1 + 1480: e12fff1e bx lr + 1484: e3a00000 mov r0, #0 + 1488: e12fff1e bx lr + +; literal pool + 148c: 00001fe8 + 1490: ffff6000 + 1494: 00001ff0 + +; Real differences from the C035 version begin here + + 1498: eafffffe b 0x1498 + 149c: eafffffe b 0x149c + 14a0: eafffffe b 0x14a0 + 14a4: eafffffe b 0x14a4 + 14a8: eafffffe b 0x14a8 + 14ac: eafffffe b 0x14ac + 14b0: eafffffe b 0x14b0 + +; Bogus interrupt/exception handlers + + 14b4: e92d4010 stmdb sp!, {r4, lr} + 14b8: e59fc080 ldr r12, =0x800000 ; via 0x1540 + 14bc: e59c4000 ldr r4, [r12] + 14c0: eb00009a bl 0x1730 + 14c4: e8bd8010 ldmia sp!, {r4, pc} + + 14c8: e92d4010 stmdb sp!, {r4, lr} + 14cc: e59fc070 ldr r12, =0x800004 ; via 0x1544 + 14d0: e59c4000 ldr r4, [r12] + 14d4: eb000095 bl 0x1730 + 14d8: e8bd8010 ldmia sp!, {r4, pc} + + 14dc: e92d4010 stmdb sp!, {r4, lr} + 14e0: e59fc060 ldr r12, =0x800008 ; via 0x1548 + 14e4: e59c4000 ldr r4, [r12] + 14e8: eb000090 bl 0x1730 + 14ec: e8bd8010 ldmia sp!, {r4, pc} + + 14f0: e92d4010 stmdb sp!, {r4, lr} + 14f4: e59fc050 ldr r12, =0x80000c ; via 0x154c + 14f8: e59c4000 ldr r4, [r12] + 14fc: eb00008b bl 0x1730 + 1500: e8bd8010 ldmia sp!, {r4, pc} + + 1504: e92d4010 stmdb sp!, {r4, lr} + 1508: e59fc040 ldr r12, =0x800010 ; via 0x1550 + 150c: e59c4000 ldr r4, [r12] + 1510: eb000086 bl 0x1730 + 1514: e8bd8010 ldmia sp!, {r4, pc} + + 1518: e92d4010 stmdb sp!, {r4, lr} + 151c: e59fc030 ldr r12, =0x800014 ; via 0x1554 + 1520: e59c4000 ldr r4, [r12] + 1524: eb000081 bl 0x1730 + 1528: e8bd8010 ldmia sp!, {r4, pc} + + 152c: e92d4010 stmdb sp!, {r4, lr} + 1530: e59fc020 ldr r12, =0x800018 ; via 0x1558 + 1534: e59c4000 ldr r4, [r12] + 1538: eb00007c bl 0x1730 + 153c: e8bd8010 ldmia sp!, {r4, pc} + +; literal pool for the above bogosity + 1540: 00800000 + 1544: 00800004 + 1548: 00800008 + 154c: 0080000c + 1550: 00800010 + 1554: 00800014 + 1558: 00800018 + +; RESET entry continues here right after setting SP +; the STUPID switch to user mode happens here + 155c: e10f0000 mrs r0, CPSR + 1560: e3c0001f bic r0, r0, #31 ; 0x1f + 1564: e3800010 orr r0, r0, #16 ; 0x10 + 1568: e129f000 msr CPSR_fc, r0 + 156c: e28f0001 add r0, pc, #1 + 1570: e12fff10 bx r0 + 1574: 4818 ldr r0, =0x8005ac ; via 0x15d8 + 1576: 4685 mov sp, r0 + 1578: 4818 ldr r0, =0x190 ; via 0x15dc + 157a: 4485 add sp, r0 + 157c: 4818 ldr r0, =0x1794 ; via 0x15e0 + 157e: 2101 mov r1, #1 + 1580: 42c8 cmn r0, r1 + 1582: d001 beq 0x1588 + 1584: f000 f806 bl 0x1594 ; "auto init" + 1588: f000 f8f0 bl 0x176c ; main() +; the following is a call to some "post-main" function +; which became a tight loop (b .) in the C035 version + 158c: 2001 mov r0, #1 + 158e: f000 f867 bl 0x1660 + 1592: e7fe b 0x1592 + +; Thumb version of TI's "auto init" function + 1594: 2503 mov r5, #3 + 1596: e01a b 0x15ce + 1598: 6841 ldr r1, [r0, #4] + 159a: 3008 add r0, #8 + 159c: 4229 tst r1, r5 + 159e: d10c bne 0x15ba + 15a0: 1c1a add r2, r3, #0 + 15a2: 43aa bic r2, r5 + 15a4: d009 beq 0x15ba + 15a6: 1f12 sub r2, r2, #4 + 15a8: 5884 ldr r4, [r0, r2] + 15aa: 508c str r4, [r1, r2] + 15ac: d1fb bne 0x15a6 + 15ae: 1c1a add r2, r3, #0 + 15b0: 43aa bic r2, r5 + 15b2: 1880 add r0, r0, r2 + 15b4: 402b and r3, r5 + 15b6: d006 beq 0x15c6 + 15b8: 1889 add r1, r1, r2 + 15ba: 1c1a add r2, r3, #0 + 15bc: 1e52 sub r2, r2, #1 + 15be: 5c84 ldrb r4, [r0, r2] + 15c0: 548c strb r4, [r1, r2] + 15c2: d1fb bne 0x15bc + 15c4: 18c0 add r0, r0, r3 + 15c6: 4228 tst r0, r5 + 15c8: d001 beq 0x15ce + 15ca: 43a8 bic r0, r5 + 15cc: 3004 add r0, #4 + 15ce: 6803 ldr r3, [r0, #0] + 15d0: 2b00 cmp r3, #0 + 15d2: d1e1 bne 0x1598 + 15d4: 46f7 mov pc, lr + 15d6: 0000 + +; literal pool + 15d8: 008005ac + 15dc: 00000190 + 15e0: 00001794 + +; Routine corresponds to 0x158c in C035 version + 15e4: e92d4010 stmdb sp!, {r4, lr} + 15e8: e1a04000 mov r4, r0 + 15ec: e1b0c0a4 movs r12, r4, lsr #1 + 15f0: 0a000001 beq 0x15fc + 15f4: e3a00001 mov r0, #1 + 15f8: e8bd8010 ldmia sp!, {r4, pc} + 15fc: e59f0054 ldr r0, =0xfffffb10 ; via 0x1658 + 1600: e1d0c0b0 ldrh r12, [r0] + 1604: e20c20ff and r2, r12, #255 ; 0xff + 1608: e20ccb3f and r12, r12, #64512 ; 0xfc00 + 160c: e182c00c orr r12, r2, r12 + 1610: e1a0c80c mov r12, r12, lsl #16 + 1614: e1a0c82c mov r12, r12, lsr #16 + 1618: e3540000 cmp r4, #0 + 161c: 1a000004 bne 0x1634 + 1620: e38ccc01 orr r12, r12, #256 ; 0x100 + 1624: e1c0c0b0 strh r12, [r0] + 1628: e1a04001 mov r4, r1 + 162c: eb00003f bl 0x1730 + 1630: e8bd8010 ldmia sp!, {r4, pc} + 1634: e3540001 cmp r4, #1 + 1638: 18bd8010 ldmneia sp!, {r4, pc} + 163c: e3a00020 mov r0, #32 ; 0x20 + 1640: e3a010cc mov r1, #204 ; 0xcc + 1644: e59f2010 ldr r2, =0x800020 ; via 0x165c + 1648: eb000040 bl 0x1750 + 164c: e1a00004 mov r0, r4 + 1650: eb1ffa72 bl 0x800020 + 1654: e8bd8010 ldmia sp!, {r4, pc} + +; literal pool + 1658: fffffb10 + 165c: 00800020 + +; this weird function would gain control if main() returned +; it seems to be an exit() implementation that does atexit processing + 1660: b570 push {r4, r5, r6, lr} + 1662: 4812 ldr r0, =0x800520 ; via 0x16ac + 1664: 6806 ldr r6, [r0, #0] + 1666: 2e00 cmp r6, #0 + 1668: d009 beq 0x167e + 166a: 4911 ldr r1, =0x800528 ; via 0x16b0 + 166c: 00b0 lsl r0, r6, #2 + 166e: 180d add r5, r1, r0 + 1670: 3d04 sub r5, #4 + 1672: 682c ldr r4, [r5, #0] + 1674: f000 f884 bl 0x1780 + 1678: 3e01 sub r6, #1 + 167a: 2e00 cmp r6, #0 + 167c: d1f8 bne 0x1670 + 167e: 480d ldr r0, =0x800524 ; via 0x16b4 + 1680: 6804 ldr r4, [r0, #0] + 1682: 2c00 cmp r4, #0 + 1684: d001 beq 0x168a + 1686: f000 f87b bl 0x1780 + 168a: 46c0 nop (mov r8, r8) + 168c: e7fe b 0x168c + +; appears to be atexit(), never called + 168e: b510 push {r4, lr} + 1690: 4a06 ldr r2, =0x800520 ; via 0x16ac + 1692: 6811 ldr r1, [r2, #0] + 1694: 2920 cmp r1, #32 ; 0x20 + 1696: db01 blt 0x169c + 1698: 2001 mov r0, #1 + 169a: bd10 pop {r4, pc} + 169c: 4c04 ldr r4, =0x800528 ; via 0x16b0 + 169e: 008b lsl r3, r1, #2 + 16a0: 50e0 str r0, [r4, r3] + 16a2: 1c48 add r0, r1, #1 + 16a4: 6010 str r0, [r2, #0] + 16a6: 2000 mov r0, #0 + 16a8: bd10 pop {r4, pc} + + 16aa: e7fe b 0x16aa + +; literal pool + 16ac: 00800520 + 16b0: 00800528 + 16b4: 00800524 + +; Checksum function listed in CAL228 document + 16b8: e92d4000 stmdb sp!, {lr} + 16bc: e24dd008 sub sp, sp, #8 + 16c0: e3500001 cmp r0, #1 + 16c4: 1a000006 bne 0x16e4 + 16c8: e3a0c002 mov r12, #2 + 16cc: e5cdc000 strb r12, [sp] + 16d0: e3a00004 mov r0, #4 + 16d4: e3a01000 mov r1, #0 + 16d8: e3a02000 mov r2, #0 + 16dc: e3a03002 mov r3, #2 + 16e0: ebfffdd1 bl 0xe2c + 16e4: e3a00000 mov r0, #0 + 16e8: e3a0c000 mov r12, #0 + 16ec: e0dc10b2 ldrh r1, [r12], #2 + 16f0: e0810000 add r0, r1, r0 + 16f4: e1a00800 mov r0, r0, lsl #16 + 16f8: e1a00820 mov r0, r0, lsr #16 + 16fc: e35c0a02 cmp r12, #8192 ; 0x2000 + 1700: 3afffff9 bcc 0x16ec + 1704: e28dd008 add sp, sp, #8 + 1708: e8bd8000 ldmia sp!, {pc} + +; RESET entry point jumps here + 170c: e59f0014 ldr r0, =0x8005ac ; via 0x1728 + 1710: e59f1014 ldr r1, =0x190 ; via 0x172c + 1714: e2411004 sub r1, r1, #4 + 1718: e0802001 add r2, r0, r1 + 171c: e3c22003 bic r2, r2, #3 + 1720: e1a0d002 mov sp, r2 + 1724: eaffff8c b 0x155c + +; literal pool + 1728: 008005ac + 172c: 00000190 + +; TI compiler's IND_CALL library helper + 1730: e3140001 tst r4, #1 + 1734: 1a000000 bne 0x173c + 1738: e12fff14 bx r4 + 173c: e1a0c004 mov r12, r4 + 1740: e1a0400e mov r4, lr + 1744: e28fe001 add lr, pc, #1 + 1748: e12fff1c bx r12 + 174c: 4720 bx r4 + 174e: 46c0 nop (mov r8, r8) + +; memory copy function like 0x165c in the C035 version + 1750: e3510000 cmp r1, #0 + 1754: 012fff1e bxeq lr + 1758: e490c004 ldr r12, [r0], #4 + 175c: e482c004 str r12, [r2], #4 + 1760: e2511004 subs r1, r1, #4 + 1764: 1afffffb bne 0x1758 + 1768: e12fff1e bx lr + +; Thumb->ARM call veneer for the main() function + 176c: 4778 bx pc + 176e: 46c0 nop (mov r8, r8) + 1770: e92d4000 stmdb sp!, {lr} + 1774: ebfffe97 bl 0x11d8 + 1778: e8bd4000 ldmia sp!, {lr} + 177c: e12fff1e bx lr + +; TI compiler's IND$CALL library helper + 1780: 46a4 mov r12, r4 + 1782: 0864 lsr r4, r4, #1 + 1784: d301 bcc 0x178a + 1786: 4760 bx r12 + 1788: 46c0 nop (mov r8, r8) + 178a: 4674 mov r4, lr + 178c: 46fe mov lr, pc + 178e: 4760 bx r12 + 1790: e12fff14 bx r4 + +; "auto init" table (.cinit section) + 1794: 0000001c + 1798: 00800000 + 179c: 00001498 + 17a0: 0000149c + 17a4: 000014a0 + 17a8: 000014a4 + 17ac: 000014a8 + 17b0: 000014ac + 17b4: 000014b0 + 17b8: 00000004 + 17bc: 008000f0 + 17c0: 0001d4c0 + 17c4: 00000001 + 17c8: 008000f4 + 17cc: 00000001 + 17d0: 00000004 + 17d4: 00800520 + 17d8: 00000000 + 17dc: 00000004 + 17e0: 00800524 + 17e4: 00000000 + 17e8: 00000001 + 17ec: 008005a8 + 17f0: 00000000 + 17f4: 00000000 + +; filler +000017F0: 00 00 00 00 00 00 00 00 F0 EF EE ED EC EB EA E9 ................ +00001800: E8 E7 E6 E5 E4 E3 E2 E1 E0 DF DE DD DC DB DA D9 ................ +00001810: D8 D7 D6 D5 D4 D3 D2 D1 D0 CF CE CD CC CB CA C9 ................ +00001820: C8 C7 C6 C5 C4 C3 C2 C1 C0 BF BE BD BC BB BA B9 ................ +00001830: B8 B7 B6 B5 B4 B3 B2 B1 B0 AF AE AD AC AB AA A9 ................ +00001840: A8 A7 A6 A5 A4 A3 A2 A1 A0 9F 9E 9D 9C 9B 9A 99 ................ +00001850: 98 97 96 95 94 93 92 91 90 8F 8E 8D 8C 8B 8A 89 ................ +00001860: 88 87 86 85 84 83 82 81 80 7F 7E 7D 7C 7B 7A 79 ..........~}|{zy +00001870: 78 77 76 75 74 73 72 71 70 6F 6E 6D 6C 6B 6A 69 xwvutsrqponmlkji +00001880: 68 67 66 65 64 63 62 61 60 5F 5E 5D 5C 5B 5A 59 hgfedcba`_^]\[ZY +00001890: 58 57 56 55 54 53 52 51 50 4F 4E 4D 4C 4B 4A 49 XWVUTSRQPONMLKJI +000018A0: 48 47 46 45 44 43 42 41 40 3F 3E 3D 3C 3B 3A 39 HGFEDCBA@?>=<;:9 +000018B0: 38 37 36 35 34 33 32 31 30 2F 2E 2D 2C 2B 2A 29 876543210/.-,+*) +000018C0: 28 27 26 25 24 23 22 21 20 1F 1E 1D 1C 1B 1A 19 ('&%$#"! ....... +000018D0: 18 17 16 15 14 13 12 11 10 0F 0E 0D 0C 0B 0A 09 ................ +000018E0: 08 07 06 05 04 03 02 01 00 FF FE FD FC FB FA F9 ................ +000018F0: F8 F7 F6 F5 F4 F3 F2 F1 F0 EF EE ED EC EB EA E9 ................ +00001900: E8 E7 E6 E5 E4 E3 E2 E1 E0 DF DE DD DC DB DA D9 ................ +00001910: D8 D7 D6 D5 D4 D3 D2 D1 D0 CF CE CD CC CB CA C9 ................ +00001920: C8 C7 C6 C5 C4 C3 C2 C1 C0 BF BE BD BC BB BA B9 ................ +00001930: B8 B7 B6 B5 B4 B3 B2 B1 B0 AF AE AD AC AB AA A9 ................ +00001940: A8 A7 A6 A5 A4 A3 A2 A1 A0 9F 9E 9D 9C 9B 9A 99 ................ +00001950: 98 97 96 95 94 93 92 91 90 8F 8E 8D 8C 8B 8A 89 ................ +00001960: 88 87 86 85 84 83 82 81 80 7F 7E 7D 7C 7B 7A 79 ..........~}|{zy +00001970: 78 77 76 75 74 73 72 71 70 6F 6E 6D 6C 6B 6A 69 xwvutsrqponmlkji +00001980: 68 67 66 65 64 63 62 61 60 5F 5E 5D 5C 5B 5A 59 hgfedcba`_^]\[ZY +00001990: 58 57 56 55 54 53 52 51 50 4F 4E 4D 4C 4B 4A 49 XWVUTSRQPONMLKJI +000019A0: 48 47 46 45 44 43 42 41 40 3F 3E 3D 3C 3B 3A 39 HGFEDCBA@?>=<;:9 +000019B0: 38 37 36 35 34 33 32 31 30 2F 2E 2D 2C 2B 2A 29 876543210/.-,+*) +000019C0: 28 27 26 25 24 23 22 21 20 1F 1E 1D 1C 1B 1A 19 ('&%$#"! ....... +000019D0: 18 17 16 15 14 13 12 11 10 0F 0E 0D 0C 0B 0A 09 ................ +000019E0: 08 07 06 05 04 03 02 01 00 FF FE FD FC FB FA F9 ................ +000019F0: F8 F7 F6 F5 F4 F3 F2 F1 F0 EF EE ED EC EB EA E9 ................ +00001A00: E8 E7 E6 E5 E4 E3 E2 E1 E0 DF DE DD DC DB DA D9 ................ +00001A10: D8 D7 D6 D5 D4 D3 D2 D1 D0 CF CE CD CC CB CA C9 ................ +00001A20: C8 C7 C6 C5 C4 C3 C2 C1 C0 BF BE BD BC BB BA B9 ................ +00001A30: B8 B7 B6 B5 B4 B3 B2 B1 B0 AF AE AD AC AB AA A9 ................ +00001A40: A8 A7 A6 A5 A4 A3 A2 A1 A0 9F 9E 9D 9C 9B 9A 99 ................ +00001A50: 98 97 96 95 94 93 92 91 90 8F 8E 8D 8C 8B 8A 89 ................ +00001A60: 88 87 86 85 84 83 82 81 80 7F 7E 7D 7C 7B 7A 79 ..........~}|{zy +00001A70: 78 77 76 75 74 73 72 71 70 6F 6E 6D 6C 6B 6A 69 xwvutsrqponmlkji +00001A80: 68 67 66 65 64 63 62 61 60 5F 5E 5D 5C 5B 5A 59 hgfedcba`_^]\[ZY +00001A90: 58 57 56 55 54 53 52 51 50 4F 4E 4D 4C 4B 4A 49 XWVUTSRQPONMLKJI +00001AA0: 48 47 46 45 44 43 42 41 40 3F 3E 3D 3C 3B 3A 39 HGFEDCBA@?>=<;:9 +00001AB0: 38 37 36 35 34 33 32 31 30 2F 2E 2D 2C 2B 2A 29 876543210/.-,+*) +00001AC0: 28 27 26 25 24 23 22 21 20 1F 1E 1D 1C 1B 1A 19 ('&%$#"! ....... +00001AD0: 18 17 16 15 14 13 12 11 10 0F 0E 0D 0C 0B 0A 09 ................ +00001AE0: 08 07 06 05 04 03 02 01 00 FF FE FD FC FB FA F9 ................ +00001AF0: F8 F7 F6 F5 F4 F3 F2 F1 F0 EF EE ED EC EB EA E9 ................ +00001B00: E8 E7 E6 E5 E4 E3 E2 E1 E0 DF DE DD DC DB DA D9 ................ +00001B10: D8 D7 D6 D5 D4 D3 D2 D1 D0 CF CE CD CC CB CA C9 ................ +00001B20: C8 C7 C6 C5 C4 C3 C2 C1 C0 BF BE BD BC BB BA B9 ................ +00001B30: B8 B7 B6 B5 B4 B3 B2 B1 B0 AF AE AD AC AB AA A9 ................ +00001B40: A8 A7 A6 A5 A4 A3 A2 A1 A0 9F 9E 9D 9C 9B 9A 99 ................ +00001B50: 98 97 96 95 94 93 92 91 90 8F 8E 8D 8C 8B 8A 89 ................ +00001B60: 88 87 86 85 84 83 82 81 80 7F 7E 7D 7C 7B 7A 79 ..........~}|{zy +00001B70: 78 77 76 75 74 73 72 71 70 6F 6E 6D 6C 6B 6A 69 xwvutsrqponmlkji +00001B80: 68 67 66 65 64 63 62 61 60 5F 5E 5D 5C 5B 5A 59 hgfedcba`_^]\[ZY +00001B90: 58 57 56 55 54 53 52 51 50 4F 4E 4D 4C 4B 4A 49 XWVUTSRQPONMLKJI +00001BA0: 48 47 46 45 44 43 42 41 40 3F 3E 3D 3C 3B 3A 39 HGFEDCBA@?>=<;:9 +00001BB0: 38 37 36 35 34 33 32 31 30 2F 2E 2D 2C 2B 2A 29 876543210/.-,+*) +00001BC0: 28 27 26 25 24 23 22 21 20 1F 1E 1D 1C 1B 1A 19 ('&%$#"! ....... +00001BD0: 18 17 16 15 14 13 12 11 10 0F 0E 0D 0C 0B 0A 09 ................ +00001BE0: 08 07 06 05 04 03 02 01 00 FF FE FD FC FB FA F9 ................ +00001BF0: F8 F7 F6 F5 F4 F3 F2 F1 F0 EF EE ED EC EB EA E9 ................ +00001C00: E8 E7 E6 E5 E4 E3 E2 E1 E0 DF DE DD DC DB DA D9 ................ +00001C10: D8 D7 D6 D5 D4 D3 D2 D1 D0 CF CE CD CC CB CA C9 ................ +00001C20: C8 C7 C6 C5 C4 C3 C2 C1 C0 BF BE BD BC BB BA B9 ................ +00001C30: B8 B7 B6 B5 B4 B3 B2 B1 B0 AF AE AD AC AB AA A9 ................ +00001C40: A8 A7 A6 A5 A4 A3 A2 A1 A0 9F 9E 9D 9C 9B 9A 99 ................ +00001C50: 98 97 96 95 94 93 92 91 90 8F 8E 8D 8C 8B 8A 89 ................ +00001C60: 88 87 86 85 84 83 82 81 80 7F 7E 7D 7C 7B 7A 79 ..........~}|{zy +00001C70: 78 77 76 75 74 73 72 71 70 6F 6E 6D 6C 6B 6A 69 xwvutsrqponmlkji +00001C80: 68 67 66 65 64 63 62 61 60 5F 5E 5D 5C 5B 5A 59 hgfedcba`_^]\[ZY +00001C90: 58 57 56 55 54 53 52 51 50 4F 4E 4D 4C 4B 4A 49 XWVUTSRQPONMLKJI +00001CA0: 48 47 46 45 44 43 42 41 40 3F 3E 3D 3C 3B 3A 39 HGFEDCBA@?>=<;:9 +00001CB0: 38 37 36 35 34 33 32 31 30 2F 2E 2D 2C 2B 2A 29 876543210/.-,+*) +00001CC0: 28 27 26 25 24 23 22 21 20 1F 1E 1D 1C 1B 1A 19 ('&%$#"! ....... +00001CD0: 18 17 16 15 14 13 12 11 10 0F 0E 0D 0C 0B 0A 09 ................ +00001CE0: 08 07 06 05 04 03 02 01 00 FF FE FD FC FB FA F9 ................ +00001CF0: F8 F7 F6 F5 F4 F3 F2 F1 F0 EF EE ED EC EB EA E9 ................ +00001D00: E8 E7 E6 E5 E4 E3 E2 E1 E0 DF DE DD DC DB DA D9 ................ +00001D10: D8 D7 D6 D5 D4 D3 D2 D1 D0 CF CE CD CC CB CA C9 ................ +00001D20: C8 C7 C6 C5 C4 C3 C2 C1 C0 BF BE BD BC BB BA B9 ................ +00001D30: B8 B7 B6 B5 B4 B3 B2 B1 B0 AF AE AD AC AB AA A9 ................ +00001D40: A8 A7 A6 A5 A4 A3 A2 A1 A0 9F 9E 9D 9C 9B 9A 99 ................ +00001D50: 98 97 96 95 94 93 92 91 90 8F 8E 8D 8C 8B 8A 89 ................ +00001D60: 88 87 86 85 84 83 82 81 80 7F 7E 7D 7C 7B 7A 79 ..........~}|{zy +00001D70: 78 77 76 75 74 73 72 71 70 6F 6E 6D 6C 6B 6A 69 xwvutsrqponmlkji +00001D80: 68 67 66 65 64 63 62 61 60 5F 5E 5D 5C 5B 5A 59 hgfedcba`_^]\[ZY +00001D90: 58 57 56 55 54 53 52 51 50 4F 4E 4D 4C 4B 4A 49 XWVUTSRQPONMLKJI +00001DA0: 48 47 46 45 44 43 42 41 40 3F 3E 3D 3C 3B 3A 39 HGFEDCBA@?>=<;:9 +00001DB0: 38 37 36 35 34 33 32 31 30 2F 2E 2D 2C 2B 2A 29 876543210/.-,+*) +00001DC0: 28 27 26 25 24 23 22 21 20 1F 1E 1D 1C 1B 1A 19 ('&%$#"! ....... +00001DD0: 18 17 16 15 14 13 12 11 10 0F 0E 0D 0C 0B 0A 09 ................ +00001DE0: 08 07 06 05 04 03 02 01 00 FF FE FD FC FB FA F9 ................ +00001DF0: F8 F7 F6 F5 F4 F3 F2 F1 F0 EF EE ED EC EB EA E9 ................ +00001E00: E8 E7 E6 E5 E4 E3 E2 E1 E0 DF DE DD DC DB DA D9 ................ +00001E10: D8 D7 D6 D5 D4 D3 D2 D1 D0 CF CE CD CC CB CA C9 ................ +00001E20: C8 C7 C6 C5 C4 C3 C2 C1 C0 BF BE BD BC BB BA B9 ................ +00001E30: B8 B7 B6 B5 B4 B3 B2 B1 B0 AF AE AD AC AB AA A9 ................ +00001E40: A8 A7 A6 A5 A4 A3 A2 A1 A0 9F 9E 9D 9C 9B 9A 99 ................ +00001E50: 98 97 96 95 94 93 92 91 90 8F 8E 8D 8C 8B 8A 89 ................ +00001E60: 88 87 86 85 84 83 82 81 80 7F 7E 7D 7C 7B 7A 79 ..........~}|{zy +00001E70: 78 77 76 75 74 73 72 71 70 6F 6E 6D 6C 6B 6A 69 xwvutsrqponmlkji +00001E80: 68 67 66 65 64 63 62 61 60 5F 5E 5D 5C 5B 5A 59 hgfedcba`_^]\[ZY +00001E90: 58 57 56 55 54 53 52 51 50 4F 4E 4D 4C 4B 4A 49 XWVUTSRQPONMLKJI +00001EA0: 48 47 46 45 44 43 42 41 40 3F 3E 3D 3C 3B 3A 39 HGFEDCBA@?>=<;:9 +00001EB0: 38 37 36 35 34 33 32 31 30 2F 2E 2D 2C 2B 2A 29 876543210/.-,+*) +00001EC0: 28 27 26 25 24 23 22 21 20 1F 1E 1D 1C 1B 1A 19 ('&%$#"! ....... +00001ED0: 18 17 16 15 14 13 12 11 10 0F 0E 0D 0C 0B 0A 09 ................ +00001EE0: 08 07 06 05 04 03 02 01 00 FF FE FD FC FB FA F9 ................ +00001EF0: F8 F7 F6 F5 F4 F3 F2 F1 F0 EF EE ED EC EB EA E9 ................ +00001F00: E8 E7 E6 E5 E4 E3 E2 E1 E0 DF DE DD DC DB DA D9 ................ +00001F10: D8 D7 D6 D5 D4 D3 D2 D1 D0 CF CE CD CC CB CA C9 ................ +00001F20: C8 C7 C6 C5 C4 C3 C2 C1 C0 BF BE BD BC BB BA B9 ................ +00001F30: B8 B7 B6 B5 B4 B3 B2 B1 B0 AF AE AD AC AB AA A9 ................ +00001F40: A8 A7 A6 A5 A4 A3 A2 A1 A0 9F 9E 9D 9C 9B 9A 99 ................ +00001F50: 98 97 96 95 94 93 92 91 90 8F 8E 8D 8C 8B 8A 89 ................ +00001F60: 88 87 86 85 84 83 82 81 80 7F 7E 7D 7C 7B 7A 79 ..........~}|{zy +00001F70: 78 77 76 75 74 73 72 71 70 6F 6E 6D 6C 6B 6A 69 xwvutsrqponmlkji +00001F80: 68 67 66 65 64 63 62 61 60 5F 5E 5D 5C 5B 5A 59 hgfedcba`_^]\[ZY +00001F90: 58 57 56 55 54 53 52 51 50 4F 4E 4D 4C 4B 4A 49 XWVUTSRQPONMLKJI +00001FA0: 48 47 46 45 44 43 42 41 40 3F 3E 3D 3C 3B 3A 39 HGFEDCBA@?>=<;:9 +00001FB0: 38 37 36 35 34 33 32 31 30 2F 2E 2D 2C 2B 2A 29 876543210/.-,+*) +00001FC0: 28 27 26 25 24 23 22 21 20 1F 1E 1D 1C 1B 1A 19 ('&%$#"! ....... +00001FD0: 18 17 16 15 14 13 12 11 10 0F 0E 0D 0C 0B 0A 09 ................ +00001FE0: 08 07 06 05 04 03 02 01 00 58 FF FF 00 50 FF FF .........X...P.. +00001FF0: 00 07 00 0E 00 15 00 1C 00 2A 00 00 00 00 00 02 .........*...... + +; base addresses of the two UARTs + 1fe8: ffff5800 + 1fec: ffff5000 + +; UART baud rates + 1ff0: 0700 + 1ff2: 0e00 + 1ff4: 1500 + 1ff6: 1c00 + 1ff8: 2a00 + 1ffa: 0000 + 1ffc: 0000 +; Boot ROM version + 1ffe: 0200