From c80993f71328876a467a966563a4b6c11f8f2243 Mon Sep 17 00:00:00 2001 From: Tangyuxin <462747508@qq.com> Date: Sun, 24 Apr 2022 01:03:54 +0800 Subject: [PATCH] [libcpu][arm] Add exception install function (#5827) --- libcpu/arm/cortex-a/trap.c | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/libcpu/arm/cortex-a/trap.c b/libcpu/arm/cortex-a/trap.c index 814db418cd..e8b3c8f0ec 100644 --- a/libcpu/arm/cortex-a/trap.c +++ b/libcpu/arm/cortex-a/trap.c @@ -19,6 +19,18 @@ extern long list_thread(void); #endif +static rt_err_t (*rt_exception_hook)(void *context) = RT_NULL; + +/** + * This function set the hook, which is invoked on fault exception handling. + * + * @param exception_handle the exception handling hook function. + */ +void rt_hw_exception_install(rt_err_t (*exception_handle)(void *context)) +{ + rt_exception_hook = exception_handle; +} + /** * this function will show registers of CPU * @@ -33,6 +45,13 @@ void rt_hw_show_register(struct rt_hw_exp_stack *regs) rt_kprintf("fp :0x%08x ip :0x%08x\n", regs->fp, regs->ip); rt_kprintf("sp :0x%08x lr :0x%08x pc :0x%08x\n", regs->sp, regs->lr, regs->pc); rt_kprintf("cpsr:0x%08x\n", regs->cpsr); + if (rt_exception_hook != RT_NULL) + { + rt_err_t result; + + result = rt_exception_hook(regs); + if (result == RT_EOK) return; + } } void (*rt_trap_hook)(struct rt_hw_exp_stack *regs, const char *ex, unsigned int exception_type);