Go to the documentation of this file.
53 #ifndef __GR55xx_HAL_H__
54 #define __GR55xx_HAL_H__
126 #define CO_MAX(a,b) ((a) > (b) ? (a) : (b))
131 #define BLE_INT_DISABLE() \
133 volatile uint32_t __ble_l_irq_rest = __get_PRIMASK(); \
134 volatile bool __ble_int_status = NVIC_GetEnableIRQ(BLE_IRQn) || NVIC_GetEnableIRQ(BLESLP_IRQn); \
136 if (__ble_int_status) \
138 NVIC_DisableIRQ(BLE_IRQn); \
139 NVIC_DisableIRQ(BLESLP_IRQn); \
141 __set_PRIMASK(__ble_l_irq_rest);
146 #define BLE_INT_RESTORE() \
147 __ble_l_irq_rest = __get_PRIMASK(); \
149 if (__ble_int_status) \
151 NVIC_EnableIRQ(BLE_IRQn); \
152 NVIC_EnableIRQ(BLESLP_IRQn); \
154 __set_PRIMASK(__ble_l_irq_rest); \
161 #define GLOBAL_INT_DISABLE() \
163 extern uint32_t global_int_disable(void); \
164 uint32_t __res_mask = global_int_disable()
169 #define GLOBAL_INT_RESTORE() \
170 extern void global_int_enable(uint32_t mask); \
171 global_int_enable(__res_mask); \
179 #define GLOBAL_INT_DISABLE() \
181 volatile uint32_t __nvic_iser0 = 0xFFFFFFFF; \
182 volatile uint32_t __nvic_iser1 = 0xFFFFFFFF; \
183 volatile uint32_t __ret_pri = __get_PRIMASK(); \
185 if( (NVIC->ICER[0] != 0xFFFFFFFF) || (NVIC->ICER[1] != 0xFFFFFFFF) ) \
187 __nvic_iser0 = NVIC->ISER[0]; \
188 __nvic_iser1 = NVIC->ISER[1]; \
189 NVIC->ICER[0] = 0xFFFFFFFF; \
190 NVIC->ICER[1] = 0xFFFFFFFF; \
192 __set_PRIMASK(__ret_pri); \
199 #define GLOBAL_INT_RESTORE() \
200 __ret_pri = __get_PRIMASK(); \
202 if( (__nvic_iser0 != 0xFFFFFFFF) || (__nvic_iser1 != 0xFFFFFFFF) ) \
204 NVIC->ISER[0] = __nvic_iser0; \
205 NVIC->ISER[1] = __nvic_iser1; \
207 __set_PRIMASK(__ret_pri); \
216 #define LOCAL_INT_DISABLE(IRQn_Type) \
218 uint32_t __l_irq_rest = __get_BASEPRI(); \
219 __set_BASEPRI(NVIC_GetPriority(IRQn_Type) + \
220 (1 << (NVIC_GetPriorityGrouping() + 1))); \
225 #define LOCAL_INT_RESTORE() \
226 __set_BASEPRI(__l_irq_rest); \
232 #define CHECK_IS_ON_FPGA() (AON->FPGA_CTRL & AON_REG_FPGA_CTRL_EXIST)
234 #define SYSTICK_RELOAD_VALUE (SysTick->LOAD)
235 #define SYSTICK_CURRENT_VALUE (SysTick->VAL)
void(* msp_deinit)(void)
Definition: gr55xx_hal.h:80
PERIPHERAL API DELAY DRIVER.
hal_status_t hal_init(void)
This function configures time base source, NVIC and Low level hardware.
uint32_t hal_get_hal_version(void)
This function returns the HAL revision.
struct _hal_callback hal_callback_t
HAL_HAL Callback function definition.
void hal_suspend_tick(void)
Suspend Tick increment.
hal_status_t hal_deinit(void)
This function de-initializes common part of the HAL and stops the source of time base.
void hal_resume_tick(void)
Resume Tick increment.
hal_status_t
HAL Status structures definition.
Definition: gr55xx_hal_def.h:70
HAL_HAL Callback function definition.
Definition: gr55xx_hal.h:78
hal_status_t hal_init_tick(uint32_t tick_priority)
This function configures the source of the time base.
void(* msp_init)(void)
Definition: gr55xx_hal.h:79
void hal_msp_init(void)
Initialize the MSP.
void hal_msp_deinit(void)
De-initialize the MSP.