參考資訊:
https://linux-sunxi.org/BROM
https://github.com/hno/Allwinner-Info/tree/master/BROM
BROM: ffff4000: ea000006 b start ffff4004: "eGON.BRM ",0 ffff4010: "110011001623",0 start: ffff4020: e30004e2 movw r0, #0x4e2 ; r0 = 1250; ffff4024: e2500001 subs r0, r0, #0x1 ; r0 = r0 - 1; ffff4028: 1afffffd bne 0xffff4024 ; loop until r0 reaches 0 ffff402c: e10f0000 mrs r0, CPSR ; read current program status register ffff4030: e3c0001f bic r0, r0, #0x1f ; load System (ARMv4+) R0-R14, CPSR, PC as MASK ffff4034: e3800013 orr r0, r0, #0x13 ; set SVC mode (supervisor) R0-R12, R13_svc R14_svc CPSR, SPSR_IRQ, PC ffff4038: e3800040 orr r0, r0, #0x40 ; enable FIQ interrupts ffff403c: e3c00c02 bic r0, r0, #0x200 ; set little endianess ffff4040: e121f000 msr CPSR_c, r0 ; write current program status register flag bits ffff4044: ee110f10 mrc 15, 0, r0, cr1, cr0, {0}; read from CoProcessor ffff4048: e3c00005 bic r0, r0, #0x5 ; MMU disabled, data caching disabled ffff404c: e3c00b06 bic r0, r0, #0x1800 ; program flow prediction disabled, instruction caching disabled ffff4050: ee010f10 mcr 15, 0, r0, cr1, cr0, {0}; write to CoProcessor ffff4054: e59f1050 ldr r1, =0x01c20c94 ; load WDT_MODE (watchdog timer) address ffff4058: e5912000 ldr r2, [r1] ; load WDT_MODE value ffff405c: e3c22001 bic r2, r2, #0x1 ; disable watchdog reset ffff4060: e5812000 str r2, [r1] ; store WDT_MODE register ffff4064: e59f1044 ldr r1, =0x01c20000 ; load CCM_PLL1_CFG ffff4068: e5912054 ldr r2, [r1, #0x54] ; load CCM_CPU_AXI_AHB_APB0_CFG ffff406c: e3003333 movw r3, #0x333 ; CCM_AXI_CLK_DIV = 0x11, CCM_AHB_CLK_DIV = 0x11, CCM_APB0_CLK_DIV = 0x11 ffff4070: e1c22003 bic r2, r2, r3 ; CCM_AXI_CLK_DIV = 0x00, CCM_AHB_CLK_DIV = 0x00, CCM_APB0_CLK_DIV = 0x00 ffff4074: e3a03000 mov r3, #0x0 ; r3 = 0; ffff4078: e1822003 orr r2, r2, r3 ; verify? ffff407c: e5812054 str r2, [r1, #0x54] ; store CCM_CPU_AXI_AHB_APB0_CFG ffff4080: e5912060 ldr r2, [r1, #0x60] ; load CCM_AHB_GATING0 ffff4084: e3a03040 mov r3, #0x40 ; CCM_AHB_GATE_DMA = 0x1 ffff4088: e1822003 orr r2, r2, r3 ; enable CCM_AHB_GATE_DMA in r2 ffff408c: e5812060 str r2, [r1, #0x60] ; store CCM_AHB_GATING0 ffff4090: e5912068 ldr r2, [r1, #0x68] ; load CCM_APB0_GATING ffff4094: e3a03020 mov r3, #0x20 ; CCM_APB_GATE_PIO = 0x1 ffff4098: e1822003 orr r2, r2, r3 ; enable CCM_APB_GATE_PIO in r2 ffff409c: e5812068 str r2, [r1, #0x68] ; store CCM_APB0_GATING ffff40a0: e3a0d902 mov sp, #0x8000 ; setup stackpointer to 32k (SRAM_BASE + SRAM_SIZE) ffff40a4: eb000002 bl boot ; jump to boot ffff40a8: eafffffe b 0xffff40a8 ; loop forever void main(void) { int i; int reg_val; for (i = 1250; i > 0; i--); asm("mrs r0, CPSR"); asm("bic r0, r0, #0x1f"); asm("orr r0, r0, #0x13"); asm("orr r0, r0, #0x40"); asm("bic r0, r0, #0x200"); asm("msr CPSRc, r0); asm("mrc 15, 0, r0, cr1, cr0, {0}"); asm("bic r0, r0, #0x5"); asm("bic r0, r0, #0x18000"); asm("mcr 15, 0, r0, cr1, cr0, {0}"); reg_val = readl(TMR_WDT_MODE); reg_val &= !TMR_WDT_RST; writel(reg_val, TMR_WDT_MODE); reg_val = readl(CCM_CPU_AXI_AHB_APB0_CFG); reg_val &= !(CCM_AXI_DIV(4) | CCM_AHB_CLK_DIV(8), CCM_APB0_CLK_DIV(8)); writel(reg_val, CCM_CPU_AXI_AHB_APB0_CFG); reg_val = readl(CCM_AHB_GATING0); reg_val |= CCM_AHB_GATE_DMA; writel(reg_val, CCM_AHB_gATING0); reg_val = readl(CCM_APB0_GATING); reg_val |= CCM_APB_GATE_PIO; writel(reg_val, CCM_APB0_GATING); asm("mov sp, 0x8000"); boot(); while (TRUE); } boot: ffff40b4: e92d4010 push {r4, lr} ; push r4 and link register (return address) onto the stack ffff40b8: eb0008b1 bl check_uboot ; check if uboot button is pressed, return value in r0 ffff40bc: e1a04000 mov r4, r0 ; r4 = check_uboot(); ffff40c0: e3540000 cmp r4, #0x0 ; see if check_uboot returned 0 ffff40c4: 0a000000 beq .try_boot_MMC0 ; if check_uboot was 0, try to boot from MMC0 ffff40c8: ea000016 b .boot_fel ; else boot FEL mode .try_boot_MMC0: ffff40cc: e3a00000 mov r0, #0x0 ; r0 = 0x0; (which mmc to boot, 0 = mmc0) ffff40d0: eb0003fa bl load_from_mmc ; load SPL from mmc0 ffff40d4: e1a04000 mov r4, r0 ; r4 = load_from_mmc(); ffff40d8: e3540000 cmp r4, #0x0 ; see if load_from_mmc returned 0 ffff40dc: 1a000000 bne .try_boot_NAND ; if load_from_mmc returned 0 try to boot from NAND-flash ffff40e0: ea000013 b .boot_spl ; else skip to .boot_spl .try_boot_NAND: ffff40e4: eb0004c9 bl load_from_nand ; load SPL from NAND ffff40e8: e1a04000 mov r4, r0 ; r4 = load_from_nand(); ffff40ec: e3540000 cmp r4, #0x0 ; see if load_from_nand returned 0 ffff40f0: 1a000000 bne .try_boot_MMC2 ; if load_from_nand returned 0 try to boot from MMC2 ffff40f4: ea00000e b .boot_spl ; else skip to .boot_spl .try_boot_MMC2: ffff40f8: e3a00002 mov r0, #0x2 ; r0 = 0x2; (which mmc to boot, 2 = mmc2) ffff40fc: eb0003ef bl load_from_mmc ; load SPL from mmc0 ffff4100: e1a04000 mov r4, r0 ; r4 = load_from_mmc(); ffff4104: e3540000 cmp r4, #0x0 ; see if load_from_mmc returned 0 ffff4108: 1a000000 bne .try_boot_SPINOR ; if load_from_mmc returned 0 try to boot from SPI NOR-flash ffff410c: ea000008 b .boot_spl ; else skip to .boot_spl .try_boot_SPINOR: ffff4110: eb0006e6 bl load_from_spinor ; load SPL from SPI NOR-flash ffff4114: e1a04000 mov r4, r0 ; r4 = load_from_spinor(); ffff4118: e3540000 cmp r4, #0x0 ; see if load_from_spinor returned 0 ffff411c: 1a000000 bne .none_found ; if load_from_spinor returned 0 boot from FEL mode (via .none_found) ffff4120: ea000003 b .boot ; else skip to .boot_spl .none_found: ffff4124: e320f000 nop {0} .boot_fel: ffff4128: e59f0010 ldr r0, =0xffff0020 ; load interrupt vector 'fel_setup' into r0 ffff412c: eb0008ca bl call_r0 ; execute 'fel_setup' (via call_r0) ffff4130: e320f000 nop {0} .boot_spl ffff4134: e3a00000 mov r0, #0x0 ; r0 = 0; ffff4138: eb0008c7 bl call_r0 ; execute from address 0 (SRAM_BASE, via call_r0) which was put here by load_from_* ffff413c: e8bd8010 pop {r4, pc} ; pop r4 and program counter back from th stack and return to ffff40a8 void boot(void) { int pin; pin = check_uboot(); if (!pin) if (load_from_mmc(MMC0)) call_r0(SRAM_BASE); else if (load_from_nand()) call_r0(SRAM_BASE); else if (load_from_mmc(MMC2)) call_r0(SRAM_BASE); else if (load_from_spinor()) call_r0(SRAM_BASE); call_r0(FEL_SETUP); } f_4144: ffff4144: e92d401f push {r0, r1, r2, r3, r4, lr} ffff4148: e1a04000 mov r4, r0 ffff414c: e1a0000d mov r0, sp ffff4150: e3a01000 mov r1, #0x0 ffff4154: e1a02001 mov r2, r1 ffff4158: e1a03001 mov r3, r1 ffff415c: e1a0c001 mov ip, r1 ffff4160: e880100e stm r0, {r1, r2, r3, ip} ffff4164: e3a00000 mov r0, #0x0 ffff4168: e58d0000 str r0, [sp] ffff416c: e58d0004 str r0, [sp, #0x4] ffff4170: e58d0008 str r0, [sp, #0x8] ffff4174: e59d000c ldr r0, [sp, #0xc] ffff4178: e3c0003f bic r0, r0, #0x3f ffff417c: e58d000c str r0, [sp, #0xc] ffff4180: e59d000c ldr r0, [sp, #0xc] ffff4184: e3c00b02 bic r0, r0, #0x800 ffff4188: e2800b02 add r0, r0, #0x800 ffff418c: e58d000c str r0, [sp, #0xc] ffff4190: e1a02004 mov r2, r4 ffff4194: e1a0000d mov r0, sp ffff4198: eb000311 bl f_4de4 ffff419c: e3500000 cmp r0, #0x0 ffff41a0: 0a000002 beq 0xffff41b0 ffff41a4: e3e00000 mvn r0, #0x0 ffff41a8: e28dd010 add sp, sp, #0x10 ffff41ac: e8bd8010 pop {r4, pc} ffff41b0: e3a00000 mov r0, #0x0 ffff41b4: eafffffb b 0xffff41a8 f_41b8: ffff41b8: e92d4030 push {r4, r5, lr} ffff41bc: e24dd094 sub sp, sp, #0x94 ffff41c0: e1a04000 mov r4, r0 ffff41c4: e1a05001 mov r5, r1 ffff41c8: e28d0084 add r0, sp, #0x84 ffff41cc: e3a01000 mov r1, #0x0 ffff41d0: e1a02001 mov r2, r1 ffff41d4: e1a03001 mov r3, r1 ffff41d8: e1a0c001 mov ip, r1 ffff41dc: e880100e stm r0, {r1, r2, r3, ip} ffff41e0: e3a00000 mov r0, #0x0 ffff41e4: e58d0084 str r0, [sp, #0x84] ffff41e8: e3a00002 mov r0, #0x2 ffff41ec: e58d0088 str r0, [sp, #0x88] ffff41f0: e5940008 ldr r0, [r4, #0x8] ffff41f4: e1a00800 lsl r0, r0, #0x10 ffff41f8: e58d008c str r0, [sp, #0x8c] ffff41fc: e59d0090 ldr r0, [sp, #0x90] ffff4200: e3c0003f bic r0, r0, #0x3f ffff4204: e2800007 add r0, r0, #0x7 ffff4208: e58d0090 str r0, [sp, #0x90] ffff420c: e59d0090 ldr r0, [sp, #0x90] ffff4210: e3c00040 bic r0, r0, #0x40 ffff4214: e58d0090 str r0, [sp, #0x90] ffff4218: e59d0090 ldr r0, [sp, #0x90] ffff421c: e3c00c01 bic r0, r0, #0x100 ffff4220: e2800c01 add r0, r0, #0x100 ffff4224: e58d0090 str r0, [sp, #0x90] ffff4228: e1a02005 mov r2, r5 ffff422c: e28d1004 add r1, sp, #0x4 ffff4230: e28d0084 add r0, sp, #0x84 ffff4234: eb0002ea bl f_4de4 ffff4238: e3500000 cmp r0, #0x0 ffff423c: 0a000002 beq 0xffff424c ffff4240: e3e00000 mvn r0, #0x0 ffff4244: e28dd094 add sp, sp, #0x94 ffff4248: e8bd8030 pop {r4, r5, pc} ffff424c: e3a00000 mov r0, #0x0 ffff4250: eafffffb b 0xffff4244 f_4254: ffff4254: e92d4030 push {r4, r5, lr} ffff4258: e24dd094 sub sp, sp, #0x94 ffff425c: e1a04000 mov r4, r0 ffff4260: e1a05001 mov r5, r1 ffff4264: e28d0084 add r0, sp, #0x84 ffff4268: e3a01000 mov r1, #0x0 ffff426c: e1a02001 mov r2, r1 ffff4270: e1a03001 mov r3, r1 ffff4274: e1a0c001 mov ip, r1 ffff4278: e880100e stm r0, {r1, r2, r3, ip} ffff427c: e1a00005 mov r0, r5 ffff4280: ebffffaf bl f_4144 ffff4284: e3500000 cmp r0, #0x0 ffff4288: 0a000002 beq 0xffff4298 ffff428c: e3e00000 mvn r0, #0x0 ffff4290: e28dd094 add sp, sp, #0x94 ffff4294: e8bd8030 pop {r4, r5, pc} ffff4298: e3a00000 mov r0, #0x0 ffff429c: e58d0084 str r0, [sp, #0x84] ffff42a0: e3a00001 mov r0, #0x1 ffff42a4: e58d0088 str r0, [sp, #0x88] ffff42a8: e30001aa movw r0, #0x1aa ffff42ac: e58d008c str r0, [sp, #0x8c] ffff42b0: e59d0090 ldr r0, [sp, #0x90] ffff42b4: e3c0003f bic r0, r0, #0x3f ffff42b8: e2800008 add r0, r0, #0x8 ffff42bc: e58d0090 str r0, [sp, #0x90] ffff42c0: e1a02005 mov r2, r5 ffff42c4: e28d1004 add r1, sp, #0x4 ffff42c8: e28d0084 add r0, sp, #0x84 ffff42cc: eb0002c4 bl f_4de4 ffff42d0: e3500000 cmp r0, #0x0 ffff42d4: 1a000008 bne 0xffff42fc ffff42d8: e59d0004 ldr r0, [sp, #0x4] ffff42dc: e7df061f bfc r0, #0xc, #0x14 ffff42e0: e30011aa movw r1, #0x1aa ffff42e4: e1500001 cmp r0, r1 ffff42e8: 1a000003 bne 0xffff42fc ffff42ec: e3a00001 mov r0, #0x1 ffff42f0: e5840004 str r0, [r4, #0x4] ffff42f4: e3a00000 mov r0, #0x0 ffff42f8: eaffffe4 b 0xffff4290 ffff42fc: e3a00001 mov r0, #0x1 ffff4300: e58d0084 str r0, [sp, #0x84] ffff4304: e3a00002 mov r0, #0x2 ffff4308: e58d0088 str r0, [sp, #0x88] ffff430c: e3a00000 mov r0, #0x0 ffff4310: e58d008c str r0, [sp, #0x8c] ffff4314: e59d0090 ldr r0, [sp, #0x90] ffff4318: e3c0003f bic r0, r0, #0x3f ffff431c: e2800037 add r0, r0, #0x37 ffff4320: e58d0090 str r0, [sp, #0x90] ffff4324: e1a02005 mov r2, r5 ffff4328: e28d1004 add r1, sp, #0x4 ffff432c: e28d0084 add r0, sp, #0x84 ffff4330: eb0002ab bl f_4de4 ffff4334: e3500000 cmp r0, #0x0 ffff4338: 1a000011 bne 0xffff4384 ffff433c: e3a00001 mov r0, #0x1 ffff4340: e58d0088 str r0, [sp, #0x88] ffff4344: e59f07b8 ldr r0, =0x40ff0000 ffff4348: e58d008c str r0, [sp, #0x8c] ffff434c: e59d0090 ldr r0, [sp, #0x90] ffff4350: e3c0003f bic r0, r0, #0x3f ffff4354: e2800029 add r0, r0, #0x29 ffff4358: e58d0090 str r0, [sp, #0x90] ffff435c: e1a02005 mov r2, r5 ffff4360: e28d1004 add r1, sp, #0x4 ffff4364: e28d0084 add r0, sp, #0x84 ffff4368: eb00029d bl f_4de4 ffff436c: e3500000 cmp r0, #0x0 ffff4370: 1a000003 bne 0xffff4384 ffff4374: e3a00001 mov r0, #0x1 ffff4378: e5840004 str r0, [r4, #0x4] ffff437c: e3a00000 mov r0, #0x0 ffff4380: eaffffc2 b 0xffff4290 ffff4384: e3a00002 mov r0, #0x2 ffff4388: e5840004 str r0, [r4, #0x4] ffff438c: e3a00000 mov r0, #0x0 ffff4390: eaffffbe b 0xffff4290 f_4394: ffff4394: e92d41f0 push {r4, r5, r6, r7, r8, lr} ffff4398: e24dd090 sub sp, sp, #0x90 ffff439c: e1a04000 mov r4, r0 ffff43a0: e1a05001 mov r5, r1 ffff43a4: e3a07000 mov r7, #0x0 ffff43a8: e3a080c8 mov r8, #0xc8 ffff43ac: e28d0080 add r0, sp, #0x80 ffff43b0: e3a01000 mov r1, #0x0 ffff43b4: e1a02001 mov r2, r1 ffff43b8: e1a03001 mov r3, r1 ffff43bc: e1a0c001 mov ip, r1 ffff43c0: e880100e stm r0, {r1, r2, r3, ip} ffff43c4: e1a00005 mov r0, r5 ffff43c8: ebffff5d bl f_4144 ffff43cc: e3500000 cmp r0, #0x0 ffff43d0: 0a000002 beq 0xffff43e0 ffff43d4: e3e00000 mvn r0, #0x0 ffff43d8: e28dd090 add sp, sp, #0x90 ffff43dc: e8bd81f0 pop {r4, r5, r6, r7, r8, pc} ffff43e0: e28d0080 add r0, sp, #0x80 ffff43e4: e3a01000 mov r1, #0x0 ffff43e8: e1a02001 mov r2, r1 ffff43ec: e1a03001 mov r3, r1 ffff43f0: e1a0c001 mov ip, r1 ffff43f4: e880100e stm r0, {r1, r2, r3, ip} ffff43f8: e3a00000 mov r0, #0x0 ffff43fc: e58d0080 str r0, [sp, #0x80] ffff4400: e3a00001 mov r0, #0x1 ffff4404: e58d0084 str r0, [sp, #0x84] ffff4408: e30001aa movw r0, #0x1aa ffff440c: e58d0088 str r0, [sp, #0x88] ffff4410: e59d008c ldr r0, [sp, #0x8c] ffff4414: e3c0003f bic r0, r0, #0x3f ffff4418: e2800008 add r0, r0, #0x8 ffff441c: e58d008c str r0, [sp, #0x8c] ffff4420: e1a02005 mov r2, r5 ffff4424: e1a0100d mov r1, sp ffff4428: e28d0080 add r0, sp, #0x80 ffff442c: eb00026c bl f_4de4 ffff4430: e3500000 cmp r0, #0x0 ffff4434: 1a000005 bne 0xffff4450 ffff4438: e59d0000 ldr r0, [sp] ffff443c: e7df061f bfc r0, #0xc, #0x14 ffff4440: e30011aa movw r1, #0x1aa ffff4444: e1500001 cmp r0, r1 ffff4448: 1a000000 bne 0xffff4450 ffff444c: e3a07001 mov r7, #0x1 ffff4450: ea000043 b 0xffff4564 ffff4454: e3580000 cmp r8, #0x0 ffff4458: ca000001 bgt 0xffff4464 ffff445c: e3e00000 mvn r0, #0x0 ffff4460: eaffffdc b 0xffff43d8 ffff4464: e2488001 sub r8, r8, #0x1 ffff4468: e28d0080 add r0, sp, #0x80 ffff446c: e3a01000 mov r1, #0x0 ffff4470: e1a02001 mov r2, r1 ffff4474: e1a03001 mov r3, r1 ffff4478: e1a0c001 mov ip, r1 ffff447c: e880100e stm r0, {r1, r2, r3, ip} ffff4480: e3a00001 mov r0, #0x1 ffff4484: e58d0080 str r0, [sp, #0x80] ffff4488: e3a00002 mov r0, #0x2 ffff448c: e58d0084 str r0, [sp, #0x84] ffff4490: e3a00000 mov r0, #0x0 ffff4494: e58d0088 str r0, [sp, #0x88] ffff4498: e59d008c ldr r0, [sp, #0x8c] ffff449c: e3c0003f bic r0, r0, #0x3f ffff44a0: e2800037 add r0, r0, #0x37 ffff44a4: e58d008c str r0, [sp, #0x8c] ffff44a8: e1a02005 mov r2, r5 ffff44ac: e1a0100d mov r1, sp ffff44b0: e28d0080 add r0, sp, #0x80 ffff44b4: eb00024a bl f_4de4 ffff44b8: e3500000 cmp r0, #0x0 ffff44bc: 0a000001 beq 0xffff44c8 ffff44c0: e3e00000 mvn r0, #0x0 ffff44c4: eaffffc3 b 0xffff43d8 ffff44c8: e3a00001 mov r0, #0x1 ffff44cc: e58d0084 str r0, [sp, #0x84] ffff44d0: e3570000 cmp r7, #0x0 ffff44d4: 0a000002 beq 0xffff44e4 ffff44d8: e59d0088 ldr r0, [sp, #0x88] ffff44dc: e3800101 orr r0, r0, #0x40000000 ffff44e0: e58d0088 str r0, [sp, #0x88] ffff44e4: e59d0088 ldr r0, [sp, #0x88] ffff44e8: e380073f orr r0, r0, #0xfc0000 ffff44ec: e58d0088 str r0, [sp, #0x88] ffff44f0: e59d008c ldr r0, [sp, #0x8c] ffff44f4: e3c0003f bic r0, r0, #0x3f ffff44f8: e2800029 add r0, r0, #0x29 ffff44fc: e58d008c str r0, [sp, #0x8c] ffff4500: e1a02005 mov r2, r5 ffff4504: e1a0100d mov r1, sp ffff4508: e28d0080 add r0, sp, #0x80 ffff450c: eb000234 bl f_4de4 ffff4510: e3500000 cmp r0, #0x0 ffff4514: 0a000001 beq 0xffff4520 ffff4518: e3e00000 mvn r0, #0x0 ffff451c: eaffffad b 0xffff43d8 ffff4520: e59d0000 ldr r0, [sp] ffff4524: e200073f and r0, r0, #0xfc0000 ffff4528: e350073f cmp r0, #0xfc0000 ffff452c: 0a000001 beq 0xffff4538 ffff4530: e3e00000 mvn r0, #0x0 ffff4534: eaffffa7 b 0xffff43d8 ffff4538: e3a06000 mov r6, #0x0 ffff453c: e320f000 nop {0} ffff4540: e1a00006 mov r0, r6 ffff4544: e2866001 add r6, r6, #0x1 ffff4548: e30014e2 movw r1, #0x4e2 ffff454c: e1500001 cmp r0, r1 ffff4550: 3afffffa bcc 0xffff4540 ffff4554: e59d0000 ldr r0, [sp] ffff4558: e3100102 tst r0, #-0x80000000 ; 0x80000000 ffff455c: 0a000000 beq 0xffff4564 ffff4560: ea000000 b 0xffff4568 ffff4564: eaffffba b 0xffff4454 ffff4568: e320f000 nop {0} ffff456c: e3570000 cmp r7, #0x0 ffff4570: 0a000005 beq 0xffff458c ffff4574: e59d0000 ldr r0, [sp] ffff4578: e3100101 tst r0, #0x40000000 ffff457c: 0a000002 beq 0xffff458c ffff4580: e5940004 ldr r0, [r4, #0x4] ffff4584: e3800020 orr r0, r0, #0x20 ffff4588: e5840004 str r0, [r4, #0x4] ffff458c: e3a00000 mov r0, #0x0 ffff4590: eaffff90 b 0xffff43d8 f_4594: ffff4594: e92d40f0 push {r4, r5, r6, r7, lr} ffff4598: e24dd094 sub sp, sp, #0x94 ffff459c: e1a04000 mov r4, r0 ffff45a0: e1a05001 mov r5, r1 ffff45a4: e3a070c8 mov r7, #0xc8 ffff45a8: e28d0084 add r0, sp, #0x84 ffff45ac: e3a01000 mov r1, #0x0 ffff45b0: e1a02001 mov r2, r1 ffff45b4: e1a03001 mov r3, r1 ffff45b8: e1a0c001 mov ip, r1 ffff45bc: e880100e stm r0, {r1, r2, r3, ip} ffff45c0: e1a00005 mov r0, r5 ffff45c4: ebfffede bl f_4144 ffff45c8: e3500000 cmp r0, #0x0 ffff45cc: 0a000002 beq 0xffff45dc ffff45d0: e3e00000 mvn r0, #0x0 ffff45d4: e28dd094 add sp, sp, #0x94 ffff45d8: e8bd80f0 pop {r4, r5, r6, r7, pc} ffff45dc: e3a00002 mov r0, #0x2 ffff45e0: e58d0084 str r0, [sp, #0x84] ffff45e4: e3a00001 mov r0, #0x1 ffff45e8: e58d0088 str r0, [sp, #0x88] ffff45ec: e59f0514 ldr r0, =0x40ff8000 ffff45f0: e58d008c str r0, [sp, #0x8c] ffff45f4: e59d0090 ldr r0, [sp, #0x90] ffff45f8: e3c0003f bic r0, r0, #0x3f ffff45fc: e2800001 add r0, r0, #0x1 ffff4600: e58d0090 str r0, [sp, #0x90] ffff4604: ea00001e b 0xffff4684 ffff4608: e3570000 cmp r7, #0x0 ffff460c: ca000001 bgt 0xffff4618 ffff4610: e3e00000 mvn r0, #0x0 ffff4614: eaffffee b 0xffff45d4 ffff4618: e2477001 sub r7, r7, #0x1 ffff461c: e1a02005 mov r2, r5 ffff4620: e28d1004 add r1, sp, #0x4 ffff4624: e28d0084 add r0, sp, #0x84 ffff4628: eb0001ed bl f_4de4 ffff462c: e3500000 cmp r0, #0x0 ffff4630: 0a000001 beq 0xffff463c ffff4634: e3e00000 mvn r0, #0x0 ffff4638: eaffffe5 b 0xffff45d4 ffff463c: e59d0004 ldr r0, [sp, #0x4] ffff4640: e59f14c4 ldr r1, =0x00ff8000 ffff4644: e0000001 and r0, r0, r1 ffff4648: e1500001 cmp r0, r1 ffff464c: 0a000001 beq 0xffff4658 ffff4650: e3e00000 mvn r0, #0x0 ffff4654: eaffffde b 0xffff45d4 ffff4658: e59d0004 ldr r0, [sp, #0x4] ffff465c: e3100102 tst r0, #-0x80000000 ; 0x80000000 ffff4660: 0a000000 beq 0xffff4668 ffff4664: ea000007 b 0xffff4688 ffff4668: e3a06000 mov r6, #0x0 ffff466c: e320f000 nop {0} ffff4670: e1a00006 mov r0, r6 ffff4674: e2866001 add r6, r6, #0x1 ffff4678: e30014e2 movw r1, #0x4e2 ffff467c: e1500001 cmp r0, r1 ffff4680: 3afffffa bcc 0xffff4670 ffff4684: eaffffdf b 0xffff4608 ffff4688: e320f000 nop {0} ffff468c: e59d0004 ldr r0, [sp, #0x4] ffff4690: e3100101 tst r0, #0x40000000 ffff4694: 0a000002 beq 0xffff46a4 ffff4698: e5940004 ldr r0, [r4, #0x4] ffff469c: e3800020 orr r0, r0, #0x20 ffff46a0: e5840004 str r0, [r4, #0x4] ffff46a4: e3a00000 mov r0, #0x0 ffff46a8: eaffffc9 b 0xffff45d4 f_46ac: ffff46ac: e92d4010 push {r4, lr} ffff46b0: e24dd090 sub sp, sp, #0x90 ffff46b4: e1a04000 mov r4, r0 ffff46b8: e28d0080 add r0, sp, #0x80 ffff46bc: e3a01000 mov r1, #0x0 ffff46c0: e1a02001 mov r2, r1 ffff46c4: e1a03001 mov r3, r1 ffff46c8: e1a0c001 mov ip, r1 ffff46cc: e880100e stm r0, {r1, r2, r3, ip} ffff46d0: e3a00000 mov r0, #0x0 ffff46d4: e58d0080 str r0, [sp, #0x80] ffff46d8: e3a00001 mov r0, #0x1 ffff46dc: e58d0084 str r0, [sp, #0x84] ffff46e0: e3a00000 mov r0, #0x0 ffff46e4: e58d0088 str r0, [sp, #0x88] ffff46e8: e59d008c ldr r0, [sp, #0x8c] ffff46ec: e3c0003f bic r0, r0, #0x3f ffff46f0: e2800002 add r0, r0, #0x2 ffff46f4: e58d008c str r0, [sp, #0x8c] ffff46f8: e59d008c ldr r0, [sp, #0x8c] ffff46fc: e3c00040 bic r0, r0, #0x40 ffff4700: e2800040 add r0, r0, #0x40 ffff4704: e58d008c str r0, [sp, #0x8c] ffff4708: e1a02004 mov r2, r4 ffff470c: e1a0100d mov r1, sp ffff4710: e28d0080 add r0, sp, #0x80 ffff4714: eb0001b2 bl f_4de4 ffff4718: e3500000 cmp r0, #0x0 ffff471c: 0a000002 beq 0xffff472c ffff4720: e3e00000 mvn r0, #0x0 ffff4724: e28dd090 add sp, sp, #0x90 ffff4728: e8bd8010 pop {r4, pc} ffff472c: e3a00000 mov r0, #0x0 ffff4730: eafffffb b 0xffff4724 f_4734: ffff4734: e92d4030 push {r4, r5, lr} ffff4738: e24dd094 sub sp, sp, #0x94 ffff473c: e1a04000 mov r4, r0 ffff4740: e1a05001 mov r5, r1 ffff4744: e28d0084 add r0, sp, #0x84 ffff4748: e3a01000 mov r1, #0x0 ffff474c: e1a02001 mov r2, r1 ffff4750: e1a03001 mov r3, r1 ffff4754: e1a0c001 mov ip, r1 ffff4758: e880100e stm r0, {r1, r2, r3, ip} ffff475c: e3a00000 mov r0, #0x0 ffff4760: e58d0084 str r0, [sp, #0x84] ffff4764: e3a00001 mov r0, #0x1 ffff4768: e58d0088 str r0, [sp, #0x88] ffff476c: e3a00000 mov r0, #0x0 ffff4770: e58d008c str r0, [sp, #0x8c] ffff4774: e59d0090 ldr r0, [sp, #0x90] ffff4778: e3c0003f bic r0, r0, #0x3f ffff477c: e2800003 add r0, r0, #0x3 ffff4780: e58d0090 str r0, [sp, #0x90] ffff4784: e59d0090 ldr r0, [sp, #0x90] ffff4788: e3c00040 bic r0, r0, #0x40 ffff478c: e58d0090 str r0, [sp, #0x90] ffff4790: e59d0090 ldr r0, [sp, #0x90] ffff4794: e3c00c01 bic r0, r0, #0x100 ffff4798: e2800c01 add r0, r0, #0x100 ffff479c: e58d0090 str r0, [sp, #0x90] ffff47a0: e1a02005 mov r2, r5 ffff47a4: e28d1004 add r1, sp, #0x4 ffff47a8: e28d0084 add r0, sp, #0x84 ffff47ac: eb00018c bl f_4de4 ffff47b0: e3500000 cmp r0, #0x0 ffff47b4: 0a000002 beq 0xffff47c4 ffff47b8: e3e00000 mvn r0, #0x0 ffff47bc: e28dd094 add sp, sp, #0x94 ffff47c0: e8bd8030 pop {r4, r5, pc} ffff47c4: e30f1fff movw r1, #0xffff ffff47c8: e59d0004 ldr r0, [sp, #0x4] ffff47cc: e0010820 and r0, r1, r0, lsr #0x10 ffff47d0: e5840008 str r0, [r4, #0x8] ffff47d4: e3a00000 mov r0, #0x0 ffff47d8: eafffff7 b 0xffff47bc f_47dc: ffff47dc: e92d4030 push {r4, r5, lr} ffff47e0: e24dd01c sub sp, sp, #0x1c ffff47e4: e1a04000 mov r4, r0 ffff47e8: e1a05001 mov r5, r1 ffff47ec: e3a02018 mov r2, #0x18 ffff47f0: e59f1318 ldr r1, =d_6460 ffff47f4: e28d0004 add r0, sp, #0x4 ffff47f8: eb0006f6 bl memcpy ffff47fc: e3a0003c mov r0, #0x3c ffff4800: e58d0004 str r0, [sp, #0x4] ffff4804: e1a01005 mov r1, r5 ffff4808: e28d0004 add r0, sp, #0x4 ffff480c: eb00013c bl f_4d04 ffff4810: e3500000 cmp r0, #0x0 ffff4814: 0a000002 beq 0xffff4824 ffff4818: e3e00000 mvn r0, #0x0 ffff481c: e28dd01c add sp, sp, #0x1c ffff4820: e8bd8030 pop {r4, r5, pc} ffff4824: e1a01005 mov r1, r5 ffff4828: e1a00004 mov r0, r4 ffff482c: ebfffe88 bl f_4254 ffff4830: e3500000 cmp r0, #0x0 ffff4834: 0a000001 beq 0xffff4840 ffff4838: e3e00000 mvn r0, #0x0 ffff483c: eafffff6 b 0xffff481c ffff4840: e5940004 ldr r0, [r4, #0x4] ffff4844: e3500001 cmp r0, #0x1 ffff4848: 1a000006 bne 0xffff4868 ffff484c: e1a01005 mov r1, r5 ffff4850: e1a00004 mov r0, r4 ffff4854: ebfffece bl f_4394 ffff4858: e3700001 cmn r0, #0x1 ffff485c: 1a000008 bne 0xffff4884 ffff4860: e3e00000 mvn r0, #0x0 ffff4864: eaffffec b 0xffff481c ffff4868: e1a01005 mov r1, r5 ffff486c: e1a00004 mov r0, r4 ffff4870: ebffff47 bl f_4594 ffff4874: e3700001 cmn r0, #0x1 ffff4878: 1a000001 bne 0xffff4884 ffff487c: e3e00000 mvn r0, #0x0 ffff4880: eaffffe5 b 0xffff481c ffff4884: e1a00005 mov r0, r5 ffff4888: ebffff87 bl f_46ac ffff488c: e3500000 cmp r0, #0x0 ffff4890: 0a000001 beq 0xffff489c ffff4894: e3e00000 mvn r0, #0x0 ffff4898: eaffffdf b 0xffff481c ffff489c: e1a01005 mov r1, r5 ffff48a0: e1a00004 mov r0, r4 ffff48a4: ebffffa2 bl f_4734 ffff48a8: e3500000 cmp r0, #0x0 ffff48ac: 0a000001 beq 0xffff48b8 ffff48b0: e3e00000 mvn r0, #0x0 ffff48b4: eaffffd8 b 0xffff481c ffff48b8: e5940004 ldr r0, [r4, #0x4] ffff48bc: e3c00010 bic r0, r0, #0x10 ffff48c0: e5840004 str r0, [r4, #0x4] ffff48c4: e3a00001 mov r0, #0x1 ffff48c8: e5840000 str r0, [r4] ffff48cc: e3a00000 mov r0, #0x0 ffff48d0: eaffffd1 b 0xffff481c f_48d4: ffff48d4: e92d4030 push {r4, r5, lr} ffff48d8: e24dd01c sub sp, sp, #0x1c ffff48dc: e1a04000 mov r4, r0 ffff48e0: e1a05001 mov r5, r1 ffff48e4: e1a01005 mov r1, r5 ffff48e8: e1a00004 mov r0, r4 ffff48ec: ebfffe31 bl f_41b8 ffff48f0: e3500000 cmp r0, #0x0 ffff48f4: 0a000002 beq 0xffff4904 ffff48f8: e3e00000 mvn r0, #0x0 ffff48fc: e28dd01c add sp, sp, #0x1c ffff4900: e8bd8030 pop {r4, r5, pc} ffff4904: e3a00000 mov r0, #0x0 ffff4908: e58d0004 str r0, [sp, #0x4] ffff490c: e3a00001 mov r0, #0x1 ffff4910: e58d000c str r0, [sp, #0xc] ffff4914: e3a00000 mov r0, #0x0 ffff4918: e58d0008 str r0, [sp, #0x8] ffff491c: e3a00c02 mov r0, #0x200 ffff4920: e58d0010 str r0, [sp, #0x10] ffff4924: e3e004ff mvn r0, #-0x1000000 ; 0xff000000 ffff4928: e58d0014 str r0, [sp, #0x14] ffff492c: e3a000ff mov r0, #0xff ffff4930: e58d0018 str r0, [sp, #0x18] ffff4934: e1a01005 mov r1, r5 ffff4938: e28d0004 add r0, sp, #0x4 ffff493c: eb0000f0 bl f_4d04 ffff4940: e3500000 cmp r0, #0x0 ffff4944: 0a000001 beq 0xffff4950 ffff4948: e3e00000 mvn r0, #0x0 ffff494c: eaffffea b 0xffff48fc ffff4950: e3a00000 mov r0, #0x0 ffff4954: eaffffe8 b 0xffff48fc f_4958: ffff4958: e92d4070 push {r4, r5, r6, lr} ffff495c: e1a04000 mov r4, r0 ffff4960: e1a05001 mov r5, r1 ffff4964: e1a06002 mov r6, r2 ffff4968: e1a00004 mov r0, r4 ffff496c: eb000082 bl configurePIO_MMC(n) ffff4970: e1a00006 mov r0, r6 ffff4974: eb0000a7 bl f_4c18 ffff4978: e3500000 cmp r0, #0x0 ffff497c: 0a000001 beq 0xffff4988 ffff4980: e3e00000 mvn r0, #0x0 ffff4984: e8bd8070 pop {r4, r5, r6, pc} ffff4988: e1a01006 mov r1, r6 ffff498c: e1a00005 mov r0, r5 ffff4990: ebffff91 bl f_47dc ffff4994: e3500000 cmp r0, #0x0 ffff4998: 1a000006 bne 0xffff49b8 ffff499c: e1a01006 mov r1, r6 ffff49a0: e1a00005 mov r0, r5 ffff49a4: ebffffca bl f_48d4 ffff49a8: e3500000 cmp r0, #0x0 ffff49ac: 0a000003 beq 0xffff49c0 ffff49b0: e3e00000 mvn r0, #0x0 ffff49b4: eafffff2 b 0xffff4984 ffff49b8: e3e00000 mvn r0, #0x0 ffff49bc: eafffff0 b 0xffff4984 ffff49c0: e3a00000 mov r0, #0x0 ffff49c4: eaffffee b 0xffff4984 f_49c8: ffff49c8: e92d4010 push {r4, lr} ffff49cc: e1a04000 mov r4, r0 ffff49d0: e1a00004 mov r0, r4 ffff49d4: eb0000ac bl f_4c8c ffff49d8: e8bd8010 pop {r4, pc} f_49dc: ffff49dc: e92d43f0 push {r4, r5, r6, r7, r8, r9, lr} ffff49e0: e24dd014 sub sp, sp, #0x14 ffff49e4: e1a04000 mov r4, r0 ffff49e8: e1a05001 mov r5, r1 ffff49ec: e1a06002 mov r6, r2 ffff49f0: e1a07003 mov r7, r3 ffff49f4: e1cd83d0 ldrd r8, [sp, #0x30] ffff49f8: e28d0004 add r0, sp, #0x4 ffff49fc: e3a01000 mov r1, #0x0 ffff4a00: e1a02001 mov r2, r1 ffff4a04: e1a03001 mov r3, r1 ffff4a08: e1a0c001 mov ip, r1 ffff4a0c: e880100e stm r0, {r1, r2, r3, ip} ffff4a10: e3a00003 mov r0, #0x3 ffff4a14: e58d0008 str r0, [sp, #0x8] ffff4a18: e59d0010 ldr r0, [sp, #0x10] ffff4a1c: e3c00c01 bic r0, r0, #0x100 ffff4a20: e2800c01 add r0, r0, #0x100 ffff4a24: e58d0010 str r0, [sp, #0x10] ffff4a28: e59d0010 ldr r0, [sp, #0x10] ffff4a2c: e3c00040 bic r0, r0, #0x40 ffff4a30: e58d0010 str r0, [sp, #0x10] ffff4a34: e59d0010 ldr r0, [sp, #0x10] ffff4a38: e3c00c02 bic r0, r0, #0x200 ffff4a3c: e58d0010 str r0, [sp, #0x10] ffff4a40: e59d0010 ldr r0, [sp, #0x10] ffff4a44: e3c00b01 bic r0, r0, #0x400 ffff4a48: e58d0010 str r0, [sp, #0x10] ffff4a4c: e3a00000 mov r0, #0x0 ffff4a50: e58d0004 str r0, [sp, #0x4] ffff4a54: e3550001 cmp r5, #0x1 ffff4a58: 1a000004 bne 0xffff4a70 ffff4a5c: e59d0010 ldr r0, [sp, #0x10] ffff4a60: e3c0003f bic r0, r0, #0x3f ffff4a64: e2800011 add r0, r0, #0x11 ffff4a68: e58d0010 str r0, [sp, #0x10] ffff4a6c: ea000007 b 0xffff4a90 ffff4a70: e59d0010 ldr r0, [sp, #0x10] ffff4a74: e3c0003f bic r0, r0, #0x3f ffff4a78: e2800012 add r0, r0, #0x12 ffff4a7c: e58d0010 str r0, [sp, #0x10] ffff4a80: e59d0010 ldr r0, [sp, #0x10] ffff4a84: e3c00080 bic r0, r0, #0x80 ffff4a88: e2800080 add r0, r0, #0x80 ffff4a8c: e58d0010 str r0, [sp, #0x10] ffff4a90: e5970004 ldr r0, [r7, #0x4] ffff4a94: e3100020 tst r0, #0x20 ffff4a98: 0a000001 beq 0xffff4aa4 ffff4a9c: e58d400c str r4, [sp, #0xc] ffff4aa0: ea000001 b 0xffff4aac ffff4aa4: e1a00484 lsl r0, r4, #0x9 ffff4aa8: e58d000c str r0, [sp, #0xc] ffff4aac: e1a02485 lsl r2, r5, #0x9 ffff4ab0: e1a03008 mov r3, r8 ffff4ab4: e1a01006 mov r1, r6 ffff4ab8: e58d9000 str r9, [sp] ffff4abc: e28d0004 add r0, sp, #0x4 ffff4ac0: eb00011a bl f_4f30 ffff4ac4: e3500000 cmp r0, #0x0 ffff4ac8: 0a000002 beq 0xffff4ad8 ffff4acc: e3e00000 mvn r0, #0x0 ffff4ad0: e28dd014 add sp, sp, #0x14 ffff4ad4: e8bd83f0 pop {r4, r5, r6, r7, r8, r9, pc} ffff4ad8: e3a00000 mov r0, #0x0 ffff4adc: eafffffb b 0xffff4ad0 f_4ae0: ffff4ae0: e1a02000 mov r2, r0 ffff4ae4: e5920000 ldr r0, [r2] ffff4ae8: e3c00c02 bic r0, r0, #0x200 ffff4aec: e5820000 str r0, [r2] ffff4af0: e5920000 ldr r0, [r2] ffff4af4: e1800481 orr r0, r0, r1, lsl #0x9 ffff4af8: e5820000 str r0, [r2] ffff4afc: e3a00000 mov r0, #0x0 ffff4b00: e12fff1e bx lr f_4b14: ffff4b14: e92d4010 push {r4, lr} ffff4b18: e1a02000 mov r2, r0 ffff4b1c: e30f3fff movw r3, #0xffff ffff4b20: e5812018 str r2, [r1, #0x18] ffff4b24: ea00000b b 0xffff4b58 ffff4b28: e5910018 ldr r0, [r1, #0x18] ffff4b2c: e3100102 tst r0, #-0x80000000 ; 0x80000000 ffff4b30: 1a000001 bne 0xffff4b3c ffff4b34: e3a00000 mov r0, #0x0 ffff4b38: e8bd8010 pop {r4, pc} ffff4b3c: e5910038 ldr r0, [r1, #0x38] ffff4b40: e3100a01 tst r0, #0x1000 ffff4b44: 0a000003 beq 0xffff4b58 ffff4b48: e3a00a01 mov r0, #0x1000 ffff4b4c: e5810038 str r0, [r1, #0x38] ffff4b50: e3e00000 mvn r0, #0x0 ffff4b54: eafffff7 b 0xffff4b38 ffff4b58: e1b00003 movs r0, r3 ffff4b5c: e2433001 sub r3, r3, #0x1 ffff4b60: 1afffff0 bne 0xffff4b28 ffff4b64: e3530000 cmp r3, #0x0 ffff4b68: aa000001 bge 0xffff4b74 ffff4b6c: e3e00000 mvn r0, #0x0 ffff4b70: eafffff0 b 0xffff4b38 ffff4b74: e3a00000 mov r0, #0x0 ffff4b78: eaffffee b 0xffff4b38 configurePIO_MMC(n): ffff4b7c: e1a02000 mov r2, r0 ffff4b80: e3520000 cmp r2, #0x0 ffff4b84: 1a00000b bne 0xffff4bb8 ffff4b88: e59f0510 ldr r0, =0x01c20000 ffff4b8c: e5901060 ldr r1, [r0, #0x60] ffff4b90: e3811c01 orr r1, r1, #0x100] ffff4b94: e5801060 str r1, [r0, #0x60] ffff4b98: e3a00102 mov r0, #0x80000000 ffff4b9c: e59f34fc ldr r3, =0x01c20000 ffff4ba0: e5830088 str r0, [r3, #0x88] ffff4ba4: e59f04f8 ldr r0, =0x00222222 ; SDC0 ffff4ba8: e58308b4 str r0, [r3, #0x8b4] ; PF_CFG0 ffff4bac: e3000555 movw r0, #0x555 ffff4bb0: e58308d0 str r0, [r3, #0x8d0] ; PF_PULL0 ffff4bb4: ea000015 b 0xffff4c10 ffff4bb8: e3520002 cmp r2, #0x2 ffff4bbc: 1a000013 bne 0xffff4c10 ffff4bc0: e59f04d8 ldr r0, =0x01c20000 ffff4bc4: e5901060 ldr r1, [r0, #0x60] ffff4bc8: e3811b01 orr r1, r1, #0x400 ffff4bcc: e5801060 str r1, [r0, #0x60] ffff4bd0: e3a00102 mov r0, #0x80000000 ffff4bd4: e59f34c4 ldr r3, =0x01c20000 ffff4bd8: e5830090 str r0, [r3, #0x90] ffff4bdc: e3a00433 mov r0, #0x33000000 ; SDC2 ffff4be0: e5830848 str r0, [r3, #0x848] ; PC_CFG0 ffff4be4: e3030333 movw r0, #0x3333 ; SDC2 ffff4be8: e583084c str r0, [r3, #0x84c] ; PC_CFG1 ffff4bec: e1c30000 bic r0, r3, r0 ffff4bf0: e5901864 ldr r1, [r0, #0x864] ; PC_PULL0 ffff4bf4: e1a00001 mov r0, r1 ffff4bf8: e7d7061f bfc r0, #0xc, #0xc ffff4bfc: e1a01000 mov r1, r0 ffff4c00: e3811605 orr r1, r1, #0x500000 ffff4c04: e3811a55 orr r1, r1, #0x55000 ffff4c08: e1a00003 mov r0, r3 ffff4c0c: e5801864 str r1, [r0, #0x864] ; PC_PULL0 ffff4c10: e3a00000 mov r0, #0x0 ffff4c14: e12fff1e bx lr f_4c18: ffff4c18: e92d4010 push {r4, lr} ffff4c1c: e1a01000 mov r1, r0 ffff4c20: e30f4fff movw r4, #0xffff ffff4c24: e3a02007 mov r2, #0x7 ffff4c28: e5812000 str r2, [r1] ffff4c2c: ea000005 b 0xffff4c48 ffff4c30: e2444001 sub r4, r4, #0x1 ffff4c34: e3540000 cmp r4, #0x0 ffff4c38: aa000001 bge 0xffff4c44 ffff4c3c: e3e00000 mvn r0, #0x0 ffff4c40: e8bd8010 pop {r4, pc} ffff4c44: e5912000 ldr r2, [r1] ffff4c48: e3120007 tst r2, #0x7 ffff4c4c: 1afffff7 bne 0xffff4c30 ffff4c50: e3a03000 mov r3, #0x0 ffff4c54: ea000000 b 0xffff4c5c ffff4c58: e2833001 add r3, r3, #0x1 ffff4c5c: e3530032 cmp r3, #0x32 ffff4c60: 3afffffc bcc 0xffff4c58 ffff4c64: e5912038 ldr r2, [r1, #0x38] ffff4c68: e30f0fff movw r0, #0xffff ffff4c6c: e1822000 orr r2, r2, r0 ffff4c70: e5812038 str r2, [r1, #0x38] ffff4c74: e3a02c02 mov r2, #0x200 ffff4c78: e5812000 str r2, [r1] ffff4c7c: e59f2424 ldr r2, =0x00070008 ffff4c80: e5812040 str r2, [r1, #0x40] ffff4c84: e3a00000 mov r0, #0x0 ffff4c88: eaffffec b 0xffff4c40 f_4c8c: ffff4c8c: e1a01000 mov r1, r0 ffff4c90: e3510000 cmp r1, #0x0 ffff4c94: 1a00000b bne 0xffff4cc8 ffff4c98: e59f0400 ldr r0, =0x01c20000 ffff4c9c: e5902060 ldr r2, [r0, #0x60] ffff4ca0: e3c22c01 bic r2, r2, #0x100 ffff4ca4: e5802060 str r2, [r0, #0x60] ffff4ca8: e3a00000 mov r0, #0x0 ffff4cac: e59f33ec ldr r3, =0x01c20000 ffff4cb0: e5830088 str r0, [r3, #0x88] ffff4cb4: e59f03f0 ldr r0, =0x00404044 ; JTAG1 ffff4cb8: e58308b4 str r0, [r3, #0x8b4] ; PF_CFG0 ffff4cbc: e3a00000 mov r0, #0x0 ffff4cc0: e58308d0 str r0, [r3, #0x8d0] ; PF_PULL0 ffff4cc4: ea00000c b 0xffff4cfc ffff4cc8: e3510002 cmp r1, #0x2 ffff4ccc: 1a00000a bne 0xffff4cfc ffff4cd0: e59f03c8 ldr r0, =0x01c20000 ffff4cd4: e5902060 ldr r2, [r0, #0x60] ffff4cd8: e3c22b01 bic r2, r2, #0x400] ffff4cdc: e5802060 str r2, [r0, #0x60] ffff4ce0: e3a00000 mov r0, #0x0 ffff4ce4: e59f33b4 ldr r3, =0x01c20000 ffff4ce8: e5830090 str r0, [r3, #0x90] ffff4cec: e5830848 str r0, [r3, #0x848] ; PC_CFG0 ffff4cf0: e583084c str r0, [r3, #0x84c] ; PC_CFG1 ffff4cf4: e3050140 movw r0, #0x5140 ffff4cf8: e5830864 str r0, [r3, #0x864] ; PC_PULL0 ffff4cfc: e3a00000 mov r0, #0x0 ffff4d00: e12fff1e bx lr f_4d04: ffff4d04: e92d4070 push {r4, r5, r6, lr} ffff4d08: e1a04000 mov r4, r0 ffff4d0c: e1a05001 mov r5, r1 ffff4d10: e5940014 ldr r0, [r4, #0x14] ffff4d14: e5941010 ldr r1, [r4, #0x10] ffff4d18: e7df0411 bfi r0, r1, #0x8, #0x18 ffff4d1c: e1a06000 mov r6, r0 ffff4d20: e5856008 str r6, [r5, #0x8] ffff4d24: e594000c ldr r0, [r4, #0xc] ffff4d28: e6ff6070 uxth r6, r0 ffff4d2c: e5856010 str r6, [r5, #0x10] ffff4d30: e3a00000 mov r0, #0x0 ffff4d34: e585000c str r0, [r5, #0xc] ffff4d38: e5950004 ldr r0, [r5, #0x4] ffff4d3c: e3c00801 bic r0, r0, #0x10000 ffff4d40: e5850004 str r0, [r5, #0x4] ffff4d44: e59f6364 ldr r6, =0x80202000 ffff4d48: e1a01005 mov r1, r5 ffff4d4c: e1a00006 mov r0, r6 ffff4d50: ebffff6f bl f_4b14 ffff4d54: e3500000 cmp r0, #0x0 ffff4d58: 0a000001 beq 0xffff4d64 ffff4d5c: e3e00000 mvn r0, #0x0 ffff4d60: e8bd8070 pop {r4, r5, r6, pc} ffff4d64: e5950004 ldr r0, [r5, #0x4] ffff4d68: e3c000ff bic r0, r0, #0xff ffff4d6c: e5850004 str r0, [r5, #0x4] ffff4d70: e5950004 ldr r0, [r5, #0x4] ffff4d74: e5941000 ldr r1, [r4] ffff4d78: e1800001 orr r0, r0, r1 ffff4d7c: e5850004 str r0, [r5, #0x4] ffff4d80: e59f6328 ldr r6, =0x80202000 ffff4d84: e1a01005 mov r1, r5 ffff4d88: e1a00006 mov r0, r6 ffff4d8c: ebffff60 bl f_4b14 ffff4d90: e3500000 cmp r0, #0x0 ffff4d94: 0a000001 beq 0xffff4da0 ffff4d98: e3e00000 mvn r0, #0x0 ffff4d9c: eaffffef b 0xffff4d60 ffff4da0: e5950004 ldr r0, [r5, #0x4] ffff4da4: e5941004 ldr r1, [r4, #0x4] ffff4da8: e2011001 and r1, r1, #0x1 ffff4dac: e3a02801 mov r2, #0x10000 ffff4db0: e1821881 orr r1, r2, r1, lsl #0x11 ffff4db4: e1800001 orr r0, r0, r1 ffff4db8: e5850004 str r0, [r5, #0x4] ffff4dbc: e59f62ec ldr r6, =0x80202000 ffff4dc0: e1a01005 mov r1, r5 ffff4dc4: e1a00006 mov r0, r6 ffff4dc8: ebffff51 bl f_4b14 ffff4dcc: e3500000 cmp r0, #0x0 ffff4dd0: 0a000001 beq 0xffff4ddc ffff4dd4: e3e00000 mvn r0, #0x0 ffff4dd8: eaffffe0 b 0xffff4d60 ffff4ddc: e3a00000 mov r0, #0x0 ffff4de0: eaffffde b 0xffff4d60 f_4de4: ffff4de4: e92d4070 push {r4, r5, r6, lr} ffff4de8: e1a03000 mov r3, r0 ffff4dec: e5930008 ldr r0, [r3, #0x8] ffff4df0: e582001c str r0, [r2, #0x1c] ffff4df4: e593000c ldr r0, [r3, #0xc] ffff4df8: e200403f and r4, r0, #0x3f ffff4dfc: e593000c ldr r0, [r3, #0xc] ffff4e00: e7e005d0 ubfx r0, r0, #0xb, #0x1 ffff4e04: e1844780 orr r4, r4, r0, lsl #0xf ffff4e08: e593000c ldr r0, [r3, #0xc] ffff4e0c: e7e003d0 ubfx r0, r0, #0x7, #0x1 ffff4e10: e1844600 orr r4, r4, r0, lsl #0xc ffff4e14: e5930004 ldr r0, [r3, #0x4] ffff4e18: e3500000 cmp r0, #0x0 ffff4e1c: 0a000006 beq 0xffff4e3c ffff4e20: e3844040 orr r4, r4, #0x40 ffff4e24: e593000c ldr r0, [r3, #0xc] ffff4e28: e7e00350 ubfx r0, r0, #0x6, #0x1 ffff4e2c: e1844380 orr r4, r4, r0, lsl #0x7 ffff4e30: e593000c ldr r0, [r3, #0xc] ffff4e34: e7e00450 ubfx r0, r0, #0x8, #0x1 ffff4e38: e1844400 orr r4, r4, r0, lsl #0x8 ffff4e3c: e5930004 ldr r0, [r3, #0x4] ffff4e40: e3500003 cmp r0, #0x3 ffff4e44: 1a000006 bne 0xffff4e64 ffff4e48: e3844c22 orr r4, r4, #0x2200 ffff4e4c: e593000c ldr r0, [r3, #0xc] ffff4e50: e7e004d0 ubfx r0, r0, #0x9, #0x1 ffff4e54: e1844500 orr r4, r4, r0, lsl #0xa ffff4e58: e593000c ldr r0, [r3, #0xc] ffff4e5c: e7e00550 ubfx r0, r0, #0xa, #0x1 ffff4e60: e1844580 orr r4, r4, r0, lsl #0xb ffff4e64: e3844102 orr r4, r4, #-0x80000000 ; 0x80000000 ffff4e68: e5824018 str r4, [r2, #0x18] ffff4e6c: e30f5fff movw r5, #0xffff ffff4e70: e320f000 nop {0} ffff4e74: e1b00005 movs r0, r5 ffff4e78: e2455001 sub r5, r5, #0x1 ffff4e7c: 0a000002 beq 0xffff4e8c ffff4e80: e5920038 ldr r0, [r2, #0x38] ffff4e84: e3100004 tst r0, #0x4 ffff4e88: 0afffff9 beq 0xffff4e74 ffff4e8c: e3a00004 mov r0, #0x4 ffff4e90: e5820038 str r0, [r2, #0x38] ffff4e94: e3550000 cmp r5, #0x0 ffff4e98: aa000001 bge 0xffff4ea4 ffff4e9c: e3e00000 mvn r0, #0x0 ffff4ea0: e8bd8070 pop {r4, r5, r6, pc} ffff4ea4: e5924038 ldr r4, [r2, #0x38] ffff4ea8: e5930004 ldr r0, [r3, #0x4] ffff4eac: e3500000 cmp r0, #0x0 ffff4eb0: 0a00001c beq 0xffff4f28 ffff4eb4: e3000102 movw r0, #0x102 ffff4eb8: e1100004 tst r0, r4 ffff4ebc: 0a000003 beq 0xffff4ed0 ffff4ec0: e3000102 movw r0, #0x102 ffff4ec4: e5820038 str r0, [r2, #0x38] ffff4ec8: e3e00000 mvn r0, #0x0 ffff4ecc: eafffff3 b 0xffff4ea0 ffff4ed0: e593000c ldr r0, [r3, #0xc] ffff4ed4: e7e00450 ubfx r0, r0, #0x8, #0x1 ffff4ed8: e3500000 cmp r0, #0x0 ffff4edc: 0a000005 beq 0xffff4ef8 ffff4ee0: e3140040 tst r4, #0x40 ffff4ee4: 0a000003 beq 0xffff4ef8 ffff4ee8: e3a00040 mov r0, #0x40 ffff4eec: e5820038 str r0, [r2, #0x38] ffff4ef0: e3e00000 mvn r0, #0x0 ffff4ef4: eaffffe9 b 0xffff4ea0 ffff4ef8: e5920020 ldr r0, [r2, #0x20] ffff4efc: e5810000 str r0, [r1] ffff4f00: e593000c ldr r0, [r3, #0xc] ffff4f04: e7e00350 ubfx r0, r0, #0x6, #0x1 ffff4f08: e3500001 cmp r0, #0x1 ffff4f0c: 1a000005 bne 0xffff4f28 ffff4f10: e5920024 ldr r0, [r2, #0x24] ffff4f14: e5810004 str r0, [r1, #0x4] ffff4f18: e5920028 ldr r0, [r2, #0x28] ffff4f1c: e5810008 str r0, [r1, #0x8] ffff4f20: e592002c ldr r0, [r2, #0x2c] ffff4f24: e581000c str r0, [r1, #0xc] ffff4f28: e3a00000 mov r0, #0x0 ffff4f2c: eaffffdb b 0xffff4ea0 f_4f30: ffff4f30: e92d4ff0 push {r4, r5, r6, r7, r8, r9, sl, fp, lr} ffff4f34: e24dd084 sub sp, sp, #0x84 ffff4f38: e1a04000 mov r4, r0 ffff4f3c: e1a05001 mov r5, r1 ffff4f40: e1a06002 mov r6, r2 ffff4f44: e1a07003 mov r7, r3 ffff4f48: e59d80a8 ldr r8, [sp, #0xa8] ffff4f4c: e3e00000 mvn r0, #0x0 ffff4f50: e58d0080 str r0, [sp, #0x80] ffff4f54: e5970000 ldr r0, [r7] ffff4f58: e3800102 orr r0, r0, #-0x80000000 ; 0x80000000 ffff4f5c: e5870000 str r0, [r7] ffff4f60: e5876014 str r6, [r7, #0x14] ffff4f64: e1a02007 mov r2, r7 ffff4f68: e1a0100d mov r1, sp ffff4f6c: e1a00004 mov r0, r4 ffff4f70: ebffff9b bl f_4de4 ffff4f74: e3500000 cmp r0, #0x0 ffff4f78: 0a000002 beq 0xffff4f88 ffff4f7c: e3a00c02 mov r0, #0x200 ffff4f80: e5870010 str r0, [r7, #0x10] ffff4f84: ea00003e b 0xffff5084 ffff4f88: e3a0a000 mov sl, #0x0 ffff4f8c: ea000010 b 0xffff4fd4 ffff4f90: e59fb11c ldr fp, =0x0007ffff ffff4f94: e597903c ldr r9, [r7, #0x3c] ffff4f98: ea000006 b 0xffff4fb8 ffff4f9c: e1b0000b movs r0, fp ffff4fa0: e24bb001 sub fp, fp, #0x1 ffff4fa4: 1a000002 bne 0xffff4fb4 ffff4fa8: e3e00000 mvn r0, #0x0 ffff4fac: e28dd084 add sp, sp, #0x84 ffff4fb0: e8bd8ff0 pop {r4, r5, r6, r7, r8, r9, sl, fp, pc} ffff4fb4: e597903c ldr r9, [r7, #0x3c] ffff4fb8: e3190004 tst r9, #0x4 ffff4fbc: 1afffff6 bne 0xffff4f9c ffff4fc0: e59f10f0 ldr r1, =0x01c0f000 ffff4fc4: e0810608 add r0, r1, r8, lsl #0xc ffff4fc8: e5900100 ldr r0, [r0, #0x100] ffff4fcc: e785010a str r0, [r5, sl, lsl #0x2] ffff4fd0: e28aa001 add sl, sl, #0x1 ffff4fd4: e15a0126 cmp sl, r6, lsr #0x2 ffff4fd8: 3affffec bcc 0xffff4f90 ffff4fdc: e3a00c02 mov r0, #0x200 ffff4fe0: e5870010 str r0, [r7, #0x10] ffff4fe4: e59fb0c8 ldr fp, =0x0007ffff ffff4fe8: e320f000 nop {0} ffff4fec: e1b0000b movs r0, fp ffff4ff0: e24bb001 sub fp, fp, #0x1 ffff4ff4: 0a000002 beq 0xffff5004 ffff4ff8: e5970038 ldr r0, [r7, #0x38] ffff4ffc: e3100008 tst r0, #0x8 ffff5000: 0afffff9 beq 0xffff4fec ffff5004: e3a00008 mov r0, #0x8 ffff5008: e5870038 str r0, [r7, #0x38] ffff500c: e35b0000 cmp fp, #0x0 ffff5010: aa000000 bge 0xffff5018 ffff5014: ea00001a b 0xffff5084 ffff5018: e594000c ldr r0, [r4, #0xc] ffff501c: e7e003d0 ubfx r0, r0, #0x7, #0x1 ffff5020: e3500000 cmp r0, #0x0 ffff5024: 0a00000c beq 0xffff505c ffff5028: e59fb08c ldr fp, =0x000fffff ffff502c: e320f000 nop {0} ffff5030: e1b0000b movs r0, fp ffff5034: e24bb001 sub fp, fp, #0x1 ffff5038: 0a000002 beq 0xffff5048 ffff503c: e5970038 ldr r0, [r7, #0x38] ffff5040: e3100901 tst r0, #0x4000 ffff5044: 0afffff9 beq 0xffff5030 ffff5048: e3a00901 mov r0, #0x4000 ffff504c: e5870038 str r0, [r7, #0x38] ffff5050: e35b0000 cmp fp, #0x0 ffff5054: aa000000 bge 0xffff505c ffff5058: ea000009 b 0xffff5084 ffff505c: e5979038 ldr r9, [r7, #0x38] ffff5060: e30a0a80 movw r0, #0xaa80 ffff5064: e1100009 tst r0, r9 ffff5068: 0a000002 beq 0xffff5078 ffff506c: e30a0a80 movw r0, #0xaa80 ffff5070: e5870038 str r0, [r7, #0x38] ffff5074: ea000002 b 0xffff5084 ffff5078: e3a00000 mov r0, #0x0 ffff507c: e58d0080 str r0, [sp, #0x80] ffff5080: e320f000 nop {0} ffff5084: e5970000 ldr r0, [r7] ffff5088: e3c00102 bic r0, r0, #-0x80000000 ; 0x80000000 ffff508c: e5870000 str r0, [r7] ffff5090: e3e00000 mvn r0, #0x0 ffff5094: e5870038 str r0, [r7, #0x38] ffff5098: e59d0080 ldr r0, [sp, #0x80] ffff509c: eaffffc2 b 0xffff4fac load_from_mmc: ffff50c0: e92d41f0 push {r4, r5, r6, r7, r8, lr} ffff50c4: e24dd038 sub sp, sp, #0x38 ffff50c8: e1a05000 mov r5, r0 ffff50cc: e3a07000 mov r7, #0x0 ffff50d0: e3e08000 mvn r8, #0x0 ffff50d4: e59f1150 ldr r1, =0x01c0f000 ffff50d8: e0817605 add r7, r1, r5, lsl #0xc ffff50dc: e1a02007 mov r2, r7 ffff50e0: e28d1008 add r1, sp, #0x8 ffff50e4: e1a00005 mov r0, r5 ffff50e8: ebfffe1a bl f_4958 ffff50ec: e3700001 cmn r0, #0x1 ffff50f0: 1a000000 bne 0xffff50f8 ffff50f4: ea000047 b 0xffff5218 ffff50f8: e3a01000 mov r1, #0x0 ffff50fc: e1a00007 mov r0, r7 ffff5100: ebfffe76 bl f_4ae0 ffff5104: e58d5004 str r5, [sp, #0x4] ffff5108: e58d7000 str r7, [sp] ffff510c: e28d3008 add r3, sp, #0x8 ffff5110: e3a02000 mov r2, #0x0 ffff5114: e3a01008 mov r1, #0x8 ffff5118: e3a00010 mov r0, #0x10 ffff511c: ebfffe2e bl f_49dc ffff5120: e3500000 cmp r0, #0x0 ffff5124: 0a00000c beq 0xffff515c ffff5128: e3a01001 mov r1, #0x1 ffff512c: e1a00007 mov r0, r7 ffff5130: ebfffe6a bl f_4ae0 ffff5134: e58d5004 str r5, [sp, #0x4] ffff5138: e58d7000 str r7, [sp] ffff513c: e28d3008 add r3, sp, #0x8 ffff5140: e3a02000 mov r2, #0x0 ffff5144: e3a01008 mov r1, #0x8 ffff5148: e3a00010 mov r0, #0x10 ffff514c: ebfffe22 bl f_49dc ffff5150: e3500000 cmp r0, #0x0 ffff5154: 0a000000 beq 0xffff515c ffff5158: ea00002e b 0xffff5218 ffff515c: e28f10cc ldr r1, =eGON_BT0 ffff5160: e3a00000 mov r0, #0x0 ffff5164: eb000435 bl f_6240 ffff5168: e3500000 cmp r0, #0x0 ffff516c: 0a000000 beq 0xffff5174 ffff5170: ea000028 b 0xffff5218 ffff5174: e3a04000 mov r4, #0x0 ffff5178: e5946010 ldr r6, [r4, #0x10] ffff517c: e3560a06 cmp r6, #0x6000 ffff5180: 8a000003 bhi 0xffff5194 ffff5184: e1a00006 mov r0, r6 ffff5188: e7df049f bfc r0, #0x9, #0x17 ffff518c: e3500000 cmp r0, #0x0 ffff5190: 0a000000 beq 0xffff5198 ffff5194: ea00001f b 0xffff5218 ffff5198: e3a01000 mov r1, #0x0 ffff519c: e1a00007 mov r0, r7 ffff51a0: ebfffe4e bl f_4ae0 ffff51a4: e1a014a6 lsr r1, r6, #0x9 ffff51a8: e58d5004 str r5, [sp, #0x4] ffff51ac: e58d7000 str r7, [sp] ffff51b0: e28d3008 add r3, sp, #0x8 ffff51b4: e3a02000 mov r2, #0x0 ffff51b8: e3a00010 mov r0, #0x10 ffff51bc: ebfffe06 bl f_49dc ffff51c0: e3500000 cmp r0, #0x0 ffff51c4: 0a00000c beq 0xffff51fc ffff51c8: e3a01001 mov r1, #0x1 ffff51cc: e1a00007 mov r0, r7 ffff51d0: ebfffe42 bl f_4ae0 ffff51d4: e1a014a6 lsr r1, r6, #0x9 ffff51d8: e58d5004 str r5, [sp, #0x4] ffff51dc: e58d7000 str r7, [sp] ffff51e0: e28d3008 add r3, sp, #0x8 ffff51e4: e3a02000 mov r2, #0x0 ffff51e8: e3a00010 mov r0, #0x10 ffff51ec: ebfffdfa bl f_49dc ffff51f0: e3500000 cmp r0, #0x0 ffff51f4: 0a000000 beq 0xffff51fc ffff51f8: ea000006 b 0xffff5218 ffff51fc: e1a01006 mov r1, r6 ffff5200: e3a00000 mov r0, #0x0 ffff5204: eb000420 bl f_628c ffff5208: e3500000 cmp r0, #0x0 ffff520c: 1a000000 bne 0xffff5214 ffff5210: e3a08000 mov r8, #0x0 ffff5214: e320f000 nop {0} ffff5218: e1a00005 mov r0, r5 ffff521c: ebfffde9 bl f_49c8 ffff5220: e1a00008 mov r0, r8 ffff5224: e28dd038 add sp, sp, #0x38 ffff5228: e8bd81f0 pop {r4, r5, r6, r7, r8, pc} eGON_BT0: "eGON.BT0",0 f_523c: ffff523c: e92d5ff0 push {r4, r5, r6, r7, r8, r9, sl, fp, ip, lr} ffff5240: e1a04000 mov r4, r0 ffff5244: e1a05001 mov r5, r1 ffff5248: e5949000 ldr r9, [r4] ffff524c: e594a018 ldr sl, [r4, #0x18] ffff5250: e1a0300a mov r3, sl ffff5254: e3a02000 mov r2, #0x0 ffff5258: e3a01001 mov r1, #0x1 ffff525c: e1a00005 mov r0, r5 ffff5260: e12fff39 blx r9 ffff5264: e1a06000 mov r6, r0 ffff5268: e3560002 cmp r6, #0x2 ffff526c: 1a000001 bne 0xffff5278 ffff5270: e3a00002 mov r0, #0x2 ffff5274: e8bd9ff0 pop {r4, r5, r6, r7, r8, r9, sl, fp, ip, pc} ffff5278: e3560003 cmp r6, #0x3 ffff527c: 1a000001 bne 0xffff5288 ffff5280: e3a00003 mov r0, #0x3 ffff5284: eafffffa b 0xffff5274 ffff5288: e28f1f6d ldr r1, =eGON_BT0 ffff528c: e3a00000 mov r0, #0x0 ffff5290: eb0003ea bl f_6240 ffff5294: e3500000 cmp r0, #0x0 ffff5298: 0a000001 beq 0xffff52a4 ffff529c: e3e00000 mvn r0, #0x0 ffff52a0: eafffff3 b 0xffff5274 ffff52a4: e3a08000 mov r8, #0x0 ffff52a8: e598b010 ldr fp, [r8, #0x10] ffff52ac: e1a0000b mov r0, fp ffff52b0: e7df069f bfc r0, #0xd, #0x13 ffff52b4: e3500000 cmp r0, #0x0 ffff52b8: 0a000001 beq 0xffff52c4 ffff52bc: e3e00000 mvn r0, #0x0 ffff52c0: eaffffeb b 0xffff5274 ffff52c4: e1a0752b lsr r7, fp, #0xa ffff52c8: e1a0300a mov r3, sl ffff52cc: e3a02000 mov r2, #0x0 ffff52d0: e1a01007 mov r1, r7 ffff52d4: e1a00005 mov r0, r5 ffff52d8: e12fff39 blx r9 ffff52dc: e1a06000 mov r6, r0 ffff52e0: e3560002 cmp r6, #0x2 ffff52e4: 1a000001 bne 0xffff52f0 ffff52e8: e3a00002 mov r0, #0x2 ffff52ec: eaffffe0 b 0xffff5274 ffff52f0: e3560003 cmp r6, #0x3 ffff52f4: 1a000001 bne 0xffff5300 ffff52f8: e3a00003 mov r0, #0x3 ffff52fc: eaffffdc b 0xffff5274 ffff5300: e1a0100b mov r1, fp ffff5304: e3a00000 mov r0, #0x0 ffff5308: eb0003df bl f_628c ffff530c: e3500000 cmp r0, #0x0 ffff5310: 1a000001 bne 0xffff531c ffff5314: e3a00000 mov r0, #0x0 ffff5318: eaffffd5 b 0xffff5274 ffff531c: e3e00000 mvn r0, #0x0 ffff5320: eaffffd3 b 0xffff5274 f_5324: ffff5324: e92d4070 push {r4, r5, r6, lr} ffff5328: e24dd028 sub sp, sp, #0x28 ffff532c: e3a04000 mov r4, #0x0 ffff5330: ea000019 b 0xffff539c ffff5334: e1a01004 mov r1, r4 ffff5338: e1a0000d mov r0, sp ffff533c: eb000043 bl f_5450 ffff5340: e1a0000d mov r0, sp ffff5344: eb000205 bl f_5b60 ffff5348: e3a06040 mov r6, #0x40 ffff534c: ea00000d b 0xffff5388 ffff5350: e1a01006 mov r1, r6 ffff5354: e1a0000d mov r0, sp ffff5358: ebffffb7 bl f_523c ffff535c: e1a05000 mov r5, r0 ffff5360: e3550000 cmp r5, #0x0 ffff5364: 1a000003 bne 0xffff5378 ffff5368: eb0001c5 bl f_5a84 ffff536c: e3a00000 mov r0, #0x0 ffff5370: e28dd028 add sp, sp, #0x28 ffff5374: e8bd8070 pop {r4, r5, r6, pc} ffff5378: e3550002 cmp r5, #0x2 ffff537c: 1a000000 bne 0xffff5384 ffff5380: ea000002 b 0xffff5390 ffff5384: e2866040 add r6, r6, #0x40 ffff5388: e3560c02 cmp r6, #0x200 ffff538c: 3affffef bcc 0xffff5350 ffff5390: e320f000 nop {0} ffff5394: eb0001ba bl f_5a84 ffff5398: e2844001 add r4, r4, #0x1 ffff539c: e354000a cmp r4, #0xa ffff53a0: 3affffe3 bcc 0xffff5334 ffff53a4: e3e00000 mvn r0, #0x0 ffff53a8: eafffff0 b 0xffff5370 f_53ac: ffff53ac: e92d4030 push {r4, r5, lr} ffff53b0: e24dd02c sub sp, sp, #0x2c ffff53b4: e3a05000 mov r5, #0x0 ffff53b8: ea000010 b 0xffff5400 ffff53bc: e1a01005 mov r1, r5 ffff53c0: e28d0004 add r0, sp, #0x4 ffff53c4: eb000021 bl f_5450 ffff53c8: e28d0004 add r0, sp, #0x4 ffff53cc: eb0001e3 bl f_5b60 ffff53d0: e3a01000 mov r1, #0x0 ffff53d4: e28d0004 add r0, sp, #0x4 ffff53d8: ebffff97 bl f_523c ffff53dc: e1a04000 mov r4, r0 ffff53e0: e3540000 cmp r4, #0x0 ffff53e4: 1a000003 bne 0xffff53f8 ffff53e8: eb0001a5 bl f_5a84 ffff53ec: e3a00000 mov r0, #0x0 ffff53f0: e28dd02c add sp, sp, #0x2c ffff53f4: e8bd8030 pop {r4, r5, pc} ffff53f8: eb0001a1 bl f_5a84 ffff53fc: e2855001 add r5, r5, #0x1 ffff5400: e355000a cmp r5, #0xa ffff5404: 3affffec bcc 0xffff53bc ffff5408: e3e00000 mvn r0, #0x0 ffff540c: eafffff7 b 0xffff53f0 load_from_nand: ffff5410: e92d4010 push {r4, lr} ffff5414: ebffffe4 bl f_53ac ffff5418: e3500000 cmp r0, #0x0 ffff541c: 1a000001 bne 0xffff5428 ffff5420: e3a00000 mov r0, #0x0 ffff5424: e8bd8010 pop {r4, pc} ffff5428: ebffffbd bl f_5324 ffff542c: e3500000 cmp r0, #0x0 ffff5430: 1a000001 bne 0xffff543c ffff5434: e3a00000 mov r0, #0x0 ffff5438: eafffff9 b 0xffff5424 ffff543c: e3e00000 mvn r0, #0x0 ffff5440: eafffff7 b 0xffff5424 f_5450: ffff5450: e92d4070 push {r4, r5, r6, lr} ffff5454: e1a05000 mov r5, r0 ffff5458: e1a04001 mov r4, r1 ffff545c: e0840104 add r0, r4, r4, lsl #0x2 ; r1 * 5 ffff5460: e59f2010 ldr r2, =d_6478 ffff5464: e0821180 add r1, r2, r0, lsl #3 ; r1 = &d_6478 + r1 * 5 * 8 = r1 * 40 ffff5468: e3a02028 mov r2, #0x28 ffff546c: e1a00005 mov r0, r5 ffff5470: eb0003d8 bl memcpy ffff5474: e8bd8070 pop {r4, r5, r6, pc} f_547c: ffff547c: e92d4010 push {r4, lr} ffff5480: e1a02000 mov r2, r0 ffff5484: e3a03000 mov r3, #0x0 ffff5488: e3a04000 mov r4, #0x0 ffff548c: ea000002 b 0xffff549c ffff5490: e3a00001 mov r0, #0x1 ffff5494: e1844310 orr r4, r4, r0, lsl r3 ffff5498: e2833001 add r3, r3, #0x1 ffff549c: e1530001 cmp r3, r1 ffff54a0: 3afffffa bcc 0xffff5490 ffff54a4: e0020004 and r0, r2, r4 ffff54a8: e8bd8010 pop {r4, pc} f_54ac: ffff54ac: e3a02000 mov r2, #0x0 ffff54b0: e59f3488 ldr r3, =0x01c02000 ffff54b4: e5832000 str r2, [r3] ffff54b8: e59f2484 ldr r2, =0x01c03030 ffff54bc: e5832304 str r2, [r3, #0x304] ffff54c0: e0032002 and r2, r3, r2 ffff54c4: e5820308 str r0, [r2, #0x308] ffff54c8: e3072f0f movw r2, #0x7f0f ffff54cc: e5832318 str r2, [r3, #0x318] ffff54d0: e1c32142 bic r2, r3, r2, asr #0x2 ffff54d4: e582130c str r1, [r2, #0x30c] ffff54d8: e59f2468 ldr r2, =0x84000423 ffff54dc: e5832300 str r2, [r3, #0x300] ffff54e0: e12fff1e bx lr int wait_dma_finished(timeout): ffff54e4: e1a01000 mov r1, r0 ffff54e8: e320f000 nop {0} ffff54ec: e59f044c ldr r0, =0x01c02000 ffff54f0: e5900300 ldr r0, [r0, #0x300] ffff54f4: e3100102 tst r0, #-0x80000000 ; 0x80000000 ffff54f8: 1a000001 bne 0xffff5504 ffff54fc: e3a00000 mov r0, #0x0 ffff5500: e12fff1e bx lr ffff5504: e2410001 sub r0, r1, #0x1 ffff5508: e1b01000 movs r1, r0 ffff550c: 1afffff6 bne 0xffff54ec ffff5510: e3a00002 mov r0, #0x2 ffff5514: eafffff9 b 0xffff5500 int nand_wait_cmd_finish(int timeout) { do { if (readl(&nfc->st) & NFC_ST_CMD_INT_FLAG) return 0; } while (--timeout); return 2; } nand_wait_cmd_finish: ffff5518: e1a01000 mov r1, r0 ffff551c: e320f000 nop {0} ffff5520: e59f0424 ldr r0, =0x01c03000 ffff5524: e5900004 ldr r0, [r0, #0x4] ; NANDC_ST ffff5528: e3100002 tst r0, #0x2 ; NFC_ST_CMD_INT_FLAG ffff552c: 0a000001 beq 0xffff5538 ffff5530: e3a00000 mov r0, #0x0 ffff5534: e12fff1e bx lr ffff5538: e2410001 sub r0, r1, #0x1 ffff553c: e1b01000 movs r1, r0 ffff5540: 1afffff6 bne 0xffff5520 ffff5544: e3a00002 mov r0, #0x2 ffff5548: eafffff9 b 0xffff5534 int nand_waid_cmd_fifo_free(int timeout) { do { if (readl(&nfc->st) & NFC_ST_CMD_FIFO_FLAG) return 0; } while(--timeout); return 2; } nand_wait_cmd_fifo_free: ffff554c: e1a01000 mov r1, r0 ffff5550: e320f000 nop {0} ffff5554: e59f03f0 ldr r0, =0x01c03000 ffff5558: e5900004 ldr r0, [r0, #0x4] ; NANDC_ST ffff555c: e3100008 tst r0, #0x8 ; NFC_ST_CMD_FIFO_FLAG ffff5560: 1a000001 bne 0xffff556c ffff5564: e3a00000 mov r0, #0x0 ffff5568: e12fff1e bx lr ffff556c: e2410001 sub r0, r1, #0x1 ffff5570: e1b01000 movs r1, r0 ffff5574: 1afffff6 bne 0xffff5554 ffff5578: e3a00002 mov r0, #0x2 ffff557c: eafffff9 b 0xffff5568 nand_wait_dma_transfer_complete(timeout_fifo,timeout_cmd,timeout_dma): ffff5580: e92d4070 push {r4, r5, r6, lr} ffff5584: e1a04000 mov r4, r0 ffff5588: e1a05001 mov r5, r1 ffff558c: e1a06002 mov r6, r2 ffff5590: e1a00004 mov r0, r4 ffff5594: ebffffec bl nand_wait_cmd_fifo_free ffff5598: e3500002 cmp r0, #0x2 ffff559c: 1a000001 bne 0xffff55a8 ffff55a0: e3a00002 mov r0, #0x2 ffff55a4: e8bd8070 pop {r4, r5, r6, pc} ffff55a8: e1a00005 mov r0, r5 ffff55ac: ebffffd9 bl nand_wait_cmd_finish ffff55b0: e3500002 cmp r0, #0x2 ffff55b4: 1a000001 bne 0xffff55c0 ffff55b8: e3a00002 mov r0, #0x2 ffff55bc: eafffff8 b 0xffff55a4 ffff55c0: e1a00006 mov r0, r6 ffff55c4: ebffffc6 bl wait_dma_finished(timeout) ffff55c8: e3500002 cmp r0, #0x2 ffff55cc: 1a000001 bne 0xffff55d8 ffff55d0: e3a00002 mov r0, #0x2 ffff55d4: eafffff2 b 0xffff55a4 ffff55d8: e3a00000 mov r0, #0x0 ffff55dc: eafffff0 b 0xffff55a4 int nand_reset_chip(void) { writel(&nfc->cmd, NAND_CMD_RESET | NFC_CMD_SEND_CMD1 | NFC_CMD_WAIT_FLAG); if (nand_wait_cmd_fifo_free(4800) == 2) return 2; if (nand_wait_cmd_finish(4920) == 2) return 2; return 0; } nand_reset_chip: ffff55e0: e92d4010 push {r4, lr} ffff55e4: e59f0364 ldr r0, =0x00c000ff CMD=0x00ff(RESET), SEND_CMD1, WAIT_FLAG RB ffff55e8: e59f135c ldr r1, =0x01c03000 ffff55ec: e5810024 str r0, [r1, #0x24] ; NFC_CMD ffff55f0: e3a00d4b mov r0, #0x12c0 ffff55f4: ebffffd4 bl nand_wait_cmd_fifo_free ffff55f8: e3500002 cmp r0, #0x2 ffff55fc: 1a000001 bne 0xffff5608 ffff5600: e3a00002 mov r0, #0x2 ffff5604: e8bd8010 pop {r4, pc} ffff5608: e3010338 movw r0, #0x1338 ffff560c: ebffffc1 bl nand_wait_cmd_finish ffff5610: e3500002 cmp r0, #0x2 ffff5614: 1a000001 bne 0xffff5620 ffff5618: e3a00002 mov r0, #0x2 ffff561c: eafffff8 b 0xffff5604 ffff5620: e3a00000 mov r0, #0x0 ffff5624: eafffff6 b 0xffff5604 nand_read_a(a,b,c): nand_read_a: ffff5628: e92d47f0 push {r4, r5, r6, r7, r8, r9, sl, lr} ffff562c: e1a04000 mov r4, r0 ffff5630: e1a05001 mov r5, r1 ffff5634: e1a06002 mov r6, r2 ffff5638: e59f030c ldr r0, =0x01c03000 ffff563c: e5900000 ldr r0, [r0] ffff5640: e3800901 orr r0, r0, #0x4000 ; RAM_ACCESS_MODE=DMA ffff5644: e59f1300 ldr r1, =0x01c03000 ffff5648: e5810000 str r0, [r1] ; CTL ffff564c: e3a07001 mov r7, #0x1 ffff5650: e3019318 movw r9, #0x1318 ffff5654: e3a00016 mov r0, #0x16 ffff5658: e1600087 smulbb r0, r7, r0 ffff565c: e280ad4b add sl, r0, #0x12c0 ffff5660: e59f02ec ldr r0, =0x00e00530 ffff5664: e5810028 str r0, [r1, #0x28] ; RCMD_SET = RCMD0=05, RCMD1=E0, CMD2=30 ffff5668: e3a01b01 mov r1, #0x400 ffff566c: e1a00005 mov r0, r5 ffff5670: ebffff8d bl f_54ac ffff5674: e59f02d0 ldr r0, =0x01c03000 ffff5678: e580701c str r7, [r0, #0x1c] ; SECTOR_NUM=? ffff567c: e1a00009 mov r0, r9 ffff5680: ebffffb1 bl nand_wait_cmd_fifo_free ffff5684: e3500002 cmp r0, #0x2 ffff5688: 1a000006 bne 0xffff56a8 ffff568c: e59f02ac ldr r0, =0x01c02000 ffff5690: e5900300 ldr r0, [r0, #0x300] ; 0x01c02300 DMA ffff5694: e3c00102 bic r0, r0, #-0x80000000 ; 0x80000000 ffff5698: e59f12a0 ldr r1, =0x01c02000 ffff569c: e5810300 str r0, [r1, #0x300] ffff56a0: e3a00002 mov r0, #0x2 ffff56a4: e8bd87f0 pop {r4, r5, r6, r7, r8, r9, sl, pc} ffff56a8: e1a08004 mov r8, r4 ffff56ac: e1a04008 mov r4, r8 ffff56b0: e1a00808 lsl r0, r8, #0x10 ffff56b4: e59f1290 ldr r1, =0x01c03000 ffff56b8: e5810014 str r0, [r1, #0x14] ; ADDR_LOW ffff56bc: e1a04008 mov r4, r8 ffff56c0: e1a00828 lsr r0, r8, #0x10 ffff56c4: e5810018 str r0, [r1, #0x18] ; ADDR_HIGH ffff56c8: e2860003 add r0, r6, #0x3 ffff56cc: e59f1284 ldr r1, =0x87e80000 ; PAGE_CMD, SEND_CMD2, SEQ, DATA_SWAP_METHOD, SEND_ADR, DATA_TRANS, SEND_CMD1, WAIT_FLAG, CMD1=00 ffff56d0: e1810800 orr r0, r1, r0, lsl #0x10 ; r0 = number of addres bits ffff56d4: e59f1270 ldr r1, =0x01c03000 ffff56d8: e5810024 str r0, [r1, #0x24] ; NFC_CMD ffff56dc: e1a0200a mov r2, sl ffff56e0: e1a0100a mov r1, sl ffff56e4: e1a0000a mov r0, sl ffff56e8: ebffffa4 bl nand_wait_dma_transfer_complete ffff56ec: e3500002 cmp r0, #0x2 ffff56f0: 1a000006 bne 0xffff5710 ffff56f4: e59f0244 ldr r0, =0x01c02000 ffff56f8: e5900300 ldr r0, [r0, #0x300] ; DMA ffff56fc: e3c00102 bic r0, r0, #-0x80000000 ; 0x80000000 ffff5700: e59f1238 ldr r1, =0x01c02000 ffff5704: e5810300 str r0, [r1, #0x300] ffff5708: e3a00002 mov r0, #0x2 ffff570c: eaffffe4 b 0xffff56a4 ffff5710: e59f1234 ldr r1, =0x01c03000 ffff5714: e5910038 ldr r0, [r1, #0x38] ; ECC_ST ffff5718: e1a01007 mov r1, r7 ffff571c: ebffff56 bl f_547c ffff5720: e3500000 cmp r0, #0x0 ; All sectors OK? ffff5724: 0a000006 beq 0xffff5744 ffff5728: e59f0210 ldr r0, =0x01c02000 ffff572c: e5900300 ldr r0, [r0, #0x300] ; DMA ffff5730: e3c00102 bic r0, r0, #-0x80000000 ; 0x80000000 ffff5734: e59f1204 ldr r1, =0x01c02000 ffff5738: e5810300 str r0, [r1, #0x300] ffff573c: e3a00003 mov r0, #0x3 ffff5740: eaffffd7 b 0xffff56a4 ffff5744: e59f01f4 ldr r0, =0x01c02000 ffff5748: e5900300 ldr r0, [r0, #0x300] ; DMA ffff574c: e3c00102 bic r0, r0, #-0x80000000 ; 0x80000000 ffff5750: e59f11e8 ldr r1, =0x01c02000 ffff5754: e5810300 str r0, [r1, #0x300] ffff5758: e3a00000 mov r0, #0x0 ffff575c: eaffffd0 b 0xffff56a4 f_5760: ffff5760: e92d47f0 push {r4, r5, r6, r7, r8, r9, sl, lr} ffff5764: e1a04000 mov r4, r0 ffff5768: e1a05001 mov r5, r1 ffff576c: e1a06002 mov r6, r2 ffff5770: e59f01d4 ldr r0, =0x01c03000 ffff5774: e5900000 ldr r0, [r0] ffff5778: e3800901 orr r0, r0, #0x4000 ffff577c: e59f11c8 ldr r1, =0x01c03000 ffff5780: e5810000 str r0, [r1] ffff5784: e3a07002 mov r7, #0x2 ffff5788: e3019318 movw r9, #0x1318 ffff578c: e3a00016 mov r0, #0x16 ffff5790: e1600087 smulbb r0, r7, r0 ffff5794: e280ad4b add sl, r0, #0x12c0 ffff5798: e59f01b4 ldr r0, =0x00e00530 ffff579c: e5810028 str r0, [r1, #0x28] ffff57a0: e3a01b01 mov r1, #0x400 ffff57a4: e1a00005 mov r0, r5 ffff57a8: ebffff3f bl f_54ac ffff57ac: e59f0198 ldr r0, =0x01c03000 ffff57b0: e580701c str r7, [r0, #0x1c] ffff57b4: e1a00009 mov r0, r9 ffff57b8: ebffff63 bl nand_wait_cmd_fifo_free ffff57bc: e3500002 cmp r0, #0x2 ffff57c0: 1a000006 bne 0xffff57e0 ffff57c4: e59f0174 ldr r0, =0x01c02000 ffff57c8: e5900300 ldr r0, [r0, #0x300] ffff57cc: e3c00102 bic r0, r0, #-0x80000000 ; 0x80000000 ffff57d0: e59f1168 ldr r1, =0x01c02000 ffff57d4: e5810300 str r0, [r1, #0x300] ffff57d8: e3a00002 mov r0, #0x2 ffff57dc: e8bd87f0 pop {r4, r5, r6, r7, r8, r9, sl, pc} ffff57e0: e1a08004 mov r8, r4 ffff57e4: e1a04008 mov r4, r8 ffff57e8: e1a00808 lsl r0, r8, #0x10 ffff57ec: e59f1158 ldr r1, =0x01c03000 ffff57f0: e5810014 str r0, [r1, #0x14] ffff57f4: e1a04008 mov r4, r8 ffff57f8: e1a00828 lsr r0, r8, #0x10 ffff57fc: e5810018 str r0, [r1, #0x18] ffff5800: e2860003 add r0, r6, #0x3 ffff5804: e59f114c ldr r1, =0x87e80000 ffff5808: e1810800 orr r0, r1, r0, lsl #0x10 ffff580c: e59f1138 ldr r1, =0x01c03000 ffff5810: e5810024 str r0, [r1, #0x24] ffff5814: e1a0200a mov r2, sl ffff5818: e1a0100a mov r1, sl ffff581c: e1a0000a mov r0, sl ffff5820: ebffff56 bl nand_wait_dma_transfer_complete ffff5824: e3500002 cmp r0, #0x2 ffff5828: 1a000006 bne 0xffff5848 ffff582c: e59f010c ldr r0, =0x01c02000 ffff5830: e5900300 ldr r0, [r0, #0x300] ffff5834: e3c00102 bic r0, r0, #-0x80000000 ; 0x80000000 ffff5838: e59f1100 ldr r1, =0x01c02000 ffff583c: e5810300 str r0, [r1, #0x300] ffff5840: e3a00002 mov r0, #0x2 ffff5844: eaffffe4 b 0xffff57dc ffff5848: e59f10fc ldr r1, =0x01c03000 ffff584c: e5910038 ldr r0, [r1, #0x38] ffff5850: e1a01007 mov r1, r7 ffff5854: ebffff08 bl f_547c ffff5858: e3500000 cmp r0, #0x0 ffff585c: 0a000006 beq 0xffff587c ffff5860: e59f00d8 ldr r0, =0x01c02000 ffff5864: e5900300 ldr r0, [r0, #0x300] ffff5868: e3c00102 bic r0, r0, #-0x80000000 ; 0x80000000 ffff586c: e59f10cc ldr r1, =0x01c02000 ffff5870: e5810300 str r0, [r1, #0x300] ffff5874: e3a00003 mov r0, #0x3 ffff5878: eaffffd7 b 0xffff57dc ffff587c: e59f00bc ldr r0, =0x01c02000 ffff5880: e5900300 ldr r0, [r0, #0x300] ffff5884: e3c00102 bic r0, r0, #-0x80000000 ; 0x80000000 ffff5888: e59f10b0 ldr r1, =0x01c02000 ffff588c: e5810300 str r0, [r1, #0x300] ffff5890: e3a00000 mov r0, #0x0 ffff5894: eaffffd0 b 0xffff57dc nand_read_a_blocks(a,b,c,d) nand_read_a_blocks: ffff5898: e92d47f0 push {r4, r5, r6, r7, r8, r9, sl, lr} ffff589c: e1a04000 mov r4, r0 ffff58a0: e1a05001 mov r5, r1 ffff58a4: e1a09002 mov r9, r2 ffff58a8: e1a06003 mov r6, r3 ffff58ac: e3a07000 mov r7, #0x0 ffff58b0: ea000009 b 0xffff58dc ffff58b4: e0891507 add r1, r9, r7, lsl #0xa ffff58b8: e0840007 add r0, r4, r7 ffff58bc: e1a02006 mov r2, r6 ffff58c0: ebffff58 bl nand_read_a ffff58c4: e1a08000 mov r8, r0 ffff58c8: e3580000 cmp r8, #0x0 ffff58cc: 0a000001 beq 0xffff58d8 ffff58d0: e1a00008 mov r0, r8 ffff58d4: e8bd87f0 pop {r4, r5, r6, r7, r8, r9, sl, pc} ffff58d8: e2877001 add r7, r7, #0x1 ffff58dc: e1570005 cmp r7, r5 ffff58e0: 3afffff3 bcc 0xffff58b4 ffff58e4: e3a00000 mov r0, #0x0 ffff58e8: eafffff9 b 0xffff58d4 f_58ec: ffff58ec: e92d47f0 push {r4, r5, r6, r7, r8, r9, sl, lr} ffff58f0: e1a04000 mov r4, r0 ffff58f4: e1a05001 mov r5, r1 ffff58f8: e1a09002 mov r9, r2 ffff58fc: e1a06003 mov r6, r3 ffff5900: e3a07000 mov r7, #0x0 ffff5904: ea000009 b 0xffff5930 ffff5908: e0891507 add r1, r9, r7, lsl #0xa ffff590c: e0840007 add r0, r4, r7 ffff5910: e1a02006 mov r2, r6 ffff5914: ebffff91 bl f_5760 ffff5918: e1a08000 mov r8, r0 ffff591c: e3580000 cmp r8, #0x0 ffff5920: 0a000001 beq 0xffff592c ffff5924: e1a00008 mov r0, r8 ffff5928: e8bd87f0 pop {r4, r5, r6, r7, r8, r9, sl, pc} ffff592c: e2877001 add r7, r7, #0x1 ffff5930: e1570005 cmp r7, r5 ffff5934: 3afffff3 bcc 0xffff5908 ffff5938: e3a00000 mov r0, #0x0 ffff593c: eafffff9 b 0xffff5928 configurePIO_PC_NAND: ffff595c: e59f0330 ldr r0, =0x22222222 ffff5960: e59f1330 ldr r1, =0x01c20000 ffff5964: e5810848 str r0, [r1, #0x848] ; PC_CFG0 ffff5968: e581084c str r0, [r1, #0x84c] ; PC_CFG1 ffff596c: e1a00240 asr r0, r0, #0x4 ffff5970: e5810850 str r0, [r1, #0x850] ; PC_CFG2 ffff5974: e3a00002 mov r0, #0x2 ffff5978: e5810854 str r0, [r1, #0x854] ; PC_CFG3 ffff597c: e59f0318 ldr r0, =0x55555555 ffff5980: e581085c str r0, [r1, #0x85c] ; PC_DRV0 ffff5984: e1a00740 asr r0, r0, #0xe ffff5988: e5810860 str r0, [r1, #0x860] ; PC_DRV1 ffff598c: e3050140 movw r0, #0x5140 ffff5990: e5810864 str r0, [r1, #0x864] ; PC_PULL0 ffff5994: e3040016 movw r0, #0x4016 ffff5998: e5810868 str r0, [r1, #0x868] ; PC_PULL1 ffff599c: e12fff1e bx lr f_59a0: ffff59a0: e92d4070 push {r4, r5, r6, lr} ffff59a4: ebffffec bl configurePIO_PC_NAND ffff59a8: e59f02e8 ldr r0, =0x01c20000 ffff59ac: e5900060 ldr r0, [r0, #0x60] ffff59b0: e3c00a02 bic r0, r0, #0x2000 ffff59b4: e59f12dc ldr r1, =0x01c20000 ffff59b8: e5810060 str r0, [r1, #0x60] ffff59bc: e1a00001 mov r0, r1 ffff59c0: e5900060 ldr r0, [r0, #0x60] ffff59c4: e3800a02 orr r0, r0, #0x2000 ffff59c8: e5810060 str r0, [r1, #0x60] ffff59cc: e1a00001 mov r0, r1 ffff59d0: e5900080 ldr r0, [r0, #0x80] ffff59d4: e3c00102 bic r0, r0, #-0x80000000 ; 0x80000000 ffff59d8: e5810080 str r0, [r1, #0x80] ffff59dc: e59f42bc ldr r4, =0x0303000f ffff59e0: e1a00001 mov r0, r1 ffff59e4: e5900080 ldr r0, [r0, #0x80] ffff59e8: e1c05004 bic r5, r0, r4 ffff59ec: e3855001 orr r5, r5, #0x1 ffff59f0: e1a00001 mov r0, r1 ffff59f4: e5805080 str r5, [r0, #0x80] ffff59f8: e5900080 ldr r0, [r0, #0x80] ffff59fc: e3800102 orr r0, r0, #-0x80000000 ; 0x80000000 ffff5a00: e5810080 str r0, [r1, #0x80] ffff5a04: e1a00001 mov r0, r1 ffff5a08: e5900060 ldr r0, [r0, #0x60] ffff5a0c: e3800040 orr r0, r0, #0x40 ffff5a10: e5810060 str r0, [r1, #0x60] ffff5a14: e3a00003 mov r0, #0x3 ffff5a18: e2411a1d sub r1, r1, #0x1d000 ffff5a1c: e5810000 str r0, [r1] ffff5a20: e3a00000 mov r0, #0x0 ffff5a24: ea000000 b 0xffff5a2c ffff5a28: e2800001 add r0, r0, #0x1 ffff5a2c: e35000f0 cmp r0, #0xf0 ffff5a30: 3afffffc bcc 0xffff5a28 ffff5a34: e8bd8070 pop {r4, r5, r6, pc} f_5a38: ffff5a38: e3a00000 mov r0, #0x0 ffff5a3c: e59f1254 ldr r1, =0x01c20000 ffff5a40: e5810848 str r0, [r1, #0x848] ; PC_CFG0 ffff5a44: e581084c str r0, [r1, #0x84c] ; PC_CFG1 ffff5a48: e5810850 str r0, [r1, #0x850] ; PC_CFG2 ffff5a4c: e5810854 str r0, [r1, #0x854] ; PC_CFG3 ffff5a50: e59f0244 ldr r0, =0x55555555 ffff5a54: e581085c str r0, [r1, #0x85c] ; PC_DRV0 ffff5a58: e1a00740 asr r0, r0, #0xe ffff5a5c: e5810860 str r0, [r1, #0x860] ; PC_DRV1 ffff5a60: e3050140 movw r0, #0x5140 ffff5a64: e5810864 str r0, [r1, #0x864] ; PC_PULL0 ffff5a68: e3040016 movw r0, #0x4016 ffff5a6c: e5810868 str r0, [r1, #0x868] ; PC_PULL1 ffff5a70: e12fff1e bx lr nand_set_boot_random_seed: ffff5a74: e59f0228 ldr r0, =0x4a800008 ; RANDOM_EN,RANDOM_SEED=0x4a80 ffff5a78: e59f1228 ldr r1, =0x01c03000 ; NAND ffff5a7c: e5810034 str r0, [r1, #0x34] ; ECC_CTL ffff5a80: e12fff1e bx lr f_5a84: ffff5a84: e92d4010 push {r4, lr} ffff5a88: ebfffff9 bl nand_set_boot_random_seed ffff5a8c: e59f0214 ldr r0, =0x01c03000 ffff5a90: e5900000 ldr r0, [r0] ffff5a94: e3c00001 bic r0, r0, #0x1 ffff5a98: e59f1208 ldr r1, =0x01c03000 ffff5a9c: e5810000 str r0, [r1] ffff5aa0: e2810a1d add r0, r1, #0x1d000 ffff5aa4: e5900080 ldr r0, [r0, #0x80] ffff5aa8: e3c00102 bic r0, r0, #-0x80000000 ; 0x80000000 ffff5aac: e2811a1d add r1, r1, #0x1d000 ffff5ab0: e5810080 str r0, [r1, #0x80] ffff5ab4: e1a00001 mov r0, r1 ffff5ab8: e5900060 ldr r0, [r0, #0x60] ffff5abc: e3c00a02 bic r0, r0, #0x2000 ffff5ac0: e5810060 str r0, [r1, #0x60] ffff5ac4: e1a00001 mov r0, r1 ffff5ac8: e5900060 ldr r0, [r0, #0x60] ffff5acc: e3c00040 bic r0, r0, #0x40 ffff5ad0: e5810060 str r0, [r1, #0x60] ffff5ad4: ebffffd7 bl f_5a38 ffff5ad8: e8bd8010 pop {r4, pc} f_5adc: ffff5adc: e92d40f0 push {r4, r5, r6, r7, lr} ffff5ae0: e3510c02 cmp r1, #0x200 ffff5ae4: 0a000003 beq 0xffff5af8 ffff5ae8: e3510b01 cmp r1, #0x400 ffff5aec: 1a000004 bne 0xffff5b04 ffff5af0: e3a03000 mov r3, #0x0 ffff5af4: ea000005 b 0xffff5b10 ffff5af8: e320f000 nop {0} ffff5afc: e3a03001 mov r3, #0x1 ffff5b00: ea000002 b 0xffff5b10 ffff5b04: e320f000 nop {0} ffff5b08: e3a03000 mov r3, #0x0 ffff5b0c: e320f000 nop {0} ffff5b10: e320f000 nop {0} ffff5b14: e3500040 cmp r0, #0x40 ffff5b18: 1a000001 bne 0xffff5b24 ffff5b1c: e3a05008 mov r5, #0x8 ffff5b20: ea000002 b 0xffff5b30 ffff5b24: e320f000 nop {0} ffff5b28: e3a05008 mov r5, #0x8 ffff5b2c: e320f000 nop {0} ffff5b30: e320f000 nop {0} ffff5b34: e59f616c ldr r6, =0x01c03000 ffff5b38: e5964034 ldr r4, [r6, #0x34] ffff5b3c: e30f6220 movw r6, #0xf220 ffff5b40: e1c44006 bic r4, r4, r6 ffff5b44: e1846605 orr r6, r4, r5, lsl #0xc ffff5b48: e1866283 orr r6, r6, r3, lsl #0x5 ffff5b4c: e3866001 orr r6, r6, #0x1 ffff5b50: e1866482 orr r6, r6, r2, lsl #0x9 ffff5b54: e59f714c ldr r7, =0x01c03000 ffff5b58: e5876034 str r6, [r7, #0x34] ffff5b5c: e8bd80f0 pop {r4, r5, r6, r7, pc} f_5b60: ffff5b60: e92d47f0 push {r4, r5, r6, r7, r8, r9, sl, lr} ffff5b64: e1a04000 mov r4, r0 ffff5b68: ebffff8c bl f_59a0 ffff5b6c: e5940008 ldr r0, [r4, #0x8] ffff5b70: e3500000 cmp r0, #0x0 ffff5b74: 0a000000 beq 0xffff5b7c ffff5b78: ebfffe98 bl nand_reset_chip ffff5b7c: e594001c ldr r0, [r4, #0x1c] ffff5b80: e5942020 ldr r2, [r4, #0x20] ffff5b84: e5941024 ldr r1, [r4, #0x24] ffff5b88: ebffffd3 bl f_5adc ffff5b8c: e59f0114 ldr r0, =0x01c03000 ffff5b90: e5900000 ldr r0, [r0] ffff5b94: e59f1110 ldr r1, =0xfff3b0fb ffff5b98: e0005001 and r5, r0, r1 ffff5b9c: e5940014 ldr r0, [r4, #0x14] ffff5ba0: e3500008 cmp r0, #0x8 ffff5ba4: 0a000010 beq 0xffff5bec ffff5ba8: ca000004 bgt 0xffff5bc0 ffff5bac: e3500002 cmp r0, #0x2 ffff5bb0: 0a000007 beq 0xffff5bd4 ffff5bb4: e3500004 cmp r0, #0x4 ffff5bb8: 1a000014 bne 0xffff5c10 ffff5bbc: ea000007 b 0xffff5be0 ffff5bc0: e3500010 cmp r0, #0x10 ffff5bc4: 0a00000b beq 0xffff5bf8 ffff5bc8: e3500020 cmp r0, #0x20 ffff5bcc: 1a00000f bne 0xffff5c10 ffff5bd0: ea00000b b 0xffff5c04 ffff5bd4: e320f000 nop {0} ffff5bd8: e3a06000 mov r6, #0x0 ffff5bdc: ea00000e b 0xffff5c1c ffff5be0: e320f000 nop {0} ffff5be4: e3a06001 mov r6, #0x1 ffff5be8: ea00000b b 0xffff5c1c ffff5bec: e320f000 nop {0} ffff5bf0: e3a06002 mov r6, #0x2 ffff5bf4: ea000008 b 0xffff5c1c ffff5bf8: e320f000 nop {0} ffff5bfc: e3a06003 mov r6, #0x3 ffff5c00: ea000005 b 0xffff5c1c ffff5c04: e320f000 nop {0} ffff5c08: e3a06004 mov r6, #0x4 ffff5c0c: ea000002 b 0xffff5c1c ffff5c10: e320f000 nop {0} ffff5c14: e3a06000 mov r6, #0x0 ffff5c18: e320f000 nop {0} ffff5c1c: e320f000 nop {0} ffff5c20: e5940004 ldr r0, [r4, #0x4] ffff5c24: e2007003 and r7, r0, #0x3 ffff5c28: e1850907 orr r0, r5, r7, lsl #0x12 ffff5c2c: e1800406 orr r0, r0, r6, lsl #0x8 ffff5c30: e3800901 orr r0, r0, #0x4000 ffff5c34: e59f106c ldr r1, =0x01c03000 ffff5c38: e5810000 str r0, [r1] ffff5c3c: e1a00001 mov r0, r1 ffff5c40: e590000c ldr r0, [r0, #0xc] ffff5c44: e3001f3f movw r1, #0xf3f ffff5c48: e1c05001 bic r5, r0, r1 ffff5c4c: e5940004 ldr r0, [r4, #0x4] ffff5c50: e3500003 cmp r0, #0x3 ffff5c54: 1a000004 bne 0xffff5c6c ffff5c58: e594000c ldr r0, [r4, #0xc] ffff5c5c: e200800f and r8, r0, #0xf ffff5c60: e5940010 ldr r0, [r4, #0x10] ffff5c64: e200903f and r9, r0, #0x3f ffff5c68: ea000001 b 0xffff5c74 ffff5c6c: e3a08000 mov r8, #0x0 ffff5c70: e3a09000 mov r9, #0x0 ffff5c74: e1850408 orr r0, r5, r8, lsl #0x8 ffff5c78: e1800009 orr r0, r0, r9 ffff5c7c: e59f1024 ldr r1, =0x01c03000 ffff5c80: e581000c str r0, [r1, #0xc] ffff5c84: e5940014 ldr r0, [r4, #0x14] ffff5c88: e1a00480 lsl r0, r0, #0x9 ffff5c8c: e58100a0 str r0, [r1, #0xa0] ffff5c90: e8bd87f0 pop {r4, r5, r6, r7, r8, r9, sl, pc} load_from_spinor: ffff5cb0: e92d41f0 push {r4, r5, r6, r7, r8, lr}; Push vars to stack ffff5cb4: eb00003c bl spinor_setup_clk ; spinor_setup_clk(); ffff5cb8: e3a04000 mov r4, #0x0 ; r4 = 0; ffff5cbc: ea000027 b 0xffff5d60 ; goto err; ffff5cc0: e1a00004 mov r0, r4 ; r0 = r4; ffff5cc4: eb00014f bl f_6208 ffff5cc8: e1a05000 mov r5, r0 ffff5ccc: e3a02001 mov r2, #0x1 ffff5cd0: e3a01000 mov r1, #0x0 ffff5cd4: e1a00001 mov r0, r1 ffff5cd8: e12fff35 blx r5 ffff5cdc: e3500002 cmp r0, #0x2 ffff5ce0: 1a000000 bne 0xffff5ce8 ffff5ce4: ea00001c b 0xffff5d5c ffff5ce8: e28f1084 ldr r1, =eGON_BT0 ffff5cec: e3a00000 mov r0, #0x0 ffff5cf0: eb000152 bl f_6240 ffff5cf4: e3500000 cmp r0, #0x0 ffff5cf8: 0a000000 beq 0xffff5d00 ffff5cfc: ea000016 b 0xffff5d5c ffff5d00: e3a07000 mov r7, #0x0 ffff5d04: e5976010 ldr r6, [r7, #0x10] ffff5d08: e1a00006 mov r0, r6 ffff5d0c: e7df049f bfc r0, #0x9, #0x17 ffff5d10: e3500000 cmp r0, #0x0 ffff5d14: 0a000000 beq 0xffff5d1c ffff5d18: ea00000f b 0xffff5d5c ffff5d1c: e1a02426 lsr r2, r6, #0x8 ffff5d20: e3a01000 mov r1, #0x0 ffff5d24: e1a00001 mov r0, r1 ffff5d28: e12fff35 blx r5 ffff5d2c: e3500002 cmp r0, #0x2 ffff5d30: 1a000000 bne 0xffff5d38 ffff5d34: ea000008 b 0xffff5d5c ffff5d38: e1a01006 mov r1, r6 ffff5d3c: e3a00000 mov r0, #0x0 ffff5d40: eb000151 bl f_628c ffff5d44: e3500000 cmp r0, #0x0 ffff5d48: 1a000002 bne 0xffff5d58 ffff5d4c: eb000035 bl f_5e28 ffff5d50: e3a00000 mov r0, #0x0 ffff5d54: e8bd81f0 pop {r4, r5, r6, r7, r8, pc} ffff5d58: e320f000 nop {0} ffff5d5c: e2844001 add r4, r4, #0x1 err: ffff5d60: e3540002 cmp r4, #0x2 ffff5d64: 3affffd5 bcc 0xffff5cc0 ffff5d68: eb00002e bl f_5e28 ffff5d6c: e3e00000 mvn r0, #0x0 ffff5d70: eafffff7 b 0xffff5d54 ffff5d74: 4e4f4765 cdpmi 7, 4, cr4, cr15, cr5, {3} ffff5d78: 3054422e subscc r4, r4, lr, lsr #0x4 ffff5d7c: 00000000 andeq r0, r0, r0 spinor_setup_pinmux: ffff5d80: e3001333 movw r1, #0x333 ; Configure Port C to SPI0_MOSI, SPI0_MISO, SPI0_CLK in r1 ffff5d84: e59f2498 ldr r2, =0x01c20000 ; load Port IO register (0x01c20800) to r2 ffff5d88: e5821848 str r1, [r2, #0x848] ; store r1 PC_CFG0 (2 * 0x24 + 0x00) ffff5d8c: e3a01203 mov r1, #0x30000000 ; Configure Port C to SPI0_CS0 in r1 ffff5d90: e5821850 str r1, [r2, #0x850] ; store r1 PC_CFG2 (2 * 0x24 + 0x08) ffff5d94: e1c21001 bic r1, r2, r1 ; load Port IO register (0x01c20800) to r1 ffff5d98: e5910868 ldr r0, [r1, #0x868] ; load PC_PULL1 into r0 ffff5d9c: e3c00903 bic r0, r0, #0xc000] ; clear SPI0_CS0 in PC_PULL1 ffff5da0: e3800901 orr r0, r0, #0x4000] ; set SPI0_CS0 as PULLDOWN ffff5da4: e5810868 str r0, [r1, #0x868] ; store PC_PULL1 ffff5da8: e12fff1e bx lr ; return void spinor_setup_pinmux(void) { int reg_val; reg_val = readl(PIO_PC_CFG0); reg_val |= SPI0_MOSI, SPI0_MISO, SPI0_CLK; writel(reg_val, PIO_PC_CFG0); reg_val = readl(PIO_PC_CFG1); reg_val |= SPI0_CS0; writel(reg_val, PIO_PC_CFG1); reg_val = readl(PIO_PC_PULL1); reg_val |= PULL_UP < SPI0_CS0; writel(reg_val, PIO_PC_PULL1); } spinor_setup_clk: ffff5dac: e92d4010 push {r4, lr} ; store load_from_spinor return point in r4 ffff5db0: e59f046c ldr r0, =0x01c20000 ; load CCM (Clock Control Module) main register into r0 ffff5db4: e5900060 ldr r0, [r0, #0x60] ; load CCM_AHB_GATING0 into r0 ffff5db8: e3800601 orr r0, r0, #0x100000 ; enable AHB SPI 0 clock gate in r0 ffff5dbc: e59f1460 ldr r1, =0x01c20000 ; load CCM main reg in r1 ffff5dc0: e5810060 str r0, [r1, #0x60] ; store CCM_AHB_GATING ffff5dc4: e1a00001 mov r0, r1 ; load CCM_AHB_GATING0 into r0 ffff5dc8: e59000a0 ldr r0, [r0, #0xa0] ; load CCM_SPI0_CLK into r0 ffff5dcc: e3800102 orr r0, r0, #-0x80000000 ; enable CCM_SPI0_GATE (with default factors, M=1; N=1; OSC24M) ffff5dd0: e58100a0 str r0, [r1, #0xa0] ; store CCM_SPIO_CLK ffff5dd4: ebffffe9 bl spinor_setup_pinmux ; configure SPI0 pinmuxing ffff5dd8: e59f0444 ldr r0, =0x01c20000 ; load CCM into r0 ffff5ddc: e5900060 ldr r0, [r0, #0x60] ; load CCM_AHB_GATING into r0 ffff5de0: e3800040 orr r0, r0, #0x40 ; enable CCM_AHB_GATE_DMA in r0 ffff5de4: e59f1438 ldr r1, =0x01c20000 ; load CCM_AHB_GATING0 into r1 ffff5de8: e5810060 str r0, [r1, #0x60] ; store CCM_AHB_GATE_DMA in CCM_AHB_GATE_DMA ffff5dec: e3010002 movw r0, #0x1002 ; set SPI0_CLK = AHB_CLK / (2 * (2 + 1)) and set SPI0_DIV_RATE to clock divide rate 2 into r0 ffff5df0: e2411a1b sub r1, r1, #0x1b000 ; subtract 0x1b000 from r1 = 0x1c05000, SPI0 Register ffff5df4: e581001c str r0, [r1, #0x1c] ; store r0 into SPI0_CCTL ffff5df8: e3000202 movw r0, #0x202 ; enable SPI0_DMA_RX_FULL and SPI0_DMA_TX_HALF ffff5dfc: e5810014 str r0, [r1, #0x14] ; store r0 in SPI0_DMACTL ffff5e00: e59f0420 ldr r0, =0x0004831f ; set SPI0_EN, SPI0_MODE_MASTER, SPI0_PHASE_CTL_SETUP, SPI0_CLK_POL_LOW, SPI0_CS_POL_LOW, SPI0_TXFIFO_RST, SPI0_RXFIFO_RST, SPI0_DISCARD_HASH_BURST, SPI0_TX_PAUSE_EN in r0 ffff5e04: e5810008 str r0, [r1, #0x8] ; store r0 in SPI0_CTL ffff5e08: e8bd8010 pop {r4, pc} ; return to load_from_spinor void spinor_setup_clk(void) { int reg_val; reg_val = readl(CCM_AHB_GATING0); reg_val |= CCM_AHB_GATE_SPI0; writel(reg_val, CCM_AHB_GATING0); reg_val = readl(CCM_SPI0_CLK); reg_val |= CCM_SPI0_GATE; writel(reg_val, CCM_SPI0_CLK); spinor_setup_pinmux(); reg_val = readl(SPI0_CCTL); reg_val |= SPIO_AHB_CLK(6) | SPI0_DIV_RATE(2); writel(reg_val, SPIO_CCTL); reg_val = readl(SPI0_DMACTL); reg_val |= SPI0_DMA_RX_FULL | SPI0_DMA_TX_HALF; writel(reg_val, SPI0_DMACTL); reg_val = readl(SPI0_CTL); reg_val |= SPI0_EN | SPI0_MODE_MASTER | SPI0_PHASE_CTL_SETUP | SPI0_CLK_POL_LOW | SPI0_CS_POL_LOW | SPI0_TXFIFO_RST | SPI0_RXFIFO_RST | SPI0_DISCARD_HASH_BURST | SPI0_TX_PAUSE_EN; writel(reg_val, SPI0_CTL); } f_5e0c: ffff5e0c: e3a00000 mov r0, #0x0 ffff5e10: e59f140c ldr r1, =0x01c20000 ffff5e14: e5810848 str r0, [r1, #0x848] ffff5e18: e5810850 str r0, [r1, #0x850] ffff5e1c: e3040016 movw r0, #0x4016 ; PC_PULL1=DEFAULT ffff5e20: e5810868 str r0, [r1, #0x868] ffff5e24: e12fff1e bx lr f_5e28: ffff5e28: e92d4010 push {r4, lr} ffff5e2c: e3a00000 mov r0, #0x0 ffff5e30: e59f13f4 ldr r1, =0x01c05000 ffff5e34: e5810014 str r0, [r1, #0x14] ffff5e38: e1c10000 bic r0, r1, r0 ffff5e3c: e5900008 ldr r0, [r0, #0x8] ffff5e40: e3c00001 bic r0, r0, #0x1 ffff5e44: e5810008 str r0, [r1, #0x8] ffff5e48: ebffffef bl f_5e0c ffff5e4c: e59f03d0 ldr r0, =0x01c20000 ffff5e50: e5900060 ldr r0, [r0, #0x60] ffff5e54: e3c00040 bic r0, r0, #0x40 ffff5e58: e59f13c4 ldr r1, =0x01c20000 ffff5e5c: e5810060 str r0, [r1, #0x60] ffff5e60: e1a00001 mov r0, r1 ffff5e64: e59000a0 ldr r0, [r0, #0xa0] ffff5e68: e3c00102 bic r0, r0, #-0x80000000 ; 0x80000000 ffff5e6c: e58100a0 str r0, [r1, #0xa0] ffff5e70: e1a00001 mov r0, r1 ffff5e74: e5900060 ldr r0, [r0, #0x60] ffff5e78: e3c00601 bic r0, r0, #0x100000 ffff5e7c: e5810060 str r0, [r1, #0x60] ffff5e80: e8bd8010 pop {r4, pc} int check_dma_1(retry): ffff5e84: e1a01000 mov r1, r0 ; r1 = r0 ffff5e88: e320f000 nop {0} ; nop ffff5e8c: e59f039c ldr r0, =0x01c02000 ; load DMA base reg into r0 ffff5e90: e5900120 ldr r0, [r0, #0x120] ; load DMA_NORM_CTRL(1) ffff5e94: e3100102 tst r0, #-0x80000000 ; test if DMA_LOAD is still running ffff5e98: 1a000001 bne 0xffff5ea4 ; DMA is still running, continue loop ffff5e9c: e3a00000 mov r0, #0x0 ; r0 = 0 ffff5ea0: e12fff1e bx lr ; return ffff5ea4: e2410001 sub r0, r1, #0x1 ; r0 = r1 - 1 ffff5ea8: e1b01000 movs r1, r0 ; r1 = r0 ffff5eac: 1afffff6 bne 0xffff5e8c ; if r1 != 0, loop ffff5eb0: e3a00002 mov r0, #0x2 ; r0 = 2 ffff5eb4: eafffff9 b 0xffff5ea0 ; return int check_dma_1(int retry) { int regval; for (;retry > 0; retry--) { regval = readl(DMA_NORM_CTRL(1)) if (regval & !DMA_LOAD) return 0; } return 2; } int check_dma_2(retry): ffff5eb8: e1a01000 mov r1, r0 ; r1 = r0 ffff5ebc: e320f000 nop {0} ; nop ffff5ec0: e59f0368 ldr r0, =0x01c02000 ; load DMA register offset into r0 ffff5ec4: e5900140 ldr r0, [r0, #0x140] ; load DMA_NORM_CTRL(2) ffff5ec8: e3100102 tst r0, #-0x80000000 ; test if DMA_LOAD is still running ffff5ecc: 1a000001 bne 0xffff5ed8 ; DMA is still running, continue loop ffff5ed0: e3a00000 mov r0, #0x0 ; r0 = 0 ffff5ed4: e12fff1e bx lr ; return ffff5ed8: e2410001 sub r0, r1, #0x1 ; r0 = r1 - 1 ffff5edc: e1b01000 movs r1, r0 ; r1 = r0 ffff5ee0: 1afffff6 bne 0xffff5ec0 ; if r1 != 0, loop ffff5ee4: e3a00002 mov r0, #0x2 ; r0 = 2 ffff5ee8: eafffff9 b 0xffff5ed4 ; return int check_dma_2(int retry) { int regval; for (;retry > 0; retry--) { regval = readl(DMA_NORM_CTRL(2)) if (regval & !DMA_LOAD) return 0; } return 2; } int wait_spi0_irq_busy(void): ffff5eec: e30f1fff movw r1, #0xffff ; r1 = 0xffff ffff5ef0: e320f000 nop {0} ; nop ffff5ef4: e1b00001 movs r0, r1 ; r0 = r1 ffff5ef8: e2411001 sub r1, r1, #0x1 ; r1 = r1 - 1 ffff5efc: 0a000003 beq 0xffff5f10 ; if r1 != 0 ffff5f00: e59f0324 ldr r0, =0x01c05000 ; load SPI0 base register into r0 ffff5f04: e5900010 ldr r0, [r0, #0x10] ; load SPI0_IRQ_STATUS register into r0 ffff5f08: e3100102 tst r0, #-0x80000000 ; test if SPI0_IRQ_STATUS | SPI_IRQ_CLEAR_BUSY ffff5f0c: 1afffff8 bne 0xffff5ef4 ; if SPI_IRQ_CLEAR_BUSY is not done, loop ffff5f10: e3510000 cmp r1, #0x0 ; if r1 = 0 ffff5f14: da000001 ble 0xffff5f20 ; if r1 < 0 return ffff5f18: e3a00000 mov r0, #0x0 ; r0 = 0 ffff5f1c: e12fff1e bx lr ; return ffff5f20: e3a00002 mov r0, #0x2 ; r0 = 2 ffff5f24: eafffffc b 0xffff5f1c ; return int wait_spi0_irq_busy(void) { int retry; int regval; for (retry = 0xffff; retry < 0; retry--) { regval = readl(SPI0_IRQ_STATUS); if (regval & !SPI_IRQ_CLEAR_BUSY) return 0; } return 2; } int wait_spi0_txfifo(int delay): ffff5f28: e1a01000 mov r1, r0 ; r1 = r0 ffff5f2c: e320f000 nop {0} ; nop ffff5f30: e59f02f4 ldr r0, =0x01c05000 ; load SPI0 base register into r0 ffff5f34: e5900010 ldr r0, [r0, #0x10] ; load SPI0_IRQ_STATUS register into r0 ffff5f38: e3100801 tst r0, #0x10000 ; test if SPI_TX_FIFO_75EMPTY is more then 75% empty ffff5f3c: 0a000001 beq 0xffff5f48 ; if empty continue ffff5f40: e3a00000 mov r0, #0x0 ; r0 = 0 ffff5f44: e12fff1e bx lr ; return ffff5f48: e2410001 sub r0, r1, #0x1 ; r0 = r1 - 1 ffff5f4c: e1b01000 movs r1, r0 ; r1 = r0 ffff5f50: 1afffff6 bne 0xffff5f30 ; loop again ffff5f54: e3a00002 mov r0, #0x2 ; r0 = 2 ffff5f58: eafffff9 b 0xffff5f44 ; return int wait_spi0_txfifo(int delay) { int regval; for (;delay > 0; delay--) { regval = readl(SPI0_IRQ_STATUS); if (regval | SPI_TX_FIFO_75EMPTY); return 0; } return 2; } f_5f5c: int spi_setup_dma(burst_cnt1, burst_cnt2, dma_src_addr, dma_dest_addr): ffff5f5c: e92d41f0 push {r4, r5, r6, r7, r8, lr} ffff5f60: e1a04000 mov r4, r0 ; r4 = r0 ffff5f64: e1a05001 mov r5, r1 ; r5 = r1 ffff5f68: e1a06002 mov r6, r2 ; r6 = r2 ffff5f6c: e1a07003 mov r7, r3 ; r7 = r3 ffff5f70: e0840005 add r0, r4, r5 ; r0 = r4 + r5 ffff5f74: e2808e96 add r8, r0, #0x960 ; r8 = r0 + 2400 ffff5f78: e0840005 add r0, r4, r5 ; r0 = r4 + r5 ffff5f7c: e59f12a8 ldr r1, =0x01c05000 ; load SPI0 base register address into r1 ffff5f80: e5810020 str r0, [r1, #0x20] ; store r0 into SPI0_BURST_CNT ffff5f84: e1a00001 mov r0, r1 ; r0 = r1 ffff5f88: e5804024 str r4, [r0, #0x24] ; store r4 in SPI0_TX_CNT ffff5f8c: e2400a03 sub r0, r0, #0x3000 ; r0 -= 0x3000; r0, =0x01c02000 ffff5f90: e5806144 str r6, [r0, #0x144] ; store r6 in DMA_NORM_SRC_ADDR(2) ffff5f94: e2810004 add r0, r1, #0x4 ; r0 = r1 + 4; r0, =0x01c05004 ffff5f98: e2411a03 sub r1, r1, #0x3000 ; r1 -= 0x3000; r1, =0x01c02000 ffff5f9c: e5810148 str r0, [r1, #0x148] ; store r0 (SPI0_TXDATA) in DMA_NORM_DEST_ADDR(2) ffff5fa0: e1c101c0 bic r0, r1, r0, asr #0x3 ; r0 = r1 &!(r0 >> 3); r0 = 0x400; ffff5fa4: e580414c str r4, [r0, #0x14c] ; store r4 in DMA_NORM_CNT(2) ffff5fa8: e59f0284 ldr r0, =0x9c380415 ; set DMA_NORM_SRC_DRQ_TYPE(SRAM), DMA_NORM_SRC_WIDTH(32), DMA_NORM_DEST_DRQ_TYPE(SPI0_TX), DMA_NORM_DEST_ADDR_NON_INCR, DMA_NORM_DEST_DATA_WIDTH(32), DMA_WAIT_STATE(3), DMA_LOAD ffff5fac: e5810140 str r0, [r1, #0x140] ; store r0 in DMA_NORM_CTRL(2) ffff5fb0: e2810a03 add r0, r1, #0x3000 ; r0 = r1 + 0x3000; r0 = 0x01c05000 ffff5fb4: e5810124 str r0, [r1, #0x124] ; store r0 in DMA_NORM_SRC_ADDR(1) ffff5fb8: e2400a03 sub r0, r0, #0x3000 ; r0 = r0 - 0x3000; r0 = 0x01c02000 ffff5fbc: e5807128 str r7, [r0, #0x128] ; store r7 in DMA_NORM_DEST_ADDR(1) ffff5fc0: e580512c str r5, [r0, #0x12c] ; store r5 in DMA_NORM_CNT(1) ffff5fc4: e59f026c ldr r0, =0x9c150438 ; set DMA_SRC_DRQ_TYPE(SPI0_RX), DMA_NORM_SRC_ADDR_NON_INCR, DMA_NORM_SRC_WIDTH(32), DMA_NORM_DEST_DRQ_TYPE(SRAM), DMA_NORM_DEST_DATA_WIDTH(32), DmA_WAIT_STATE(3), DMA_LOAD ffff5fc8: e5810120 str r0, [r1, #0x120] ; store r0 in DMA_NORM_CTRL(1) ffff5fcc: e2810a03 add r0, r1, #0x3000 ; r0 = r1 + 0x3000; r0 = 0x01c05000 ffff5fd0: e5900008 ldr r0, [r0, #0x8] ; r0 = SPI0_CTL ffff5fd4: e3800b01 orr r0, r0, #0x400 ; r0 = r0 | SPI0_XCHANGE_BURST ffff5fd8: e2811a03 add r1, r1, #0x3000 ; r1 += 0x03000; r1 = 0x01c05000 ffff5fdc: e5810008 str r0, [r1, #0x8] ; store r0 in SPI0_CTL ffff5fe0: e1a00008 mov r0, r8 ; r0 = r8 ffff5fe4: ebffffb3 bl check_dma_2() ; r0 = check_dma_2(r0) /* check_dma_2(burst_cnt1 + burst_cnt2 + 2400) */ ffff5fe8: e3500002 cmp r0, #0x2 ; test if r0 == 2 ffff5fec: 1a00000a bne 0xffff601c ; else do dma_check_2(r0) +4 (without popping stack) ffff5ff0: e59f0238 ldr r0, =0x01c02000 ; load DMA base reg into r0 ffff5ff4: e5900140 ldr r0, [r0, #0x140] ; load DMA_NORM_CTRL(2) into r0 ffff5ff8: e3c00102 bic r0, r0, #-0x80000000 ; r0 = DMA_NORM_CTRL(2) & !DMA_LOAD /* reset DMA channel 2 */ ffff5ffc: e59f122c ldr r1, =0x01c02000 ; load DMA base reg into r1 ffff6000: e5810140 str r0, [r1, #0x140] ; store r0 into DMA_NORM_CTRL(2) ffff6004: e1a00001 mov r0, r1 ; r0 = r1 ffff6008: e5900120 ldr r0, [r0, #0x120] ; load DMA_NORM_CTRL(1) into r0 ffff600c: e3c00102 bic r0, r0, #-0x80000000 ; r0 = DMA_NORM_CTRL(1) & !DMA_LOAD /* reset DMA channel 1 */ ffff6010: e5810120 str r0, [r1, #0x120] ; store r0 into DMA_NORM_CTRL(1) ffff6014: e3a00002 mov r0, #0x2 ; r0 = 2 /* dma_check_2(2) ffff6018: e8bd81f0 pop {r4, r5, r6, r7, r8, pc}; pop stack dma_check_2: ffff601c: e1a00008 mov r0, r8 ; r0 = r8 ffff6020: ebffff97 bl check_dma_1() ; r0 = check_dma_1(r0); /* check_dma_1(burst_cnt1 +burst_cnt2 + 2400) */ ffff6024: e3500002 cmp r0, #0x2 ; if r0 == 2 skip to dma_check_1 ffff6028: 1a00000a bne 0xffff6058 ; else continue ffff602c: e59f01fc ldr r0, =0x01c02000 ; load DMA base reg into r0 ffff6030: e5900140 ldr r0, [r0, #0x140] ; load DMA_NORM_CTRL(2) into r0 ffff6034: e3c00102 bic r0, r0, #-0x80000000 ; r0 = DMA_NORM_CTRL(2) & !DMA_LOAD /* reset DMA channel 2 */ ffff6038: e59f11f0 ldr r1, =0x01c02000 ; load DMA base reg into r1 ffff603c: e5810140 str r0, [r1, #0x140] ; store r0 into DMA_NORM_CTRL(2) ffff6040: e1a00001 mov r0, r1 ; r0 = r1 ffff6044: e5900120 ldr r0, [r0, #0x120] ; load DMA_NORM_CTRL(1) into r0 ffff6048: e3c00102 bic r0, r0, #-0x80000000 ; r0 = DMA_NORM_CTLR(1) & !DMA_LOAD /* reset DMA channel 1 */ ffff604c: e5810120 str r0, [r1, #0x120] ; store r0 in DMA_NORM_CTRL(1) ffff6050: e3a00002 mov r0, #0x2 ; r0 = 2 ffff6054: eaffffef b 0xffff6018 ; else go to dma_check_2(2) efff6058: e1a00008 mov r0, r8 ; r0 = r8; ffff605c: ebffffb1 bl wait_spi0_txfifo() ; r0 = wait_spi0_txfifo(r0) ffff6060: e3500002 cmp r0, #0x2 ; if r0 = 2 ffff6064: 1a00000a bne 0xffff6094 ; skip if not 2 ffff6068: e59f01c0 ldr r0, =0x01c02000 ; load DMA base reg into r0 ffff606c: e5900140 ldr r0, [r0, #0x140] ; load DMA_NORM_CTRL(2) into r0 ffff6070: e3c00102 bic r0, r0, #-0x80000000 ; r0 = DMA_NORM_CTRL(2) & !DMA_LOAD /* reset DMA channel 2 */ ffff6074: e59f11b4 ldr r1, =0x01c02000 ; load DMA base reg into r1 ffff6078: e5810140 str r0, [r1, #0x140] ; store r0 into DMA_NORM_CTRL(2) ffff607c: e1a00001 mov r0, r1 ; r0 = r1 ffff6080: e5900120 ldr r0, [r0, #0x120] ; load DMA_NORM_CTRL(1) into r0 ffff6084: e3c00102 bic r0, r0, #-0x80000000 ; r0 = DMA_NORM_CTLR(1) & !DMA_LOAD /* reset DMA channel 1 */ ffff6088: e5810120 str r0, [r1, #0x120] ; store r0 into DMA_NORM_CTRL(1) ffff608c: e3a00002 mov r0, #0x2 ; r0 = 2 ffff6090: eaffffe0 b 0xffff6018 ; restart at dma_check_2(2) ffff6094: e59f0194 ldr r0, =0x01c02000 ; load DMA base reg into r0 ffff6098: e5900140 ldr r0, [r0, #0x140] ; load DMA_NORM_CTRL(2) into r0 ffff609c: e3c00102 bic r0, r0, #-0x80000000 ; r0 = DMA_NORM_CTRL(2) & !DMA_LOAD /* reset DMA channel 2 */ ffff60a0: e59f1188 ldr r1, =0x01c02000 ; load DMA base reg into r1 ffff60a4: e5810140 str r0, [r1, #0x140] ; store r0 in DMA_NORM_CTRL(2) ffff60a8: e1a00001 mov r0, r1 ; r0 = r1 ffff60ac: e5900120 ldr r0, [r0, #0x120] ; load DMA_NORM_CTRL(1) into r0 ffff60b0: e3c00102 bic r0, r0, #-0x80000000 ; r0 = DMA_NORM_CTLR(1) & !DMA_LOAD /* reset DMA channel 1 */ ffff60b4: e5810120 str r0, [r1, #0x120] ; store r0 in DMA_NORM_CTRL(1) ffff60b8: e2810a03 add r0, r1, #0x3000 ; r0 = r1 + 0x3000; r0 = 0x01c05000 ffff60bc: e5900010 ldr r0, [r0, #0x10] ; load SPI0_IRQ_STATUS register into r0 ffff60c0: e3800801 orr r0, r0, #0x10000 ; r0 = SPI0_IRQ_STATUS | SPI_TX_DONE ffff60c4: e2811a03 add r1, r1, #0x3000 ; r1 = r1 + 0x3000; r1 = 0x01c05000 ffff60c8: e5810010 str r0, [r1, #0x10] ; store r1 in SPI0_IRQ_STATUS ffff60cc: ebffff86 bl wait_spi0_irq_busy() ; r0 = wait_spi0_irq_busy(); ffff60d0: e3500002 cmp r0, #0x2 ; if r0 = 2 ffff60d4: 1a000001 bne 0xffff60e0 ; restart at dma_check_2(0) ffff60d8: e3a00002 mov r0, #0x2 ; r0 = 2 ffff60dc: eaffffcd b 0xffff6018 ; restart at dma_check_2(2) ffff60e0: e3a00000 mov r0, #0x0 ; r0 = 0 ffff60e4: eaffffcb b 0xffff6018 ; restart at dma_check_2(0) f_60e8: ffff60e8: e92d4ff8 push {r3, r4, r5, r6, r7, r8, r9, sl, fp, lr} ffff60ec: e1a04000 mov r4, r0 ; r4 = r0 ffff60f0: e1a05001 mov r5, r1 ; r5 = r1 ffff60f4: e1a06002 mov r6, r2 ; r6 = r2 ffff60f8: e1a0b005 mov fp, r5 ; fp = r5 ffff60fc: e3a08000 mov r8, #0x0 ; r8 = 0; ffff6100: e1a07404 lsl r7, r4, #0x8 ; r7 = r4 << 8 ffff6104: e1a0a406 lsl sl, r6, #0x8 ; sl = r6 << 8 ffff6108: ea000018 b 0xffff6170 ; goto err ffff610c: e3a00003 mov r0, #0x3 ; r0 = 3 ffff6110: e5cd0000 strb r0, [sp] ; store r0 in sp ffff6114: e1a00827 lsr r0, r7, #0x10 ; r0 = r7 >> 10 ffff6118: e5cd0001 strb r0, [sp, #0x1] ; store r0 in sp +1 ffff611c: e1a00427 lsr r0, r7, #0x8 ; r0 = r7 >> 8 ffff6120: e5cd0002 strb r0, [sp, #0x2] ; store r0 in sp + 2 ffff6124: e5cd7003 strb r7, [sp, #0x3] ; store r7 in sp + 3 ffff6128: e04a0008 sub r0, sl, r8 ; r0 = sl - r8 ffff612c: e3500b02 cmp r0, #0x800 ; if (r0 = 0x800) ffff6130: 9a000001 bls 0xffff613c ; ffff6134: e3a00b02 mov r0, #0x800 ; r0 = 0x800 ffff6138: ea000000 b 0xffff6140 ; else ffff613c: e04a0008 sub r0, sl, r8 ; r0 = sl - r8 ffff6140: e1a09000 mov r9, r0 ; r9 = r0 ffff6144: e08b3008 add r3, fp, r8 ; r3 = fp + r8 ffff6148: e1a0200d mov r2, sp ; r2 = sp ffff614c: e1a01009 mov r1, r9 ; r1 = r9 ffff6150: e3a00004 mov r0, #0x4 ; r0 = 4 ffff6154: ebffff80 bl f_5f5c ffff6158: e3500002 cmp r0, #0x2 ffff615c: 1a000001 bne 0xffff6168 ffff6160: e3a00002 mov r0, #0x2 ffff6164: e8bd8ff8 pop {r3, r4, r5, r6, r7, r8, r9, sl, fp, pc} ffff6168: e0877009 add r7, r7, r9 ffff616c: e0888009 add r8, r8, r9 err: ffff6170: e158000a cmp r8, sl ffff6174: 3affffe4 bcc 0xffff610c ffff6178: e3a00000 mov r0, #0x0 ffff617c: eafffff8 b 0xffff6164 f_6180: ffff6180: e92d47fc push {r2, r3, r4, r5, r6, r7, r8, r9, sl, lr} ffff6184: e1a04000 mov r4, r0 ffff6188: e1a05001 mov r5, r1 ffff618c: e1a06002 mov r6, r2 ffff6190: e1a09005 mov r9, r5 ffff6194: e3a00000 mov r0, #0x0 ffff6198: e58d0004 str r0, [sp, #0x4] ffff619c: e3a07000 mov r7, #0x0 ffff61a0: e3a0a000 mov sl, #0x0 ffff61a4: e1a08484 lsl r8, r4, #0x9 ffff61a8: ea000012 b 0xffff61f8 ffff61ac: e3a000e8 mov r0, #0xe8 ffff61b0: e5cd0000 strb r0, [sp] ffff61b4: e1a00828 lsr r0, r8, #0x10 ffff61b8: e5cd0001 strb r0, [sp, #0x1] ffff61bc: e1a00428 lsr r0, r8, #0x8 ffff61c0: e5cd0002 strb r0, [sp, #0x2] ffff61c4: e5cd8003 strb r8, [sp, #0x3] ffff61c8: e089300a add r3, r9, sl ffff61cc: e1a0200d mov r2, sp ffff61d0: e3a01c01 mov r1, #0x100 ffff61d4: e3a00008 mov r0, #0x8 ffff61d8: ebffff5f bl f_5f5c ffff61dc: e3500002 cmp r0, #0x2 ffff61e0: 1a000001 bne 0xffff61ec ffff61e4: e3a00002 mov r0, #0x2 ffff61e8: e8bd87fc pop {r2, r3, r4, r5, r6, r7, r8, r9, sl, pc} ffff61ec: e2877001 add r7, r7, #0x1 ffff61f0: e28aac01 add sl, sl, #0x100 ffff61f4: e2888c02 add r8, r8, #0x200 ffff61f8: e1570006 cmp r7, r6 ffff61fc: 3affffea bcc 0xffff61ac ffff6200: e3a00000 mov r0, #0x0 ffff6204: eafffff7 b 0xffff61e8 f_6208: ffff6208: e92d400c push {r2, r3, lr} ; psuh r2, r3 and lr onto the stack ffff620c: e1a01000 mov r1, r0 ; r1 = r0 ffff6210: e59f2024 ldr r2, =d_6608 ; ffff6214: e8920005 ldm r2, {r0, r2} ffff6218: e88d0005 stm sp, {r0, r2} ffff621c: e79d0101 ldr r0, [sp, r1, lsl #0x2] ffff6220: e8bd800c pop {r2, r3, pc} f_6240: ffff6240: e92d40f0 push {r4, r5, r6, r7, lr} ffff6244: e1a02000 mov r2, r0 ffff6248: e1a03002 mov r3, r2 ffff624c: e1a02003 mov r2, r3 ffff6250: e2836004 add r6, r3, #0x4 ffff6254: e3a04000 mov r4, #0x0 ffff6258: e3a05008 mov r5, #0x8 ffff625c: ea000006 b 0xffff627c ffff6260: e4d60001 ldrb r0, [r6], #0x1 ffff6264: e4d17001 ldrb r7, [r1], #0x1 ffff6268: e1500007 cmp r0, r7 ffff626c: 0a000001 beq 0xffff6278 ffff6270: e3a00001 mov r0, #0x1 ffff6274: e8bd80f0 pop {r4, r5, r6, r7, pc} ffff6278: e2844001 add r4, r4, #0x1 ffff627c: e1540005 cmp r4, r5 ffff6280: 3afffff6 bcc 0xffff6260 ffff6284: e3a00000 mov r0, #0x0 ffff6288: eafffff9 b 0xffff6274 f_628c: ffff628c: e92d40f0 push {r4, r5, r6, r7, lr} ffff6290: e1a02000 mov r2, r0 ffff6294: e1a06002 mov r6, r2 ffff6298: e1a02006 mov r2, r6 ffff629c: e596500c ldr r5, [r6, #0xc] ffff62a0: e59f00c0 ldr r0, =0x5f0a6c39 ffff62a4: e1a02006 mov r2, r6 ffff62a8: e586000c str r0, [r6, #0xc] ffff62ac: e1a04121 lsr r4, r1, #0x2 ffff62b0: e3a07000 mov r7, #0x0 ffff62b4: e1a03002 mov r3, r2 ffff62b8: e320f000 nop {0} ffff62bc: e4930004 ldr r0, [r3], #0x4 ffff62c0: e0877000 add r7, r7, r0 ffff62c4: e4930004 ldr r0, [r3], #0x4 ffff62c8: e0877000 add r7, r7, r0 ffff62cc: e4930004 ldr r0, [r3], #0x4 ffff62d0: e0877000 add r7, r7, r0 ffff62d4: e4930004 ldr r0, [r3], #0x4 ffff62d8: e0877000 add r7, r7, r0 ffff62dc: e2440004 sub r0, r4, #0x4 ffff62e0: e1a04000 mov r4, r0 ffff62e4: e3500003 cmp r0, #0x3 ffff62e8: 8afffff3 bhi 0xffff62bc ffff62ec: ea000001 b 0xffff62f8 ffff62f0: e4930004 ldr r0, [r3], #0x4 ffff62f4: e0877000 add r7, r7, r0 ffff62f8: e1b00004 movs r0, r4 ffff62fc: e2444001 sub r4, r4, #0x1 ffff6300: 1afffffa bne 0xffff62f0 ffff6304: e586500c str r5, [r6, #0xc] ffff6308: e1570005 cmp r7, r5 ffff630c: 1a000001 bne 0xffff6318 ffff6310: e3a00000 mov r0, #0x0 ffff6314: e8bd80f0 pop {r4, r5, r6, r7, pc} ffff6318: e3a00001 mov r0, #0x1 ffff631c: eafffffc b 0xffff6314 ffff6320: e92d4070 push {r4, r5, r6, lr} ffff6324: e1a04000 mov r4, r0 ffff6328: e1a05001 mov r5, r1 ffff632c: e1a06002 mov r6, r2 ffff6330: e1a01006 mov r1, r6 ffff6334: e1a00004 mov r0, r4 ffff6338: ebffffc0 bl f_6240 ffff633c: e3500000 cmp r0, #0x0 ffff6340: 1a000006 bne 0xffff6360 ffff6344: e1a01005 mov r1, r5 ffff6348: e1a00004 mov r0, r4 ffff634c: ebffffce bl f_628c ffff6350: e3500000 cmp r0, #0x0 ffff6354: 1a000001 bne 0xffff6360 ffff6358: e3a00000 mov r0, #0x0 ffff635c: e8bd8070 pop {r4, r5, r6, pc} ffff6360: e3a00001 mov r0, #0x1 ffff6364: eafffffc b 0xffff635c udelay: ffff636c: e1a01000 mov r1, r0 ffff6370: ea000000 b 0xffff6378 ffff6374: e2411001 sub r1, r1, #0x1 ffff6378: e3510000 cmp r1, #0x0 ffff637c: cafffffc bgt 0xffff6374 ffff6380: e12fff1e bx lr check_uboot: ffff6384: e92d4070 push {r4, r5, r6, lr} ffff6388: e3a05000 mov r5, #0x0 ffff638c: e3a0603c mov r6, #0x3c ffff6390: e3a04004 mov r4, #0x4 ffff6394: ea000006 b 0xffff63b4 ffff6398: e1a00006 mov r0, r6 ffff639c: ebfffff2 bl udelay ffff63a0: e3a00507 mov r0, #0x1c00000 ffff63a4: e5900024 ldr r0, [r0, #0x24] ; = 0x1c00024 FEL button? ffff63a8: e7e00450 ubfx r0, r0, #0x8, #0x1 ffff63ac: e0855000 add r5, r5, r0 ffff63b0: e2444001 sub r4, r4, #0x1 ffff63b4: e3540000 cmp r4, #0x0 ffff63b8: cafffff6 bgt 0xffff6398 ffff63bc: e3550000 cmp r5, #0x0 ffff63c0: 1a000001 bne 0xffff63cc ffff63c4: e3e00000 mvn r0, #0x0 ffff63c8: e8bd8070 pop {r4, r5, r6, pc} ffff63cc: e3a00000 mov r0, #0x0 ffff63d0: eafffffc b 0xffff63c8 ffff63d4: e12fff1e bx lr memcpy: ffff63d8: e92d41f0 push {r4, r5, r6, r7, r8, lr} ffff63dc: e2522020 subs r2, r2, #0x20 ffff63e0: 3a00000d bcc 0xffff641c ffff63e4: e3520e12 cmp r2, #0x120 ffff63e8: 3a000007 bcc 0xffff640c ffff63ec: f5d1f100 pld [r1, #0x100] ffff63f0: e8b151f8 ldm r1!, {r3, r4, r5, r6, r7, r8, ip, lr} ffff63f4: e2422040 sub r2, r2, #0x40 ffff63f8: e3520e12 cmp r2, #0x120 ffff63fc: e8a051f8 stmia r0!, {r3, r4, r5, r6, r7, r8, ip, lr} ffff6400: e8b151f8 ldm r1!, {r3, r4, r5, r6, r7, r8, ip, lr} ffff6404: e8a051f8 stmia r0!, {r3, r4, r5, r6, r7, r8, ip, lr} ffff6408: 2afffff7 bcs 0xffff63ec ffff640c: e8b151f8 ldm r1!, {r3, r4, r5, r6, r7, r8, ip, lr} ffff6410: e2522020 subs r2, r2, #0x20 ffff6414: e8a051f8 stmia r0!, {r3, r4, r5, r6, r7, r8, ip, lr} ffff6418: 2afffffb bcs 0xffff640c ffff641c: e1b0ce02 lsls ip, r2, #0x1c ffff6420: 28b15018 ldmcs r1!, {r3, r4, ip, lr} ffff6424: 28a05018 stmiacs r0!, {r3, r4, ip, lr} ffff6428: 48b10018 ldmmi r1!, {r3, r4} ffff642c: 48a00018 stmiami r0!, {r3, r4} ffff6430: e8bd41f0 pop {r4, r5, r6, r7, r8, lr} ffff6434: e1b0cf02 lsls ip, r2, #0x1e ffff6438: 24913004 ldrcs r3, [r1], #0x4 ffff643c: 24803004 strcs r3, [r0], #0x4 ffff6440: 012fff1e bxeq lr ffff6444: e1b02f82 lsls r2, r2, #0x1f ffff6448: 20d130b2 ldrhcs r3, [r1], #0x2 ffff644c: 44d12001 ldrbmi r2, [r1], #0x1 ffff6450: 20c030b2 strhcs r3, [r0], #0x2 ffff6454: 44c02001 strbmi r2, [r0], #0x1 ffff6458: e12fff1e bx lr call_r0: ffff645c: e1a0f000 mov pc, r0 d_6460: ffff6460: .l 0x00000000 ffff6464: .l 0x00000000 ffff6468: .l 0x00000001 ffff646c: .l 0x00000200 ffff6470: .l 0x00ffffff ffff6474: .l 0x000000ff d_6478: ffff6478: .l nand_read_a_blocks ffff647c: .l 0x00000000 ffff6480: .l 0x00000001 ffff6484: .l 0x00000000 ffff6488: .l 0x00000000 ffff648c: .l 0x00000002 ffff6490: .l 0x00000001 ffff6494: .l 0x00000040 ffff6498: .l 0x00000001 ffff649c: .l 0x00000400 ffff64a0: .l f_58ec ffff64a4: .l 0x00000000 ffff64a8: .l 0x00000000 ffff64ac: .l 0x00000000 ffff64b0: .l 0x00000000 ffff64b4: .l 0x00000002 ffff64b8: .l 0x00000001 ffff64bc: .l 0x00000040 ffff64c0: .l 0x00000001 ffff64c4: .l 0x00000200 ffff64c8: .l nand_read_a_blocks ffff64cc: .l 0x00000000 ffff64d0: .l 0x00000000 ffff64d4: .l 0x00000000 ffff64d8: .l 0x00000000 ffff64dc: .l 0x00000002 ffff64e0: .l 0x00000000 ffff64e4: .l 0x00000040 ffff64e8: .l 0x00000001 ffff64ec: .l 0x00000400 ffff64f0: .l f_58ec ffff64f4: .l 0x00000000 ffff64f8: .l 0x00000000 ffff64fc: .l 0x00000000 ffff6500: .l 0x00000000 ffff6504: .l 0x00000002 ffff6508: .l 0x00000000 ffff650c: .l 0x00000040 ffff6510: .l 0x00000001 ffff6514: .l 0x00000200 ffff6518: .l nand_read_a_blocks ffff651c: .l 0x00000003 ffff6520: .l 0x00000001 ffff6524: .l 0x00000001 ffff6528: .l 0x0000003f ffff652c: .l 0x00000002 ffff6530: .l 0x00000001 ffff6534: .l 0x00000040 ffff6538: .l 0x00000001 ffff653c: .l 0x00000400 ffff6540: .l nand_read_a_blocks ffff6544: .l 0x00000003 ffff6548: .l 0x00000000 ffff654c: .l 0x00000002 ffff6550: .l 0x0000003f ffff6554: .l 0x00000002 ffff6558: .l 0x00000001 ffff655c: .l 0x00000040 ffff6560: .l 0x00000001 ffff6564: .l 0x00000400 ffff6568: .l nand_read_a_blocks ffff656c: .l 0x00000003 ffff6570: .l 0x00000000 ffff6574: .l 0x00000003 ffff6578: .l 0x0000003f ffff657c: .l 0x00000002 ffff6580: .l 0x00000001 ffff6584: .l 0x00000040 ffff6588: .l 0x00000001 ffff658c: .l 0x00000400 ffff6590: .l f_58ec ffff6594: .l 0x00000003 ffff6598: .l 0x00000000 ffff659c: .l 0x00000001 ffff65a0: .l 0x0000003f ffff65a4: .l 0x00000002 ffff65a8: .l 0x00000001 ffff65ac: .l 0x00000040 ffff65b0: .l 0x00000001 ffff65b4: .l 0x00000200 ffff65b8: .l f_58ec ffff65bc: .l 0x00000003 ffff65c0: .l 0x00000000 ffff65c4: .l 0x00000002 ffff65c8: .l 0x0000003f ffff65cc: .l 0x00000002 ffff65d0: .l 0x00000001 ffff65d4: .l 0x00000040 ffff65d8: .l 0x00000001 ffff65dc: .l 0x00000200 ffff65e0: .l f_58ec ffff65e4: .l 0x00000003 ffff65e8: .l 0x00000000 ffff65ec: .l 0x00000003 ffff65f0: .l 0x0000003f ffff65f4: .l 0x00000002 ffff65f8: .l 0x00000001 ffff65fc: .l 0x00000040 ffff6600: .l 0x00000001 ffff6604: .l 0x00000200 d_6608: ffff6608: .l f_60e8 ffff660c: .l f_6180