/* * SPDX-FileCopyrightText: 2015-2022 Espressif Systems (Shanghai) CO LTD * * SPDX-License-Identifier: Apache-2.0 */ #ifndef ESP_CORE_DUMP_PORT_IMPL_H_ #define ESP_CORE_DUMP_PORT_IMPL_H_ /** * @file * @brief Core dump port interface implementation for RISC-V. */ #include "esp_core_dump_types.h" #include "esp_app_format.h" #ifdef __cplusplus extern "C" { #endif /** * @brief Define the type that will be used to describe the current context when * doing a backup of the current stack. This same structure is used to restore the stack. */ typedef struct { uint32_t sp; } core_dump_stack_context_t; /** * @brief Set the stack pointer to the address passed as a parameter. * @note This function must be inlined. * * @param new_sp New stack pointer to set in sp register. * @param old_ctx CPU context, related to SP, to fill. It will be given back when restoring SP. */ FORCE_INLINE_ATTR void esp_core_dump_replace_sp(void* new_sp, core_dump_stack_context_t* old_ctx) { asm volatile ("mv %0, sp \n\t\ mv sp, %1 \n\t\ " : "=&r"(old_ctx->sp) : "r"(new_sp)); } /** * @brief Restore the stack pointer that was returned when calling `esp_core_dump_replace_sp()` function. * * @param ctx CPU context, related to SP, to restore. */ FORCE_INLINE_ATTR void esp_core_dump_restore_sp(core_dump_stack_context_t* old_ctx) { asm volatile ("mv sp, %0 \n\t" :: "r"(old_ctx->sp)); } #ifdef __cplusplus } #endif #endif