Changes in boot/arch/arm32/src/asm.S [24bead17:b5a3b50] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
boot/arch/arm32/src/asm.S
r24bead17 rb5a3b50 61 61 # 62 62 63 # 64 # r0 is kernel entry point 65 # r1 is pointer to the bootinfo structure 63 #if defined(MACHINE_gta02) 66 64 67 65 #define CP15_C1_IC 12 68 #define CP15_C1_BP 1169 66 #define CP15_C1_DC 2 67 #define CP15_C7_SEG_SHIFT 5 68 #define CP15_C7_SEG_SIZE 3 69 #define CP15_C7_IDX_SHIFT 26 70 70 71 # Disable I-cache and D-cache before the kernel is started. 71 72 mrc p15, 0, r4, c1, c0, 0 72 73 bic r4, r4, #(1 << CP15_C1_DC) 73 74 bic r4, r4, #(1 << CP15_C1_IC) 74 bic r4, r4, #(1 << CP15_C1_BP)75 75 mcr p15, 0, r4, c1, c0, 0 76 76 77 78 #Wait for the operations to complete 79 #ifdef PROCESSOR_ARCH_armv7_a 80 dsb 81 #else 82 #cp15 dsb, r4 is ignored (should be zero) 83 mcr p15, 0, r4, c7, c10, 4 77 # Now clean D-cache to guarantee coherency between I-cache and D-cache. 78 79 # D-cache clean and invalidate procedure. 80 # See ARM920T TRM pages 2-17, 4-17. 81 82 # Initialize segment 83 mov r4, #0 84 # Initialize index 85 1: mov r5, #0 86 2: orr r6, r4, r5 87 # Clean and invalidate a single line 88 mcr p15, 0, r6, c7, c10, 2 89 # Increment index 90 add r5, r5, #(1 << CP15_C7_IDX_SHIFT) 91 cmp r5, #0 92 bne 2b 93 # Increment segment 94 add r4, #(1 << CP15_C7_SEG_SHIFT) 95 tst r4, #(1 << (CP15_C7_SEG_SHIFT + CP15_C7_SEG_SIZE)) 96 beq 1b 84 97 #endif 85 86 # Clean ICache and BPredictors, r4 ignored (SBZ)87 mcr p15, 0, r4, c7, c5, 088 nop89 98 90 #Wait for the operations to complete91 #ifdef PROCESSOR_ARCH_armv7_a92 isb93 nop94 #else95 # cp15 isb96 mcr p15, 0, r4, c7, c5, 497 nop98 #endif99 99 mov pc, r0
Note:
See TracChangeset
for help on using the changeset viewer.