/* * Copyright (c) 2018 Intel Corporation. * * SPDX-License-Identifier: Apache-2.0 */ #include "sw_isr_common.h" #include #include #include void __weak z_isr_install(unsigned int irq, void (*routine)(const void *), const void *param) { unsigned int table_idx; /* * Do not assert on the IRQ enable status for ARM GIC since the SGI * type interrupts are always enabled and attempting to install an ISR * for them will cause the assertion to fail. */ #ifndef CONFIG_GIC __ASSERT(!irq_is_enabled(irq), "IRQ %d is enabled", irq); #endif /* !CONFIG_GIC */ table_idx = z_get_sw_isr_table_idx(irq); /* If dynamic IRQs are enabled, then the _sw_isr_table is in RAM and * can be modified */ _sw_isr_table[table_idx].arg = param; _sw_isr_table[table_idx].isr = routine; } /* Some architectures don't/can't interpret flags or priority and have * no more processing to do than this. Provide a generic fallback. */ int __weak arch_irq_connect_dynamic(unsigned int irq, unsigned int priority, void (*routine)(const void *), const void *parameter, uint32_t flags) { ARG_UNUSED(flags); ARG_UNUSED(priority); z_isr_install(irq, routine, parameter); return irq; }