16811660ee
In order to bring consistency in-tree, migrate all arch code to the new prefix <zephyr/...>. Note that the conversion has been scripted, refer to zephyrproject-rtos#45388 for more details. Signed-off-by: Gerard Marull-Paretas <gerard.marull@nordicsemi.no>
42 lines
754 B
C
42 lines
754 B
C
/*
|
|
* Copyright (c) 2019-2020 Cobham Gaisler AB
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#include <zephyr/kernel.h>
|
|
#include <zephyr/kernel_structs.h>
|
|
#include <zephyr/irq.h>
|
|
#include <zephyr/irq_offload.h>
|
|
|
|
volatile irq_offload_routine_t _offload_routine;
|
|
static volatile const void *offload_param;
|
|
|
|
void z_irq_do_offload(void)
|
|
{
|
|
irq_offload_routine_t tmp;
|
|
|
|
if (!_offload_routine) {
|
|
return;
|
|
}
|
|
|
|
tmp = _offload_routine;
|
|
_offload_routine = NULL;
|
|
|
|
tmp((const void *)offload_param);
|
|
}
|
|
|
|
void arch_irq_offload(irq_offload_routine_t routine, const void *parameter)
|
|
{
|
|
unsigned int key;
|
|
|
|
key = irq_lock();
|
|
_offload_routine = routine;
|
|
offload_param = parameter;
|
|
|
|
/* Generate irq offload trap */
|
|
__asm__ volatile ("ta 13");
|
|
|
|
irq_unlock(key);
|
|
}
|