1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- /*
- * Copyright (c) 2019, Arm Limited. All rights reserved.
- *
- * SPDX-License-Identifier: BSD-3-Clause
- */
- #include <arch.h>
- #include <asm_macros.S>
- #include <platform_def.h>
- .globl plat_secondary_cold_boot_setup
- .globl plat_get_my_entrypoint
- .globl plat_is_my_cpu_primary
- /* --------------------------------------------------------------------
- * void plat_secondary_cold_boot_setup (void);
- *
- * For AArch32, cold-booting secondary CPUs is not yet
- * implemented and they panic.
- * --------------------------------------------------------------------
- */
- func plat_secondary_cold_boot_setup
- cb_panic:
- b cb_panic
- endfunc plat_secondary_cold_boot_setup
- /* ---------------------------------------------------------------------
- * unsigned long plat_get_my_entrypoint (void);
- *
- * Main job of this routine is to distinguish between a cold and warm
- * boot. On FVP, this information can be queried from the power
- * controller. The Power Control SYS Status Register (PSYSR) indicates
- * the wake-up reason for the CPU.
- *
- * For a cold boot, return 0.
- * For a warm boot, read the mailbox and return the address it contains.
- *
- * TODO: PSYSR is a common register and should be
- * accessed using locks. Since it is not possible
- * to use locks immediately after a cold reset
- * we are relying on the fact that after a cold
- * reset all cpus will read the same WK field
- * ---------------------------------------------------------------------
- */
- func plat_get_my_entrypoint
- /* TODO support warm boot */
- /* Cold reset */
- mov r0, #0
- bx lr
- endfunc plat_get_my_entrypoint
- /* -----------------------------------------------------
- * unsigned int plat_is_my_cpu_primary (void);
- *
- * Currently configured for a sigle CPU
- * -----------------------------------------------------
- */
- func plat_is_my_cpu_primary
- mov r0, #1
- bx lr
- endfunc plat_is_my_cpu_primary
|