1 /*
2  * Copyright (c) 2020 Nordic Semiconductor ASA
3  * Copyright (c) 2020 Oticon A/S
4  *
5  * SPDX-License-Identifier: Apache-2.0
6  */
7 
8 #include <stdint.h>
9 #include "irq_ctrl.h"
10 #include "posix_core.h"
11 #include "posix_board_if.h"
12 #include "board_soc.h"
13 #include "bs_tracing.h"
14 
15 /*
16  *  Replacement for ARMs NVIC functions()
17  */
NVIC_SetPendingIRQ(IRQn_Type IRQn)18 void NVIC_SetPendingIRQ(IRQn_Type IRQn)
19 {
20 	hw_irq_ctrl_raise_im_from_sw(CONFIG_NATIVE_SIMULATOR_MCU_N, IRQn);
21 }
22 
NVIC_ClearPendingIRQ(IRQn_Type IRQn)23 void NVIC_ClearPendingIRQ(IRQn_Type IRQn)
24 {
25 	hw_irq_ctrl_clear_irq(CONFIG_NATIVE_SIMULATOR_MCU_N, IRQn);
26 }
27 
NVIC_DisableIRQ(IRQn_Type IRQn)28 void NVIC_DisableIRQ(IRQn_Type IRQn)
29 {
30 	hw_irq_ctrl_disable_irq(CONFIG_NATIVE_SIMULATOR_MCU_N, IRQn);
31 }
32 
NVIC_GetPendingIRQ(IRQn_Type IRQn)33 uint32_t NVIC_GetPendingIRQ(IRQn_Type IRQn)
34 {
35 	return hw_irq_ctrl_is_irq_pending(CONFIG_NATIVE_SIMULATOR_MCU_N, IRQn);
36 }
37 
NVIC_EnableIRQ(IRQn_Type IRQn)38 void NVIC_EnableIRQ(IRQn_Type IRQn)
39 {
40 	hw_irq_ctrl_enable_irq(CONFIG_NATIVE_SIMULATOR_MCU_N, IRQn);
41 }
42 
NVIC_GetEnableIRQ(IRQn_Type IRQn)43 uint32_t NVIC_GetEnableIRQ(IRQn_Type IRQn)
44 {
45 	return hw_irq_ctrl_is_irq_enabled(CONFIG_NATIVE_SIMULATOR_MCU_N, IRQn);
46 }
47 
NVIC_SetPriority(IRQn_Type IRQn,uint32_t priority)48 void NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority)
49 {
50 	hw_irq_ctrl_prio_set(CONFIG_NATIVE_SIMULATOR_MCU_N, IRQn, priority);
51 }
52 
NVIC_GetPriority(IRQn_Type IRQn)53 uint32_t NVIC_GetPriority(IRQn_Type IRQn)
54 {
55 	return hw_irq_ctrl_get_prio(CONFIG_NATIVE_SIMULATOR_MCU_N, IRQn);
56 }
57 
NVIC_SystemReset(void)58 void NVIC_SystemReset(void)
59 {
60 	bs_trace_error_time_line("%s called. Exiting\n", __func__);
61 }
62 
63 /*
64  * Replacements for some other CMSIS functions
65  */
__enable_irq(void)66 void __enable_irq(void)
67 {
68 	hw_irq_ctrl_change_lock(CONFIG_NATIVE_SIMULATOR_MCU_N, false);
69 }
70 
__disable_irq(void)71 void __disable_irq(void)
72 {
73 	hw_irq_ctrl_change_lock(CONFIG_NATIVE_SIMULATOR_MCU_N, true);
74 }
75 
__get_PRIMASK(void)76 uint32_t __get_PRIMASK(void)
77 {
78 	return hw_irq_ctrl_get_current_lock(CONFIG_NATIVE_SIMULATOR_MCU_N);
79 }
80 
__set_PRIMASK(uint32_t primask)81 void __set_PRIMASK(uint32_t primask)
82 {
83 	hw_irq_ctrl_change_lock(CONFIG_NATIVE_SIMULATOR_MCU_N, primask != 0);
84 }
85 
__WFE(void)86 void __WFE(void)
87 {
88 	nrfbsim_WFE_model();
89 }
90 
__WFI(void)91 void __WFI(void)
92 {
93 	__WFE();
94 }
95 
__SEV(void)96 void __SEV(void)
97 {
98 	nrfbsim_SEV_model();
99 }
100