/* * SPDX-FileCopyrightText: 2021 Espressif Systems (Shanghai) CO LTD * * SPDX-License-Identifier: Apache-2.0 */ #ifndef _ESP_CPU_UTILS_H #define _ESP_CPU_UTILS_H #ifdef __cplusplus extern "C" { #endif /** * @brief Fetch the PC value of the previous instruction * * @param pc PC value of the current backtrace frame * */ static inline uint32_t esp_cpu_process_stack_pc(uint32_t pc) { if (pc & 0x80000000) { //Top two bits of a0 (return address) specify window increment. Overwrite to map to address space. pc = (pc & 0x3fffffff) | 0x40000000; } //Minus 3 to get PC of previous instruction (i.e. instruction executed before return address) return pc - 3; } #ifdef __cplusplus } #endif #endif // _ESP_CPU_UTILS_H