1 /*
2  * SPDX-FileCopyrightText: 2020-2022 Espressif Systems (Shanghai) CO LTD
3  *
4  * SPDX-License-Identifier: Apache-2.0
5  */
6 
7 #pragma once
8 
9 /*
10 Note: This is a compatibility header. Call the interfaces in esp_cpu.h instead
11 */
12 
13 #include <stdint.h>
14 #include <stdbool.h>
15 #include "soc/soc_caps.h"
16 #include "esp_attr.h"
17 #include "esp_cpu.h"
18 
19 #ifdef __cplusplus
20 extern "C" {
21 #endif
22 
23 typedef enum {
24     INTDESC_NORMAL = 0,
25     INTDESC_RESVD,
26     INTDESC_SPECIAL,
27 } int_desc_flag_t;
28 
29 typedef enum {
30     INTTP_LEVEL = ESP_CPU_INTR_TYPE_LEVEL,
31     INTTP_EDGE = ESP_CPU_INTR_TYPE_EDGE,
32     INTTP_NA = ESP_CPU_INTR_TYPE_NA,
33 } int_type_t;
34 
35 typedef struct {
36     int level;
37     int_type_t type;
38     int_desc_flag_t cpuflags[SOC_CPU_CORES_NUM];
39 } int_desc_t;
40 
41 typedef void (*interrupt_handler_t)(void *arg);
42 
43 // ---------------- Interrupt Descriptors ------------------
44 
45 /**
46  * @brief Gets the interrupt type given an interrupt number.
47  *
48  * @param interrupt_number Interrupt number 0 to 31
49  * @return interrupt type
50  */
interrupt_controller_hal_desc_type(int interrupt_number)51 FORCE_INLINE_ATTR __attribute__((deprecated)) int_type_t interrupt_controller_hal_desc_type(int interrupt_number)
52 {
53     esp_cpu_intr_desc_t intr_desc;
54     esp_cpu_intr_get_desc(esp_cpu_get_core_id(), interrupt_number, &intr_desc);
55     return (int_type_t)intr_desc.type;
56 }
57 
58 /**
59  * @brief Gets the interrupt level given an interrupt number.
60  *
61  * @param interrupt_number Interrupt number 0 to 31
62  * @return interrupt level bitmask
63  */
interrupt_controller_hal_desc_level(int interrupt_number)64 FORCE_INLINE_ATTR __attribute__((deprecated)) int interrupt_controller_hal_desc_level(int interrupt_number)
65 {
66     esp_cpu_intr_desc_t intr_desc;
67     esp_cpu_intr_get_desc(esp_cpu_get_core_id(), interrupt_number, &intr_desc);
68     return intr_desc.priority;
69 }
70 
71 /**
72  * @brief Gets the cpu flags given the interrupt number and target cpu.
73  *
74  * @param interrupt_number Interrupt number 0 to 31
75  * @param cpu_number CPU number between 0 and SOC_CPU_CORES_NUM - 1
76  * @return flags for that interrupt number
77  */
78 FORCE_INLINE_ATTR __attribute__((deprecated))
interrupt_controller_hal_desc_flags(int interrupt_number,int cpu_number)79 int_desc_flag_t interrupt_controller_hal_desc_flags(int interrupt_number, int cpu_number)
80 {
81     esp_cpu_intr_desc_t intr_desc;
82     esp_cpu_intr_get_desc(cpu_number, interrupt_number, &intr_desc);
83     int_desc_flag_t ret;
84     if (intr_desc.flags & ESP_CPU_INTR_DESC_FLAG_SPECIAL) {
85         ret = INTDESC_SPECIAL;
86     } else if (intr_desc.flags & ESP_CPU_INTR_DESC_FLAG_RESVD) {
87         ret = INTDESC_RESVD;
88     } else {
89         ret = INTDESC_NORMAL;
90     }
91     return ret;
92 }
93 
94 /**
95  * @brief Gets the interrupt type given an interrupt number.
96  *
97  * @param interrupt_number Interrupt number 0 to 31
98  * @return interrupt type
99  */
interrupt_controller_hal_get_type(int interrupt_number)100 FORCE_INLINE_ATTR __attribute__((deprecated)) int_type_t interrupt_controller_hal_get_type(int interrupt_number)
101 {
102     return interrupt_controller_hal_desc_type(interrupt_number);
103 }
104 
105 /**
106  * @brief Gets the interrupt level given an interrupt number.
107  *
108  * @param interrupt_number Interrupt number 0 to 31
109  * @return interrupt level bitmask
110  */
interrupt_controller_hal_get_level(int interrupt_number)111 FORCE_INLINE_ATTR __attribute__((deprecated)) int interrupt_controller_hal_get_level(int interrupt_number)
112 {
113     return interrupt_controller_hal_desc_level(interrupt_number);
114 }
115 
116 /**
117  * @brief Gets the cpu flags given the interrupt number and target cpu.
118  *
119  * @param interrupt_number Interrupt number 0 to 31
120  * @param cpu_number CPU number between 0 and SOC_CPU_CORES_NUM - 1
121  * @return flags for that interrupt number
122  */
123 FORCE_INLINE_ATTR __attribute__((deprecated))
interrupt_controller_hal_get_cpu_desc_flags(int interrupt_number,int cpu_number)124 uint32_t interrupt_controller_hal_get_cpu_desc_flags(int interrupt_number, int cpu_number)
125 {
126     return (uint32_t)interrupt_controller_hal_desc_flags(interrupt_number, cpu_number);
127 }
128 
129 // --------------- Interrupt Configuration -----------------
130 
131 #if SOC_CPU_HAS_FLEXIBLE_INTC
132 /**
133  * @brief Set the type of an interrupt in the controller.
134  *
135  * @param interrupt_number Interrupt number 0 to 31
136  * @param type interrupt type as edge or level triggered
137  */
interrupt_controller_hal_set_int_type(int intr,int_type_t type)138 FORCE_INLINE_ATTR __attribute__((deprecated)) void interrupt_controller_hal_set_int_type(int intr, int_type_t type)
139 {
140     esp_cpu_intr_set_type(intr, (esp_cpu_intr_type_t)type);
141 }
142 
143 /**
144  * @brief Sets the interrupt level int the interrupt controller.
145  *
146  * @param interrupt_number Interrupt number 0 to 31
147  * @param level priority between 1 (lowest) to 7 (highest)
148  */
interrupt_controller_hal_set_int_level(int intr,int level)149 FORCE_INLINE_ATTR __attribute__((deprecated)) void interrupt_controller_hal_set_int_level(int intr, int level)
150 {
151     esp_cpu_intr_set_priority(intr, level);
152 }
153 #endif // SOC_CPU_HAS_FLEXIBLE_INTC
154 
155 /**
156  * @brief checks if given interrupt number has a valid handler
157  *
158  * @param intr interrupt number ranged from 0 to 31
159  * @param cpu this argument is ignored
160  * @return true for valid handler, false otherwise
161  */
interrupt_controller_hal_has_handler(int intr,int cpu)162 FORCE_INLINE_ATTR __attribute__((deprecated)) bool interrupt_controller_hal_has_handler(int intr, int cpu)
163 {
164     (void) cpu;
165     return esp_cpu_intr_has_handler(intr);
166 }
167 
168 /**
169  * @brief sets interrupt handler and optional argument of a given interrupt number
170  *
171  * @param intr interrupt number ranged from 0 to 31
172  * @param handler handler invoked when an interrupt occurs
173  * @param arg optional argument to pass to the handler
174  */
175 FORCE_INLINE_ATTR __attribute__((deprecated))
interrupt_controller_hal_set_int_handler(uint8_t intr,interrupt_handler_t handler,void * arg)176 void interrupt_controller_hal_set_int_handler(uint8_t intr, interrupt_handler_t handler, void *arg)
177 {
178     esp_cpu_intr_set_handler(intr, (esp_cpu_intr_handler_t)handler, arg);
179 }
180 
181 /**
182  * @brief Gets argument passed to handler of a given interrupt number
183  *
184  * @param intr interrupt number ranged from 0 to 31
185  *
186  * @return argument used by handler of passed interrupt number
187  */
interrupt_controller_hal_get_int_handler_arg(uint8_t intr)188 FORCE_INLINE_ATTR __attribute__((deprecated)) void *interrupt_controller_hal_get_int_handler_arg(uint8_t intr)
189 {
190     return esp_cpu_intr_get_handler_arg(intr);
191 }
192 
193 // ------------------ Interrupt Control --------------------
194 
195 /**
196  * @brief enable interrupts specified by the mask
197  *
198  * @param mask bitmask of interrupts that needs to be enabled
199  */
interrupt_controller_hal_enable_interrupts(uint32_t mask)200 FORCE_INLINE_ATTR __attribute__((deprecated)) void interrupt_controller_hal_enable_interrupts(uint32_t mask)
201 {
202     esp_cpu_intr_enable(mask);
203 }
204 
205 /**
206  * @brief disable interrupts specified by the mask
207  *
208  * @param mask bitmask of interrupts that needs to be disabled
209  */
interrupt_controller_hal_disable_interrupts(uint32_t mask)210 FORCE_INLINE_ATTR __attribute__((deprecated)) void interrupt_controller_hal_disable_interrupts(uint32_t mask)
211 {
212     esp_cpu_intr_disable(mask);
213 }
214 
215 /**
216  * @brief Read the current interrupt mask.
217  *
218  * @return The bitmask of current interrupts
219  */
interrupt_controller_hal_read_interrupt_mask(void)220 FORCE_INLINE_ATTR __attribute__((deprecated)) uint32_t interrupt_controller_hal_read_interrupt_mask(void)
221 {
222     return esp_cpu_intr_get_enabled_mask();
223 }
224 
225 /**
226  * @brief Acknowledge an edge-trigger interrupt by clearing its pending flag
227  *
228  * @param intr interrupt number ranged from 0 to 31
229  */
interrupt_controller_hal_edge_int_acknowledge(int intr)230 FORCE_INLINE_ATTR __attribute__((deprecated)) void interrupt_controller_hal_edge_int_acknowledge(int intr)
231 {
232     esp_cpu_intr_edge_ack(intr);
233 }
234 
235 #ifdef __cplusplus
236 }
237 #endif
238