123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- /*
- * Copyright (c) 2014, Wind River Systems, Inc.
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- /**
- * @file
- * @brief Software-managed ISR table
- *
- * Data types for a software-managed ISR table, with a parameter per-ISR.
- */
- #ifndef ZEPHYR_INCLUDE_SW_ISR_TABLE_H_
- #define ZEPHYR_INCLUDE_SW_ISR_TABLE_H_
- #if !defined(_ASMLANGUAGE)
- #include <zephyr/types.h>
- #include <toolchain.h>
- #ifdef __cplusplus
- extern "C" {
- #endif
- /*
- * Note the order: arg first, then ISR. This allows a table entry to be
- * loaded arg -> r0, isr -> r3 in _isr_wrapper with one ldmia instruction,
- * on ARM Cortex-M (Thumb2).
- */
- struct _isr_table_entry {
- const void *arg;
- void (*isr)(const void *);
- #ifdef CONFIG_TRACING_IRQ_PROFILER
- uint32_t irq_cnt;
- uint32_t max_irq_cycles;
- uint32_t irq_total_us;
- #endif
- };
- /* The software ISR table itself, an array of these structures indexed by the
- * irq line
- */
- extern struct _isr_table_entry _sw_isr_table[];
- /*
- * Data structure created in a special binary .intlist section for each
- * configured interrupt. gen_irq_tables.py pulls this out of the binary and
- * uses it to create the IRQ vector table and the _sw_isr_table.
- *
- * More discussion in include/linker/intlist.ld
- */
- struct _isr_list {
- /** IRQ line number */
- int32_t irq;
- /** Flags for this IRQ, see ISR_FLAG_* definitions */
- int32_t flags;
- /** ISR to call */
- void *func;
- /** Parameter for non-direct IRQs */
- const void *param;
- };
- /** This interrupt gets put directly in the vector table */
- #define ISR_FLAG_DIRECT BIT(0)
- #define _MK_ISR_NAME(x, y) __MK_ISR_NAME(x, y)
- #define __MK_ISR_NAME(x, y) __isr_ ## x ## _irq_ ## y
- /* Create an instance of struct _isr_list which gets put in the .intList
- * section. This gets consumed by gen_isr_tables.py which creates the vector
- * and/or SW ISR tables.
- */
- #ifndef __UVISION_VERSION
- #define Z_ISR_DECLARE(irq, flags, func, param) \
- static Z_DECL_ALIGN(struct _isr_list) Z_GENERIC_SECTION(.intList) \
- __used _MK_ISR_NAME(func, __COUNTER__) = \
- {irq, flags, (void *)&func, (const void *)param}
- #else
- #define Z_ISR_DECLARE(irq, flags, func, param) \
- _sw_isr_table[irq].arg = (void *)param; \
- _sw_isr_table[irq].isr = (void (*)(const void *))func;
- #endif
- #define IRQ_TABLE_SIZE (CONFIG_NUM_IRQS - CONFIG_GEN_IRQ_START_VECTOR)
- #ifdef CONFIG_DYNAMIC_INTERRUPTS
- void z_isr_install(unsigned int irq, void (*routine)(const void *),
- const void *param);
- #endif
- #ifdef __cplusplus
- }
- #endif
- #endif /* _ASMLANGUAGE */
- #endif /* ZEPHYR_INCLUDE_SW_ISR_TABLE_H_ */
|