Zephyr API Documentation 4.3.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
irq.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2013-2014 Wind River Systems, Inc.
3 * Copyright (c) 2019 Nordic Semiconductor ASA.
4 * Copyright 2026 Arm Limited and/or its affiliates <open-source-office@arm.com>
5 *
6 * SPDX-License-Identifier: Apache-2.0
7 */
8
16
17#ifndef ZEPHYR_INCLUDE_ARCH_ARM_IRQ_H_
18#define ZEPHYR_INCLUDE_ARCH_ARM_IRQ_H_
19
20#include <zephyr/sw_isr_table.h>
21#include <stdbool.h>
22#if !defined(_ASMLANGUAGE) && defined(CONFIG_CPU_CORTEX_M)
24#endif
25
26#ifdef __cplusplus
27extern "C" {
28#endif
29
30#ifdef _ASMLANGUAGE
31#if defined(CONFIG_ARM_CUSTOM_INTERRUPT_CONTROLLER) || defined(CONFIG_MULTI_LEVEL_INTERRUPTS)
32#define arch_irq_enable z_soc_irq_enable
33#define arch_irq_disable z_soc_irq_disable
34#define arch_irq_is_enabled z_soc_irq_is_enabled
35#else
36#define arch_irq_enable arm_irq_enable
37#define arch_irq_disable arm_irq_disable
38#define arch_irq_is_enabled arm_irq_is_enabled
39#endif
40#ifndef CONFIG_USE_SWITCH
41GTEXT(z_arm_int_exit);
42#endif
43GTEXT(arch_irq_enable)
46#if defined(CONFIG_ARM_CUSTOM_INTERRUPT_CONTROLLER)
47GTEXT(z_soc_irq_get_active)
48GTEXT(z_soc_irq_eoi)
49#endif /* CONFIG_ARM_CUSTOM_INTERRUPT_CONTROLLER */
50#else
51
52#if !defined(CONFIG_ARM_CUSTOM_INTERRUPT_CONTROLLER)
53extern void arm_irq_enable(unsigned int irq);
54extern void arm_irq_disable(unsigned int irq);
55extern int arm_irq_is_enabled(unsigned int irq);
56extern void arm_irq_priority_set(unsigned int irq, unsigned int prio, uint32_t flags);
57#if !defined(CONFIG_MULTI_LEVEL_INTERRUPTS)
58#define arch_irq_enable(irq) arm_irq_enable(irq)
59#define arch_irq_disable(irq) arm_irq_disable(irq)
60#define arch_irq_is_enabled(irq) arm_irq_is_enabled(irq)
61#define z_arm_irq_priority_set(irq, prio, flags) arm_irq_priority_set(irq, prio, flags)
62#endif
63#endif
64
65#if defined(CONFIG_ARM_CUSTOM_INTERRUPT_CONTROLLER) || defined(CONFIG_MULTI_LEVEL_INTERRUPTS)
66/*
67 * When a custom interrupt controller or multi-level interrupts is specified,
68 * map the architecture interrupt control functions to the SoC layer interrupt
69 * control functions.
70 */
71
72void z_soc_irq_init(void);
73void z_soc_irq_enable(unsigned int irq);
74void z_soc_irq_disable(unsigned int irq);
75int z_soc_irq_is_enabled(unsigned int irq);
76
77void z_soc_irq_priority_set(
78 unsigned int irq, unsigned int prio, unsigned int flags);
79
80unsigned int z_soc_irq_get_active(void);
81void z_soc_irq_eoi(unsigned int irq);
82
83#define arch_irq_enable(irq) z_soc_irq_enable(irq)
84#define arch_irq_disable(irq) z_soc_irq_disable(irq)
85#define arch_irq_is_enabled(irq) z_soc_irq_is_enabled(irq)
86
87#define z_arm_irq_priority_set(irq, prio, flags) \
88 z_soc_irq_priority_set(irq, prio, flags)
89
90#endif
91
92#if defined(CONFIG_CPU_CORTEX_M) && defined(CONFIG_USE_SWITCH)
93static inline void z_arm_int_exit(void)
94{
96}
97#else
98extern void z_arm_int_exit(void);
99#endif
100
101extern void z_arm_interrupt_init(void);
102
103/* Flags for use with IRQ_CONNECT() */
111#define IRQ_ZERO_LATENCY BIT(0)
112
113#ifdef CONFIG_CPU_CORTEX_M
114
115#if defined(CONFIG_ZERO_LATENCY_LEVELS)
116#define ZERO_LATENCY_LEVELS CONFIG_ZERO_LATENCY_LEVELS
117#else
118#define ZERO_LATENCY_LEVELS 1
119#endif
120
121#define _CHECK_PRIO(priority_p, flags_p) \
122 BUILD_ASSERT(((flags_p & IRQ_ZERO_LATENCY) && \
123 ((ZERO_LATENCY_LEVELS == 1) || \
124 (priority_p < ZERO_LATENCY_LEVELS))) || \
125 (priority_p <= IRQ_PRIO_LOWEST), \
126 "Invalid interrupt priority. Values must not exceed IRQ_PRIO_LOWEST");
127#else
128#define _CHECK_PRIO(priority_p, flags_p)
129#endif
130
131/* All arguments must be computable by the compiler at build time.
132 *
133 * Z_ISR_DECLARE will populate the .intList section with the interrupt's
134 * parameters, which will then be used by gen_irq_tables.py to create
135 * the vector table and the software ISR table. This is all done at
136 * build-time.
137 *
138 * We additionally set the priority in the interrupt controller at
139 * runtime.
140 */
141#define ARCH_IRQ_CONNECT(irq_p, priority_p, isr_p, isr_param_p, flags_p) \
142{ \
143 BUILD_ASSERT(!(flags_p & IRQ_ZERO_LATENCY), \
144 "ZLI interrupts must be registered using IRQ_DIRECT_CONNECT()"); \
145 _CHECK_PRIO(priority_p, flags_p) \
146 Z_ISR_DECLARE(irq_p, 0, isr_p, isr_param_p); \
147 z_arm_irq_priority_set(irq_p, priority_p, flags_p); \
148}
149
150#define ARCH_IRQ_DIRECT_CONNECT(irq_p, priority_p, isr_p, flags_p) \
151{ \
152 BUILD_ASSERT(IS_ENABLED(CONFIG_ZERO_LATENCY_IRQS) || !(flags_p & IRQ_ZERO_LATENCY), \
153 "ZLI interrupt registered but feature is disabled"); \
154 _CHECK_PRIO(priority_p, flags_p) \
155 Z_ISR_DECLARE_DIRECT(irq_p, ISR_FLAG_DIRECT, isr_p); \
156 z_arm_irq_priority_set(irq_p, priority_p, flags_p); \
157}
158
159#ifdef CONFIG_PM
160extern void _arch_isr_direct_pm(void);
161#define ARCH_ISR_DIRECT_PM() _arch_isr_direct_pm()
162#else
163#define ARCH_ISR_DIRECT_PM() do { } while (false)
164#endif
165
166#define ARCH_ISR_DIRECT_HEADER() arch_isr_direct_header()
167#define ARCH_ISR_DIRECT_FOOTER(swap) arch_isr_direct_footer(swap)
168
169#ifdef CONFIG_TRACING_ISR
170extern void sys_trace_isr_enter(void);
171extern void sys_trace_isr_exit(void);
172#endif
173
174static inline void arch_isr_direct_header(void)
175{
176#ifdef CONFIG_TRACING_ISR
178#endif
179}
180
181static inline void arch_isr_direct_footer(int maybe_swap)
182{
183#ifdef CONFIG_TRACING_ISR
185#endif
186 if (maybe_swap != 0) {
187 z_arm_int_exit();
188 }
189}
190
191#define ARCH_ISR_DIAG_OFF \
192 TOOLCHAIN_DISABLE_CLANG_WARNING(TOOLCHAIN_WARNING_EXTRA) \
193 TOOLCHAIN_DISABLE_GCC_WARNING(TOOLCHAIN_WARNING_ATTRIBUTES) \
194 TOOLCHAIN_DISABLE_IAR_WARNING(TOOLCHAIN_WARNING_ATTRIBUTES)
195#define ARCH_ISR_DIAG_ON \
196 TOOLCHAIN_ENABLE_CLANG_WARNING(TOOLCHAIN_WARNING_EXTRA) \
197 TOOLCHAIN_ENABLE_GCC_WARNING(TOOLCHAIN_WARNING_ATTRIBUTES) \
198 TOOLCHAIN_ENABLE_IAR_WARNING(TOOLCHAIN_WARNING_ATTRIBUTES)
199
200#define ARCH_ISR_DIRECT_DECLARE(name) \
201 static inline int name##_body(void); \
202 ARCH_ISR_DIAG_OFF \
203 __attribute__ ((interrupt ("IRQ"))) void name(void) \
204 { \
205 int check_reschedule; \
206 ISR_DIRECT_HEADER(); \
207 check_reschedule = name##_body(); \
208 ISR_DIRECT_FOOTER(check_reschedule); \
209 } \
210 ARCH_ISR_DIAG_ON \
211 static inline int name##_body(void)
212
213#if defined(CONFIG_DYNAMIC_DIRECT_INTERRUPTS)
214
215extern void z_arm_irq_direct_dynamic_dispatch_reschedule(void);
216extern void z_arm_irq_direct_dynamic_dispatch_no_reschedule(void);
217
270#define ARM_IRQ_DIRECT_DYNAMIC_CONNECT(irq_p, priority_p, flags_p, resch) \
271 IRQ_DIRECT_CONNECT(irq_p, priority_p, \
272 _CONCAT(z_arm_irq_direct_dynamic_dispatch_, resch), flags_p)
273
274#endif /* CONFIG_DYNAMIC_DIRECT_INTERRUPTS */
275
276#if defined(CONFIG_ARM_SECURE_FIRMWARE)
277/* Architecture-specific definition for the target security
278 * state of an NVIC IRQ line.
279 */
280typedef enum {
281 IRQ_TARGET_STATE_SECURE = 0,
282 IRQ_TARGET_STATE_NON_SECURE
283} irq_target_state_t;
284
285#endif /* CONFIG_ARM_SECURE_FIRMWARE */
286
287#endif /* _ASMLANGUAGE */
288
289#ifdef __cplusplus
290}
291#endif
292
293#endif /* ZEPHYR_INCLUDE_ARCH_ARM_IRQ_H_ */
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:59
void arm_irq_priority_set(unsigned int irq, unsigned int prio, uint32_t flags)
#define arch_irq_enable(irq)
Definition irq.h:58
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:60
Cortex-M context-switch support helpers.
static void arm_m_exc_tail(void)
ISR-tail helper that patches the stacked LR for deferred switch fixup.
Definition arm-m-switch.h:156
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.