2021-08-14 23:52:35 +02:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2021 Henrik Brix Andersen <henrik@brixandersen.dk>
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
2022-05-09 13:56:13 +02:00
|
|
|
#include <zephyr/toolchain.h>
|
2021-08-14 23:52:35 +02:00
|
|
|
|
|
|
|
GTEXT(__soc_handle_irq)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* SOC-specific function to handle pending IRQ number generating the interrupt.
|
|
|
|
* Exception number is given as parameter via register a0.
|
|
|
|
*/
|
|
|
|
SECTION_FUNC(exception.other, __soc_handle_irq)
|
|
|
|
/*
|
|
|
|
* The the MIP CSR on the NEORV32 is read-only and can thus not be used for
|
|
|
|
* clearing a pending IRQ. Instead we disable the IRQ in the MIE CSR and
|
|
|
|
* re-enable it (if it was enabled when clearing).
|
|
|
|
*/
|
|
|
|
li t1, 1
|
|
|
|
sll t0, t1, a0
|
|
|
|
csrrc t2, mie, t0
|
|
|
|
and t1, t2, t0
|
|
|
|
csrrs t2, mie, t1
|
|
|
|
|
|
|
|
/* Return */
|
2021-12-14 15:46:42 +01:00
|
|
|
ret
|