14#ifndef ZEPHYR_INCLUDE_ARCH_ARC_V2_IRQ_H_
15#define ZEPHYR_INCLUDE_ARCH_ARC_V2_IRQ_H_
29extern void z_arc_firq_stack_set(
void);
33#ifdef CONFIG_TRACING_ISR
38extern void z_irq_priority_set(
unsigned int irq,
unsigned int prio,
49#define ARCH_IRQ_CONNECT(irq_p, priority_p, isr_p, isr_param_p, flags_p) \
51 Z_ISR_DECLARE(irq_p, 0, isr_p, isr_param_p); \
52 z_irq_priority_set(irq_p, priority_p, flags_p); \
76#define ARCH_IRQ_DIRECT_CONNECT(irq_p, priority_p, isr_p, flags_p) \
78 Z_ISR_DECLARE(irq_p, ISR_FLAG_DIRECT, isr_p, NULL); \
79 BUILD_ASSERT(priority_p || !IS_ENABLED(CONFIG_ARC_FIRQ) || \
80 (IS_ENABLED(CONFIG_ARC_FIRQ_STACK) && \
81 !IS_ENABLED(CONFIG_ARC_STACK_CHECKING)), \
82 "irq priority cannot be set to 0 when CONFIG_ARC_FIRQ_STACK" \
83 "is not configured or CONFIG_ARC_FIRQ_STACK " \
84 "and CONFIG_ARC_STACK_CHECKING are configured together"); \
85 z_irq_priority_set(irq_p, priority_p, flags_p); \
91#ifdef CONFIG_TRACING_ISR
99 if (z_arc_v2_aux_reg_read(_ARC_V2_ICAUSE) ==
100 z_arc_v2_aux_reg_read(_ARC_V2_AUX_IRQ_HINT)) {
101 z_arc_v2_aux_reg_write(_ARC_V2_AUX_IRQ_HINT, 0);
103#ifdef CONFIG_TRACING_ISR
108#define ARCH_ISR_DIRECT_HEADER() arch_isr_direct_header()
111#define ARCH_ISR_DIRECT_FOOTER(swap) arch_isr_direct_footer(swap)
114#define _ARC_DIRECT_ISR_FUNC_ATTRIBUTE __interrupt__
116#define _ARC_DIRECT_ISR_FUNC_ATTRIBUTE interrupt("ilink")
123#define ARCH_ISR_DIRECT_DECLARE(name) \
124 static inline int name##_body(void); \
125 __attribute__ ((_ARC_DIRECT_ISR_FUNC_ATTRIBUTE))void name(void) \
127 ISR_DIRECT_HEADER(); \
129 ISR_DIRECT_FOOTER(0); \
131 static inline int name##_body(void)
170 __asm__
volatile(
"clri %0" :
"=r"(
key)::
"memory");
176 __asm__
volatile(
"seti %0" : :
"ir"(
key) :
"memory");
185 return (
key & 0x10) == 0x10;
static ALWAYS_INLINE unsigned int arch_irq_lock(void)
Disable all interrupts on the local CPU.
Definition: irq.h:166
static ALWAYS_INLINE void arch_irq_unlock(unsigned int key)
Definition: irq.h:174
void arch_irq_disable(unsigned int irq)
int arch_irq_is_enabled(unsigned int irq)
static void arch_isr_direct_header(void)
Definition: irq.h:89
static void arch_isr_direct_footer(int maybe_swap)
Definition: irq.h:96
void arch_irq_enable(unsigned int irq)
static ALWAYS_INLINE bool arch_irq_unlocked(unsigned int key)
Definition: irq.h:179
ARCv2 auxiliary registers definitions.
Common toolchain abstraction.
#define ALWAYS_INLINE
Definition: common.h:124
void sys_trace_isr_enter(void)
Called when entering an ISR.
void sys_trace_isr_exit(void)
Called when exiting an ISR.
flags
Definition: http_parser.h:131
Public interface for configuring interrupts.
static k_spinlock_key_t key
Definition: spinlock_error_case.c:14
__UINT32_TYPE__ uint32_t
Definition: stdint.h:90
Software-managed ISR table.