/*
|
* Copyright (c) 2020 Nordic Semiconductor ASA
|
* Copyright (c) 2020 Oticon A/S
|
* Copyright (c) 2021 Codecoup
|
*
|
* SPDX-License-Identifier: Apache-2.0
|
*/
|
|
#include <stdint.h>
|
#include "irq_ctrl.h"
|
|
#include "irq_sources.h"
|
#include <nrfx.h>
|
#include "cmsis.h"
|
#include "os/sim.h"
|
|
#include <stdbool.h>
|
#include <stddef.h>
|
|
extern void (* systemVectors[256])(void);
|
|
/*
|
* Replacement for ARMs NVIC functions()
|
*/
|
void NVIC_SetPendingIRQ(IRQn_Type IRQn)
|
{
|
hw_irq_ctrl_raise_im_from_sw(IRQn);
|
}
|
|
void NVIC_ClearPendingIRQ(IRQn_Type IRQn)
|
{
|
hw_irq_ctrl_clear_irq(IRQn);
|
}
|
|
void NVIC_DisableIRQ(IRQn_Type IRQn)
|
{
|
hw_irq_ctrl_disable_irq(IRQn);
|
}
|
|
void NVIC_EnableIRQ(IRQn_Type IRQn)
|
{
|
hw_irq_ctrl_enable_irq(IRQn);
|
}
|
|
void NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority)
|
{
|
hw_irq_ctrl_prio_set(IRQn, priority);
|
}
|
|
uint32_t NVIC_GetPriority(IRQn_Type IRQn)
|
{
|
return hw_irq_ctrl_get_prio(IRQn);
|
}
|
|
void NVIC_SystemReset(void)
|
{
|
inner_main_clean_up(1);
|
}
|
|
/*
|
* Replacements for some other CMSIS functions
|
*/
|
void __enable_irq(void)
|
{
|
hw_irq_ctrl_change_lock(false);
|
}
|
|
void __disable_irq(void)
|
{
|
hw_irq_ctrl_change_lock(true);
|
}
|
|
uint32_t __get_PRIMASK(void)
|
{
|
return hw_irq_ctrl_get_current_lock();
|
}
|
|
void NVIC_SetVector(IRQn_Type IRQn, uint32_t vector)
|
{
|
systemVectors[(int32_t)IRQn + 16] = (void(*)(void))vector;
|
}
|