/* * Copyright (c) 2013-2020, ARM Limited and Contributors. All rights reserved. * * SPDX-License-Identifier: BSD-3-Clause */ #include #include #include #include #include #include /******************************************************************************* * This function returns a pointer to the most recent 'cpu_context' structure * for the calling CPU that was set as the context for the specified security * state. NULL is returned if no such structure has been specified. ******************************************************************************/ void *cm_get_context(uint32_t security_state) { #if ENABLE_RME assert(sec_state_is_valid(security_state)); #else /* ENABLE_RME */ assert(security_state <= NON_SECURE); #endif return get_cpu_data(cpu_context[security_state]); } /******************************************************************************* * This function sets the pointer to the current 'cpu_context' structure for the * specified security state for the calling CPU ******************************************************************************/ void cm_set_context(void *context, uint32_t security_state) { #if ENABLE_RME assert(sec_state_is_valid(security_state)); #else /* ENABLE_RME */ assert(security_state <= NON_SECURE); #endif set_cpu_data(cpu_context[security_state], context); } /******************************************************************************* * This function returns a pointer to the most recent 'cpu_context' structure * for the CPU identified by `cpu_idx` that was set as the context for the * specified security state. NULL is returned if no such structure has been * specified. ******************************************************************************/ void *cm_get_context_by_index(unsigned int cpu_idx, unsigned int security_state) { assert(sec_state_is_valid(security_state)); return get_cpu_data_by_index(cpu_idx, cpu_context[security_state]); } /******************************************************************************* * This function sets the pointer to the current 'cpu_context' structure for the * specified security state for the CPU identified by CPU index. ******************************************************************************/ void cm_set_context_by_index(unsigned int cpu_idx, void *context, unsigned int security_state) { assert(sec_state_is_valid(security_state)); set_cpu_data_by_index(cpu_idx, cpu_context[security_state], context); }