From 5d316ac14200753bd64b0f0e504342ec61406b9b Mon Sep 17 00:00:00 2001 From: Felipe Neves Date: Wed, 16 Dec 2020 14:20:38 -0300 Subject: [PATCH] interrupt: added INTC FLEXIBLE capabillity to esp32c3 CPU caps --- components/esp_system/intr_alloc.c | 20 +++--- .../include/hal/interrupt_controller_ll.h | 30 --------- .../hal/esp32c3/interrupt_descriptor_table.c | 64 +++++++++---------- .../include/hal/interrupt_controller_ll.h | 32 ---------- .../include/hal/interrupt_controller_ll.h | 31 --------- .../include/hal/interrupt_controller_hal.h | 24 +++---- .../include/hal/interrupt_controller_types.h | 2 +- components/soc/esp32c3/include/soc/cpu_caps.h | 1 + 8 files changed, 59 insertions(+), 145 deletions(-) diff --git a/components/esp_system/intr_alloc.c b/components/esp_system/intr_alloc.c index b00fdacae3..4e88cc8698 100644 --- a/components/esp_system/intr_alloc.c +++ b/components/esp_system/intr_alloc.c @@ -237,18 +237,20 @@ static bool is_vect_desc_usable(vector_desc_t *vd, int flags, int cpu, int force ALCHLOG("....Unusable: special-purpose int"); return false; } + +#ifndef SOC_CPU_HAS_FLEXIBLE_INTC //Check if the interrupt level is acceptable - if (!(flags&(1<flags&VECDESC_FL_RESERVED) { ALCHLOG("....Unusable: reserved at runtime."); @@ -583,6 +585,7 @@ esp_err_t esp_intr_alloc_intrstatus(int source, int flags, uint32_t intrstatusre esp_intr_disable(ret); } +#ifdef SOC_CPU_HAS_FLEXIBLE_INTC //Extract the level from the interrupt passed flags int level = (__builtin_ffs((flags >> 1) & ESP_INTR_FLAG_LEVELMASK)) + 1; @@ -593,6 +596,7 @@ esp_err_t esp_intr_alloc_intrstatus(int source, int flags, uint32_t intrstatusre } else { interrupt_controller_hal_set_int_type(intr,INTTP_LEVEL); } +#endif portEXIT_CRITICAL(&spinlock); diff --git a/components/hal/esp32/include/hal/interrupt_controller_ll.h b/components/hal/esp32/include/hal/interrupt_controller_ll.h index d59fcc4d29..f450f2c6c1 100644 --- a/components/hal/esp32/include/hal/interrupt_controller_ll.h +++ b/components/hal/esp32/include/hal/interrupt_controller_ll.h @@ -110,36 +110,6 @@ static inline void intr_cntrl_ll_edge_int_acknowledge (int intr) xthal_set_intclear(1 << intr); } -/** - * @brief Sets the interrupt level int the interrupt controller. - * - * @param interrupt_number Interrupt number 0 to 31 - * @param level priority between 1 (lowest) to 7 (highest) - */ -static inline void intr_cntrl_ll_set_int_level(int intr, int level) -{ - /* Not needed currently for xtensa platforms since the level is already set - * in interrupt table - */ - (void)intr; - (void)level; -} - -/** - * @brief Set the type of an interrupt in the controller. - * - * @param interrupt_number Interrupt number 0 to 31 - * @param type interrupt type as edge or level triggered - */ -static inline void intr_cntrl_ll_set_int_type(int intr, int_type_t type) -{ - /* Not needed currently for xtensa platforms since the type is already set - * in interrupt table - */ - (void)intr; - (void)type; -} - #ifdef __cplusplus } #endif diff --git a/components/hal/esp32c3/interrupt_descriptor_table.c b/components/hal/esp32c3/interrupt_descriptor_table.c index 7e0e5709c4..ca2ea05641 100644 --- a/components/hal/esp32c3/interrupt_descriptor_table.c +++ b/components/hal/esp32c3/interrupt_descriptor_table.c @@ -18,38 +18,38 @@ //This is basically a software-readable version of the interrupt usage table in include/soc/soc.h const int_desc_t interrupt_descriptor_table[32] = { - { 1, INTTP_ANY, {INTDESC_RESVD } }, //0 - { 1, INTTP_ANY, {INTDESC_SPECIAL } }, //1 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //2 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //3 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //4 - { 1, INTTP_ANY, {INTDESC_SPECIAL } }, //5 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //6 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //7 - { 1, INTTP_ANY, {INTDESC_SPECIAL } }, //8 - { 1, INTTP_ANY, {INTDESC_SPECIAL } }, //9 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //10 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //11 - { 1, INTTP_ANY, {INTDESC_SPECIAL } }, //12 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //13 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //14 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //15 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //16 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //17 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //18 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //19 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //20 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //21 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //22 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //23 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //24 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //25 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //26 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //27 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //28 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //29 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //30 - { 1, INTTP_ANY, {INTDESC_NORMAL } }, //31 + { 1, INTTP_NA, {INTDESC_RESVD } }, //0 + { 1, INTTP_NA, {INTDESC_SPECIAL } }, //1 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //2 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //3 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //4 + { 1, INTTP_NA, {INTDESC_SPECIAL } }, //5 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //6 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //7 + { 1, INTTP_NA, {INTDESC_SPECIAL } }, //8 + { 1, INTTP_NA, {INTDESC_SPECIAL } }, //9 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //10 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //11 + { 1, INTTP_NA, {INTDESC_SPECIAL } }, //12 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //13 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //14 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //15 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //16 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //17 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //18 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //19 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //20 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //21 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //22 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //23 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //24 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //25 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //26 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //27 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //28 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //29 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //30 + { 1, INTTP_NA, {INTDESC_NORMAL } }, //31 }; const int_desc_t *interrupt_controller_hal_desc_table(void) diff --git a/components/hal/esp32s2/include/hal/interrupt_controller_ll.h b/components/hal/esp32s2/include/hal/interrupt_controller_ll.h index 2e07c0ff00..2303f5e808 100644 --- a/components/hal/esp32s2/include/hal/interrupt_controller_ll.h +++ b/components/hal/esp32s2/include/hal/interrupt_controller_ll.h @@ -109,38 +109,6 @@ static inline void intr_cntrl_ll_edge_int_acknowledge (int intr) { xthal_set_intclear(1 << intr); } - -/** - * @brief Sets the interrupt level int the interrupt controller. - * - * @param interrupt_number Interrupt number 0 to 31 - * @param level priority between 1 (lowest) to 7 (highest) - */ -static inline void intr_cntrl_ll_set_int_level(int intr, int level) -{ - /* Not needed currently for xtensa platforms since the level is already set - * in interrupt table - */ - (void)intr; - (void)level; -} - -/** - * @brief Set the type of an interrupt in the controller. - * - * @param interrupt_number Interrupt number 0 to 31 - * @param type interrupt type as edge or level triggered - */ -static inline void intr_cntrl_ll_set_int_type(int intr, int_type_t type) -{ - /* Not needed currently for xtensa platforms since the type is already set - * in interrupt table - */ - (void)intr; - (void)type; -} - - #ifdef __cplusplus } #endif diff --git a/components/hal/esp32s3/include/hal/interrupt_controller_ll.h b/components/hal/esp32s3/include/hal/interrupt_controller_ll.h index d59fcc4d29..2303f5e808 100644 --- a/components/hal/esp32s3/include/hal/interrupt_controller_ll.h +++ b/components/hal/esp32s3/include/hal/interrupt_controller_ll.h @@ -109,37 +109,6 @@ static inline void intr_cntrl_ll_edge_int_acknowledge (int intr) { xthal_set_intclear(1 << intr); } - -/** - * @brief Sets the interrupt level int the interrupt controller. - * - * @param interrupt_number Interrupt number 0 to 31 - * @param level priority between 1 (lowest) to 7 (highest) - */ -static inline void intr_cntrl_ll_set_int_level(int intr, int level) -{ - /* Not needed currently for xtensa platforms since the level is already set - * in interrupt table - */ - (void)intr; - (void)level; -} - -/** - * @brief Set the type of an interrupt in the controller. - * - * @param interrupt_number Interrupt number 0 to 31 - * @param type interrupt type as edge or level triggered - */ -static inline void intr_cntrl_ll_set_int_type(int intr, int_type_t type) -{ - /* Not needed currently for xtensa platforms since the type is already set - * in interrupt table - */ - (void)intr; - (void)type; -} - #ifdef __cplusplus } #endif diff --git a/components/hal/include/hal/interrupt_controller_hal.h b/components/hal/include/hal/interrupt_controller_hal.h index dd0f615a1f..9c275a15b4 100644 --- a/components/hal/include/hal/interrupt_controller_hal.h +++ b/components/hal/include/hal/interrupt_controller_hal.h @@ -84,17 +84,6 @@ static inline int_type_t interrupt_controller_hal_get_type(int interrupt_number) return interrupt_controller_hal_desc_type(interrupt_number); } -/** - * @brief Set the type of an interrupt in the controller. - * - * @param interrupt_number Interrupt number 0 to 31 - * @param type interrupt type as edge or level triggered - */ -static inline void interrupt_controller_hal_set_int_type(int intr, int_type_t type) -{ - intr_cntrl_ll_set_int_type(intr, type); -} - /** * @brief Gets the interrupt level given an interrupt number. * @@ -106,6 +95,18 @@ static inline int interrupt_controller_hal_get_level(int interrupt_number) return interrupt_controller_hal_desc_level(interrupt_number); } +#ifdef SOC_CPU_HAS_FLEXIBLE_INTC +/** + * @brief Set the type of an interrupt in the controller. + * + * @param interrupt_number Interrupt number 0 to 31 + * @param type interrupt type as edge or level triggered + */ +static inline void interrupt_controller_hal_set_int_type(int intr, int_type_t type) +{ + intr_cntrl_ll_set_int_type(intr, type); +} + /** * @brief Sets the interrupt level int the interrupt controller. * @@ -116,6 +117,7 @@ static inline void interrupt_controller_hal_set_int_level(int intr, int level) { intr_cntrl_ll_set_int_level(intr, level); } +#endif /** * @brief Gets the cpu flags given the interrupt number and target cpu. diff --git a/components/hal/include/hal/interrupt_controller_types.h b/components/hal/include/hal/interrupt_controller_types.h index 9e36dc7361..528b0eb35d 100644 --- a/components/hal/include/hal/interrupt_controller_types.h +++ b/components/hal/include/hal/interrupt_controller_types.h @@ -30,7 +30,7 @@ typedef enum { typedef enum { INTTP_LEVEL=0, INTTP_EDGE, - INTTP_ANY, + INTTP_NA, } int_type_t; typedef struct { diff --git a/components/soc/esp32c3/include/soc/cpu_caps.h b/components/soc/esp32c3/include/soc/cpu_caps.h index e8692efc29..2d8a80bcfc 100644 --- a/components/soc/esp32c3/include/soc/cpu_caps.h +++ b/components/soc/esp32c3/include/soc/cpu_caps.h @@ -16,5 +16,6 @@ #define SOC_CPU_BREAKPOINTS_NUM 8 #define SOC_CPU_WATCHPOINTS_NUM 8 +#define SOC_CPU_HAS_FLEXIBLE_INTC 1 #define SOC_CPU_WATCHPOINT_SIZE 0x80000000 // bytes