Lines Matching +full:10 +full:base +full:- +full:te
1 /* SPDX-License-Identifier: GPL-2.0-only */
5 * Copyright (C) 1996-2002 Russell King
12 #include "efi-header.S"
20 AR_CLASS( .arch armv7-a )
21 M_CLASS( .arch armv7-m )
69 mov \rb, #0x80000000 @ physical base address
101 kputc #'-'
105 kputc #'-'
110 kputc #'-'
154 * in little-endian form.
234 * Booting from Angel - need to enter SVC mode and disable
251 * be needed here - is there an Angel SWI call for this?
269 * different platforms - we have chosen 128MB to allow
319 * That means r4 < pc || r4 - 16k page directory > &_end.
388 /* preserve 64-bit alignment */
438 /* preserve 64-bit alignment */
455 * r4 - 16k page directory >= r10 -> OK
456 * r4 + image length <= address of wont_overwrite -> OK
475 * Bump to the next 256-byte boundary with the size of
479 add r10, r10, #((reloc_code_end - restart + 256) & ~255)
486 /* Relocate the hyp vector base if necessary */
525 1: ldmdb r6!, {r0 - r3, r10 - r12, lr}
527 stmdb r9!, {r0 - r3, r10 - r12, lr}
665 .size LC0, . - LC0
668 LC1: .word .L_user_stack_end - LC1 @ sp
669 .word _edata - LC1 @ r6
670 .size LC1, . - LC1
673 .word _end - restart + 16384 + 1024*1024
676 .long (input_data_end - 4) - .
687 * dcache_line_size - get the minimum D-cache line size from the CTR register
735 mcr p15, 0, r0, c2, c0, 0 @ D-cache on
736 mcr p15, 0, r0, c2, c0, 1 @ I-cache on
737 mcr p15, 0, r0, c3, c0, 0 @ write-buffer on
740 mcr p15, 0, r0, c5, c0, 1 @ I-access permission
741 mcr p15, 0, r0, c5, c0, 0 @ D-access permission
745 mcr p15, 0, r0, c7, c5, 0 @ flush(inval) I-Cache
746 mcr p15, 0, r0, c7, c6, 0 @ flush(inval) D-Cache
755 mcr p15, 0, r0, c7, c5, 0 @ flush(inval) I-Cache
756 mcr p15, 0, r0, c7, c6, 0 @ flush(inval) D-Cache
765 mcr p15, 0, r0, c3, c0, 0 @ write-buffer on
805 orr r1, r1, #3 << 10 @ AP=11
810 orrlo r1, r1, #0x10 @ Set XN|U for non-RAM
823 orr r1, r1, #3 << 10
858 orr r0, r0, #0x5000 @ I-cache enable, RR cache replacement
860 ARM_BE8( orr r0, r0, #1 << 25 ) @ big-endian page tables
882 orr r0, r0, #0x5000 @ I-cache enable, RR cache replacement
888 ARM_BE8( orr r0, r0, #1 << 25 ) @ big-endian page tables
892 bic r6, r6, #1 << 31 @ 32-bit translation system
914 orr r0, r0, #0x1000 @ I-cache enable
925 mov r1, #-1
956 * On v7-M the processor id is located in the V7M_SCB_CPUID
958 * v7-M (if existant at all) we just return early here.
961 * use cp15 registers that are not implemented on v7-M.
979 * - CPU ID match
980 * - CPU ID mask
981 * - 'cache on' method instruction
982 * - 'cache off' method instruction
983 * - 'cache flush' method instruction
1031 .word 0x41069260 @ ARM926EJ-S (v5TEJ)
1134 .size proc_types, . - proc_types
1137 * If you get a "non-constant expression in ".if" statement"
1142 .if (. - proc_types) % PROC_ENTRY_SIZE != 0
1165 mcr p15, 0, r0, c7, c6, 0 @ flush D-Cache
1166 mcr p15, 0, r0, c7, c5, 0 @ flush I-Cache
1307 mov r2, r2, lsl r1 @ base dcache size *2
1346 .size phexbuf, . - phexbuf
1357 cmp r2, #10
1453 mov r4, r0 @ preserve image base
1464 @ 32-bit addressable DRAM mapped 1:1 using short descriptors.
1467 @ U-Boot might decide to enter the EFI stub in HYP mode
1487 ARM( bic r1, r1, #(1 << 30) ) @ clear HSCTLR.TE
1488 THUMB( orr r1, r1, #(1 << 30) ) @ set HSCTLR.TE
1491 mcr p15, 4, r0, c12, c0, 0 @ set HYP vector base (HVBAR)
1500 1: mov r9, r4 @ preserve image base
1504 orr r4, r9, #1 @ restore image base and set LSB
1525 0: .long .L_user_stack_end - .