51 lines
1020 B
C
51 lines
1020 B
C
/*
|
|
* Copyright (c) 2020 Antony Pavlov <antonynpavlov@gmail.com>
|
|
*
|
|
* based on arch/riscv/core/irq_offload.c
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#include <zephyr/kernel.h>
|
|
#include <zephyr/kernel_structs.h>
|
|
#include <kernel_internal.h>
|
|
#include <zephyr/irq.h>
|
|
#include <zephyr/irq_offload.h>
|
|
|
|
volatile irq_offload_routine_t _offload_routine;
|
|
static volatile const void *offload_param;
|
|
|
|
/*
|
|
* Called by z_mips_enter_irq()
|
|
*
|
|
* Just in case the offload routine itself generates an unhandled
|
|
* exception, clear the offload_routine global before executing.
|
|
*/
|
|
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 ("syscall");
|
|
|
|
irq_unlock(key);
|
|
}
|