|
|
@@ -1,5 +1,18 @@
|
|
|
-#ifndef PANIC_H
|
|
|
-#define PANIC_H
|
|
|
+// Copyright 2015-2019 Espressif Systems (Shanghai) PTE LTD
|
|
|
+//
|
|
|
+// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
+// you may not use this file except in compliance with the License.
|
|
|
+// You may obtain a copy of the License at
|
|
|
+//
|
|
|
+// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
+//
|
|
|
+// Unless required by applicable law or agreed to in writing, software
|
|
|
+// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
+// See the License for the specific language governing permissions and
|
|
|
+// limitations under the License.
|
|
|
+
|
|
|
+#pragma once
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
extern "C"
|
|
|
@@ -21,8 +34,27 @@ extern "C"
|
|
|
|
|
|
#include "esp_err.h"
|
|
|
#include "soc/soc.h"
|
|
|
+#include "soc/soc_memory_layout.h"
|
|
|
|
|
|
|
|
|
+/*
|
|
|
+ * @brief Structure used for backtracing
|
|
|
+ *
|
|
|
+ * This structure stores the backtrace information of a particular stack frame
|
|
|
+ * (i.e. the PC and SP). This structure is used iteratively with the
|
|
|
+ * esp_cpu_get_next_backtrace_frame() function to traverse each frame within a
|
|
|
+ * single stack. The next_pc represents the PC of the current frame's caller, thus
|
|
|
+ * a next_pc of 0 indicates that the current frame is the last frame on the stack.
|
|
|
+ *
|
|
|
+ * @note Call esp_backtrace_get_start() to obtain initialization values for
|
|
|
+ * this structure
|
|
|
+ */
|
|
|
+typedef struct {
|
|
|
+ uint32_t pc; /* PC of the current frame */
|
|
|
+ uint32_t sp; /* SP of the current frame */
|
|
|
+ uint32_t next_pc; /* PC of the current frame's caller */
|
|
|
+} esp_backtrace_frame_t;
|
|
|
+
|
|
|
/**
|
|
|
* @brief If an OCD is connected over JTAG. set breakpoint 0 to the given function
|
|
|
* address. Do nothing otherwise.
|
|
|
@@ -53,7 +85,6 @@ void esp_set_breakpoint_if_jtag(void *fn);
|
|
|
*/
|
|
|
esp_err_t esp_set_watchpoint(int no, void *adr, int size, int flags);
|
|
|
|
|
|
-
|
|
|
/**
|
|
|
* @brief Clear a watchpoint
|
|
|
*
|
|
|
@@ -82,21 +113,56 @@ inline static bool esp_stack_ptr_in_extram(uint32_t sp)
|
|
|
}
|
|
|
#endif
|
|
|
|
|
|
+/*
|
|
|
+ * Get the first frame of the current stack's backtrace
|
|
|
+ *
|
|
|
+ * Given the following function call flow (B -> A -> X -> esp_backtrace_get_start),
|
|
|
+ * this function will do the following.
|
|
|
+ * - Flush CPU registers and window frames onto the current stack
|
|
|
+ * - Return PC and SP of function A (i.e. start of the stack's backtrace)
|
|
|
+ * - Return PC of function B (i.e. next_pc)
|
|
|
+ *
|
|
|
+ * @note This function is implemented in assembly
|
|
|
+ *
|
|
|
+ * @param[out] pc PC of the first frame in the backtrace
|
|
|
+ * @param[out] sp SP of the first frame in the backtrace
|
|
|
+ * @param[out] next_pc PC of the first frame's caller
|
|
|
+ */
|
|
|
+extern void esp_backtrace_get_start(uint32_t *pc, uint32_t *sp, uint32_t *next_pc);
|
|
|
+
|
|
|
+/**
|
|
|
+ * Get the next frame on a stack for backtracing
|
|
|
+ *
|
|
|
+ * Given a stack frame(i), this function will obtain the next stack frame(i-1)
|
|
|
+ * on the same call stack (i.e. the caller of frame(i)). This function is meant to be
|
|
|
+ * called iteratively when doing a backtrace.
|
|
|
+ *
|
|
|
+ * Entry Conditions: Frame structure containing valid SP and next_pc
|
|
|
+ * Exit Conditions:
|
|
|
+ * - Frame structure updated with SP and PC of frame(i-1). next_pc now points to frame(i-2).
|
|
|
+ * - If a next_pc of 0 is returned, it indicates that frame(i-1) is last frame on the stack
|
|
|
+ *
|
|
|
+ * @param[inout] frame Pointer to frame structure
|
|
|
+ *
|
|
|
+ * @return
|
|
|
+ * - True if the SP and PC of the next frame(i-1) are sane
|
|
|
+ * - False otherwise
|
|
|
+ */
|
|
|
+bool esp_backtrace_get_next_frame(esp_backtrace_frame_t *frame);
|
|
|
+
|
|
|
/**
|
|
|
- * @brief Checks stack pointer
|
|
|
+ * @brief Print the backtrace of the current stack
|
|
|
+ *
|
|
|
+ * @param depth The maximum number of stack frames to print (should be > 0)
|
|
|
+ *
|
|
|
+ * @return
|
|
|
+ * - ESP_OK Backtrace successfully printed to completion or to depth limit
|
|
|
+ * - ESP_FAIL Backtrace is corrupted
|
|
|
*/
|
|
|
-static inline bool esp_stack_ptr_is_sane(uint32_t sp)
|
|
|
-{
|
|
|
-#if CONFIG_SPIRAM_ALLOW_STACK_EXTERNAL_MEMORY
|
|
|
- return (esp_stack_ptr_in_dram(sp) || esp_stack_ptr_in_extram(sp));
|
|
|
-#else
|
|
|
- return esp_stack_ptr_in_dram(sp);
|
|
|
-#endif
|
|
|
-}
|
|
|
+esp_err_t esp_backtrace_print(int depth);
|
|
|
+
|
|
|
#endif
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
}
|
|
|
#endif
|
|
|
-
|
|
|
-#endif
|