/* * Copyright (c) 2022, ARM Limited. All rights reserved. * Copyright (c) 2023, NVIDIA Corporation. All rights reserved. * * SPDX-License-Identifier: BSD-3-Clause * * Dispatch synchronous system register traps from lower ELs. */ #include #include int handle_sysreg_trap(uint64_t esr_el3, cpu_context_t *ctx) { uint64_t __unused opcode = esr_el3 & ISS_SYSREG_OPCODE_MASK; #if ENABLE_FEAT_RNG_TRAP if ((opcode == ISS_SYSREG_OPCODE_RNDR) || (opcode == ISS_SYSREG_OPCODE_RNDRRS)) { return plat_handle_rng_trap(esr_el3, ctx); } #endif #if IMPDEF_SYSREG_TRAP if ((opcode & ISS_SYSREG_OPCODE_IMPDEF) == ISS_SYSREG_OPCODE_IMPDEF) { return plat_handle_impdef_trap(esr_el3, ctx); } #endif return TRAP_RET_UNHANDLED; }