arch/common: Provide a weak, generic z_arch_irq_connect_dynamic()
It was discovered that the xtensa version of z_arch_irq_connect_dynamic() was being removed along with the old xtensa architecture support, because it was never included in the asm2 builds. But there's no xtensa-specific code in it at all. Architectures that use the existing sw_isr_table mechanism and don't (or can't, in the case of xtensa which has fixed interrupt priority) interpret the other parameters might as well have access to a working generic implementation. Fixes #18272 Signed-off-by: Andy Ross <andrew.j.ross@intel.com>
This commit is contained in:
parent
1751648db0
commit
74d26094f8
1 changed files with 17 additions and 0 deletions
|
@ -24,4 +24,21 @@ void z_isr_install(unsigned int irq, void (*routine)(void *), void *param)
|
|||
_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 z_arch_irq_connect_dynamic(unsigned int irq,
|
||||
unsigned int priority,
|
||||
void (*routine)(void *),
|
||||
void *parameter,
|
||||
u32_t flags)
|
||||
{
|
||||
ARG_UNUSED(flags);
|
||||
ARG_UNUSED(priority);
|
||||
|
||||
z_isr_install(irq, routine, parameter);
|
||||
return irq;
|
||||
}
|
||||
|
||||
#endif /* CONFIG_DYNAMIC_INTERRUPTS */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue