From 0cf3bcf49506ee4a8c5444284b0c9dd5afbf2df3 Mon Sep 17 00:00:00 2001 From: flyingcys Date: Wed, 29 Mar 2023 19:01:26 +0800 Subject: [PATCH] [bsp]fix esp32_c3 compile error (#7107) * fix rt_hw_interrupt_install return value * add __rt_rvstack --- bsp/ESP32_C3/rtt.patch | 1 + libcpu/risc-v/common/trap_common.c | 7 ++++++- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/bsp/ESP32_C3/rtt.patch b/bsp/ESP32_C3/rtt.patch index 37c41b76b0..7f583abd2b 100644 --- a/bsp/ESP32_C3/rtt.patch +++ b/bsp/ESP32_C3/rtt.patch @@ -113,6 +113,7 @@ index d6670bf759..1d51ffeea0 100644 + __stack_cpu0 = .; + __stack_end__ = .; + } > dram0_0_seg ++ PROVIDE( __rt_rvstack = __stack_end__); + + .heap : + { diff --git a/libcpu/risc-v/common/trap_common.c b/libcpu/risc-v/common/trap_common.c index 2e978f2aed..e7d0043a11 100644 --- a/libcpu/risc-v/common/trap_common.c +++ b/libcpu/risc-v/common/trap_common.c @@ -41,21 +41,26 @@ rt_weak void rt_hw_interrupt_init(void) * @param handler Break-in function requiring binding * @param param NULL * @param name NULL - * @return NULL + * @return old handler */ rt_weak rt_isr_handler_t rt_hw_interrupt_install(int vector, rt_isr_handler_t handler, void *param, const char *name) { + rt_isr_handler_t old_handler = RT_NULL; void *user_param = param; char *user_name = name; + if(vector < ISR_NUMBER) { + old_handler = rv32irq_table[vector].handler; if (handler != RT_NULL) { rv32irq_table[vector].handler = (rt_isr_handler_t)handler; rv32irq_table[vector].param = param; } } + + return old_handler; } /** -- GitLab