mirror of
https://github.com/ARM-software/arm-trusted-firmware.git
synced 2025-04-16 17:44:19 +00:00

The model has a bug where it will not clear CPUPWRCTLR_EL1 on reset, even though the actual cores do. The write of 1 to the bit itself triggers the powerdown sequnece, regardless of the value before the write. As such, the bug does not impact functionality but it does throw off software reading it. Clear the bit on Travis and Gelas as they are the only ones to require reading it back. Change-Id: I765a7fa055733d522480be30d412e3b417af2bd7 Signed-off-by: Boyan Karatotev <boyan.karatotev@arm.com>
67 lines
1.8 KiB
ArmAsm
67 lines
1.8 KiB
ArmAsm
/*
|
|
* Copyright (c) 2023-2025, Arm Limited. All rights reserved.
|
|
*
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
*/
|
|
|
|
#include <arch.h>
|
|
#include <asm_macros.S>
|
|
#include <common/bl_common.h>
|
|
#include <travis.h>
|
|
#include <cpu_macros.S>
|
|
#include <plat_macros.S>
|
|
|
|
/* Hardware handled coherency */
|
|
#if HW_ASSISTED_COHERENCY == 0
|
|
#error "Travis must be compiled with HW_ASSISTED_COHERENCY enabled"
|
|
#endif
|
|
|
|
/* 64-bit only core */
|
|
#if CTX_INCLUDE_AARCH32_REGS == 1
|
|
#error "Travis supports only AArch64. Compile with CTX_INCLUDE_AARCH32_REGS=0"
|
|
#endif
|
|
|
|
#if FEAT_PABANDON == 0
|
|
#error "Travis must be compiled with FEAT_PABANDON enabled"
|
|
#endif
|
|
|
|
#if ERRATA_SME_POWER_DOWN == 0
|
|
#error "Travis needs ERRATA_SME_POWER_DOWN=1 to powerdown correctly"
|
|
#endif
|
|
|
|
cpu_reset_func_start travis
|
|
/* ----------------------------------------------------
|
|
* Disable speculative loads
|
|
* ----------------------------------------------------
|
|
*/
|
|
msr SSBS, xzr
|
|
/* model bug: not cleared on reset */
|
|
sysreg_bit_clear TRAVIS_IMP_CPUPWRCTLR_EL1, \
|
|
TRAVIS_IMP_CPUPWRCTLR_EL1_CORE_PWRDN_EN_BIT
|
|
cpu_reset_func_end travis
|
|
|
|
func travis_core_pwr_dwn
|
|
/* ---------------------------------------------------
|
|
* Flip CPU power down bit in power control register.
|
|
* It will be set on powerdown and cleared on wakeup
|
|
* ---------------------------------------------------
|
|
*/
|
|
sysreg_bit_toggle TRAVIS_IMP_CPUPWRCTLR_EL1, \
|
|
TRAVIS_IMP_CPUPWRCTLR_EL1_CORE_PWRDN_EN_BIT
|
|
isb
|
|
ret
|
|
endfunc travis_core_pwr_dwn
|
|
|
|
.section .rodata.travis_regs, "aS"
|
|
travis_regs: /* The ASCII list of register names to be reported */
|
|
.asciz "cpuectlr_el1", ""
|
|
|
|
func travis_cpu_reg_dump
|
|
adr x6, travis_regs
|
|
mrs x8, TRAVIS_IMP_CPUECTLR_EL1
|
|
ret
|
|
endfunc travis_cpu_reg_dump
|
|
|
|
declare_cpu_ops travis, TRAVIS_MIDR, \
|
|
travis_reset_func, \
|
|
travis_core_pwr_dwn
|