17#ifndef ZEPHYR_INCLUDE_ARCH_ARM_IRQ_H_
18#define ZEPHYR_INCLUDE_ARCH_ARM_IRQ_H_
28#if defined(CONFIG_ARM_CUSTOM_INTERRUPT_CONTROLLER) || defined(CONFIG_MULTI_LEVEL_INTERRUPTS)
29#define arch_irq_enable z_soc_irq_enable
30#define arch_irq_disable z_soc_irq_disable
31#define arch_irq_is_enabled z_soc_irq_is_enabled
33#define arch_irq_enable arm_irq_enable
34#define arch_irq_disable arm_irq_disable
35#define arch_irq_is_enabled arm_irq_is_enabled
41#if defined(CONFIG_ARM_CUSTOM_INTERRUPT_CONTROLLER)
42GTEXT(z_soc_irq_get_active)
47#if !defined(CONFIG_ARM_CUSTOM_INTERRUPT_CONTROLLER)
52#if !defined(CONFIG_MULTI_LEVEL_INTERRUPTS)
53#define arch_irq_enable(irq) arm_irq_enable(irq)
54#define arch_irq_disable(irq) arm_irq_disable(irq)
55#define arch_irq_is_enabled(irq) arm_irq_is_enabled(irq)
56#define z_arm_irq_priority_set(irq, prio, flags) arm_irq_priority_set(irq, prio, flags)
60#if defined(CONFIG_ARM_CUSTOM_INTERRUPT_CONTROLLER) || defined(CONFIG_MULTI_LEVEL_INTERRUPTS)
67void z_soc_irq_init(
void);
68void z_soc_irq_enable(
unsigned int irq);
69void z_soc_irq_disable(
unsigned int irq);
70int z_soc_irq_is_enabled(
unsigned int irq);
72void z_soc_irq_priority_set(
73 unsigned int irq,
unsigned int prio,
unsigned int flags);
75unsigned int z_soc_irq_get_active(
void);
76void z_soc_irq_eoi(
unsigned int irq);
78#define arch_irq_enable(irq) z_soc_irq_enable(irq)
79#define arch_irq_disable(irq) z_soc_irq_disable(irq)
80#define arch_irq_is_enabled(irq) z_soc_irq_is_enabled(irq)
82#define z_arm_irq_priority_set(irq, prio, flags) \
83 z_soc_irq_priority_set(irq, prio, flags)
87extern void z_arm_int_exit(
void);
89extern void z_arm_interrupt_init(
void);
99#define IRQ_ZERO_LATENCY BIT(0)
101#ifdef CONFIG_CPU_CORTEX_M
103#if defined(CONFIG_ZERO_LATENCY_LEVELS)
104#define ZERO_LATENCY_LEVELS CONFIG_ZERO_LATENCY_LEVELS
106#define ZERO_LATENCY_LEVELS 1
109#define _CHECK_PRIO(priority_p, flags_p) \
110 BUILD_ASSERT(((flags_p & IRQ_ZERO_LATENCY) && \
111 ((ZERO_LATENCY_LEVELS == 1) || \
112 (priority_p < ZERO_LATENCY_LEVELS))) || \
113 (priority_p <= IRQ_PRIO_LOWEST), \
114 "Invalid interrupt priority. Values must not exceed IRQ_PRIO_LOWEST");
116#define _CHECK_PRIO(priority_p, flags_p)
129#define ARCH_IRQ_CONNECT(irq_p, priority_p, isr_p, isr_param_p, flags_p) \
131 BUILD_ASSERT(!(flags_p & IRQ_ZERO_LATENCY), \
132 "ZLI interrupts must be registered using IRQ_DIRECT_CONNECT()"); \
133 _CHECK_PRIO(priority_p, flags_p) \
134 Z_ISR_DECLARE(irq_p, 0, isr_p, isr_param_p); \
135 z_arm_irq_priority_set(irq_p, priority_p, flags_p); \
138#define ARCH_IRQ_DIRECT_CONNECT(irq_p, priority_p, isr_p, flags_p) \
140 BUILD_ASSERT(IS_ENABLED(CONFIG_ZERO_LATENCY_IRQS) || !(flags_p & IRQ_ZERO_LATENCY), \
141 "ZLI interrupt registered but feature is disabled"); \
142 _CHECK_PRIO(priority_p, flags_p) \
143 Z_ISR_DECLARE_DIRECT(irq_p, ISR_FLAG_DIRECT, isr_p); \
144 z_arm_irq_priority_set(irq_p, priority_p, flags_p); \
148extern void _arch_isr_direct_pm(
void);
149#define ARCH_ISR_DIRECT_PM() _arch_isr_direct_pm()
151#define ARCH_ISR_DIRECT_PM() do { } while (false)
154#define ARCH_ISR_DIRECT_HEADER() arch_isr_direct_header()
155#define ARCH_ISR_DIRECT_FOOTER(swap) arch_isr_direct_footer(swap)
158extern void z_arm_int_exit(
void);
160#ifdef CONFIG_TRACING_ISR
167#ifdef CONFIG_TRACING_ISR
174#ifdef CONFIG_TRACING_ISR
177 if (maybe_swap != 0) {
182#define ARCH_ISR_DIAG_OFF \
183 TOOLCHAIN_DISABLE_CLANG_WARNING(TOOLCHAIN_WARNING_EXTRA) \
184 TOOLCHAIN_DISABLE_GCC_WARNING(TOOLCHAIN_WARNING_ATTRIBUTES) \
185 TOOLCHAIN_DISABLE_IAR_WARNING(TOOLCHAIN_WARNING_ATTRIBUTES)
186#define ARCH_ISR_DIAG_ON \
187 TOOLCHAIN_ENABLE_CLANG_WARNING(TOOLCHAIN_WARNING_EXTRA) \
188 TOOLCHAIN_ENABLE_GCC_WARNING(TOOLCHAIN_WARNING_ATTRIBUTES) \
189 TOOLCHAIN_ENABLE_IAR_WARNING(TOOLCHAIN_WARNING_ATTRIBUTES)
191#define ARCH_ISR_DIRECT_DECLARE(name) \
192 static inline int name##_body(void); \
194 __attribute__ ((interrupt ("IRQ"))) void name(void) \
196 int check_reschedule; \
197 ISR_DIRECT_HEADER(); \
198 check_reschedule = name##_body(); \
199 ISR_DIRECT_FOOTER(check_reschedule); \
202 static inline int name##_body(void)
204#if defined(CONFIG_DYNAMIC_DIRECT_INTERRUPTS)
206extern void z_arm_irq_direct_dynamic_dispatch_reschedule(
void);
207extern void z_arm_irq_direct_dynamic_dispatch_no_reschedule(
void);
261#define ARM_IRQ_DIRECT_DYNAMIC_CONNECT(irq_p, priority_p, flags_p, resch) \
262 IRQ_DIRECT_CONNECT(irq_p, priority_p, \
263 _CONCAT(z_arm_irq_direct_dynamic_dispatch_, resch), flags_p)
267#if defined(CONFIG_ARM_SECURE_FIRMWARE)
272 IRQ_TARGET_STATE_SECURE = 0,
273 IRQ_TARGET_STATE_NON_SECURE
static void arch_isr_direct_header(void)
Definition irq.h:91
static void arch_isr_direct_footer(int maybe_swap)
Definition irq.h:98
#define arch_irq_disable(irq)
Definition irq.h:54
void arm_irq_priority_set(unsigned int irq, unsigned int prio, uint32_t flags)
#define arch_irq_enable(irq)
Definition irq.h:53
int arm_irq_is_enabled(unsigned int irq)
void arm_irq_enable(unsigned int irq)
void arm_irq_disable(unsigned int irq)
#define arch_irq_is_enabled(irq)
Definition irq.h:55
void sys_trace_isr_enter(void)
Called when entering an ISR.
void sys_trace_isr_exit(void)
Called when exiting an ISR.
flags
Definition parser.h:97
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
Software-managed ISR table.