Go to the documentation of this file.
53 #ifndef __GR55xx_HAL_H__
54 #define __GR55xx_HAL_H__
101 #define CO_MAX(a,b) ((a) > (b) ? (a) : (b))
106 #define BLE_INT_DISABLE() \
108 volatile uint32_t __ble_l_irq_rest = __get_PRIMASK(); \
109 volatile bool __ble_int_status = NVIC_GetEnableIRQ(BLE_IRQn) || NVIC_GetEnableIRQ(BLESLP_IRQn); \
111 if (__ble_int_status) \
113 NVIC_DisableIRQ(BLE_IRQn); \
114 NVIC_DisableIRQ(BLESLP_IRQn); \
116 __set_PRIMASK(__ble_l_irq_rest);
121 #define BLE_INT_RESTORE() \
122 __ble_l_irq_rest = __get_PRIMASK(); \
124 if (__ble_int_status) \
126 NVIC_EnableIRQ(BLE_IRQn); \
127 NVIC_EnableIRQ(BLESLP_IRQn); \
129 __set_PRIMASK(__ble_l_irq_rest); \
137 #define GLOBAL_INT_DISABLE() \
139 extern uint32_t global_int_disable(void); \
140 uint32_t __res_mask = global_int_disable()
145 #define GLOBAL_INT_RESTORE() \
146 extern void global_int_enable(uint32_t mask); \
147 global_int_enable(__res_mask); \
155 #define GLOBAL_INT_DISABLE() \
157 volatile uint32_t __nvic_iser0 = 0xFFFFFFFF; \
158 volatile uint32_t __nvic_iser1 = 0xFFFFFFFF; \
159 volatile uint32_t __ret_pri = __get_PRIMASK(); \
161 if( (NVIC->ICER[0] != 0xFFFFFFFF) || (NVIC->ICER[1] != 0xFFFFFFFF) ) \
163 __nvic_iser0 = NVIC->ISER[0]; \
164 __nvic_iser1 = NVIC->ISER[1]; \
165 NVIC->ICER[0] = 0xFFFFFFFF; \
166 NVIC->ICER[1] = 0xFFFFFFFF; \
168 __set_PRIMASK(__ret_pri); \
175 #define GLOBAL_INT_RESTORE() \
176 __ret_pri = __get_PRIMASK(); \
178 if( (__nvic_iser0 != 0xFFFFFFFF) || (__nvic_iser1 != 0xFFFFFFFF) ) \
180 NVIC->ISER[0] = __nvic_iser0; \
181 NVIC->ISER[1] = __nvic_iser1; \
183 __set_PRIMASK(__ret_pri); \
192 #define LOCAL_INT_DISABLE(IRQn_Type) \
194 uint32_t __l_irq_rest = __get_BASEPRI(); \
195 __set_BASEPRI(NVIC_GetPriority(IRQn_Type) + \
196 (1 << (NVIC_GetPriorityGrouping() + 1))); \
201 #define LOCAL_INT_RESTORE() \
202 __set_BASEPRI(__l_irq_rest); \
208 #define CHECK_IS_ON_FPGA() (AON->FPGA_CTRL & AON_REG_FPGA_CTRL_EXIST)
210 #define SYSTICK_RELOAD_VALUE (SysTick->LOAD)
211 #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.