| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- /*
- * SPDX-FileCopyrightText: 2020-2022 Espressif Systems (Shanghai) CO LTD
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- #include "freertos/xtensa_context.h"
- #include "esp_private/panic_internal.h"
- #include "hal/wdt_hal.h"
- extern void esp_panic_handler(panic_info_t *info);
- extern volatile bool g_override_illegal_instruction;
- void __real_esp_panic_handler(panic_info_t *info);
- void __real_esp_panic_handler_reconfigure_wdts(void);
- void __real_esp_cpu_stall(int core_id);
- static void disable_all_wdts(void)
- {
- wdt_hal_context_t wdt0_context = {.inst = WDT_MWDT0, .mwdt_dev = &TIMERG0};
- #if SOC_TIMER_GROUPS >= 2
- wdt_hal_context_t wdt1_context = {.inst = WDT_MWDT1, .mwdt_dev = &TIMERG1};
- #endif
- //Todo: Refactor to use Interrupt or Task Watchdog API, and a system level WDT context
- //Task WDT is the Main Watchdog Timer of Timer Group 0
- wdt_hal_write_protect_disable(&wdt0_context);
- wdt_hal_disable(&wdt0_context);
- wdt_hal_write_protect_enable(&wdt0_context);
- #if SOC_TIMER_GROUPS >= 2
- //Interupt WDT is the Main Watchdog Timer of Timer Group 1
- wdt_hal_write_protect_disable(&wdt1_context);
- wdt_hal_disable(&wdt1_context);
- wdt_hal_write_protect_enable(&wdt1_context);
- #endif
- }
- /* Memprot test specific IllegalInstruction exception handler:
- * when testing the protection against a code execution, sample code
- * is being injected into various memory regions which produces
- * EXCCAUSE_ILLEGAL on execution attempt. Such a result is expected
- * but it causes system reboot in the standard panic handler.
- * The following variant of panic handling simply returns back to the
- * next instruction and continues normal execution.
- *
- * NOTE: if EXCCAUSE_ILLEGAL comes from a different source than the testing code
- * the behavior is undefined
- * */
- void __wrap_esp_panic_handler(panic_info_t *info)
- {
- XtExcFrame *frm = (XtExcFrame *)info->frame;
- if ( frm->exccause == EXCCAUSE_ILLEGAL && g_override_illegal_instruction == true ) {
- frm->pc = frm->a0;
- return;
- } else {
- __real_esp_panic_handler(info);
- }
- }
- void __wrap_esp_panic_handler_reconfigure_wdts(void)
- {
- if ( g_override_illegal_instruction == true ) {
- disable_all_wdts();
- return;
- } else {
- __real_esp_panic_handler_reconfigure_wdts();
- }
- }
- void __wrap_esp_cpu_stall(int core_id)
- {
- if ( g_override_illegal_instruction == true ) {
- return;
- } else {
- __real_esp_cpu_stall(core_id);
- }
- }
|