Bump clang version to 18 (#14116)
[betaflight.git] / lib / main / STM32H7 / Drivers / STM32H7xx_HAL_Driver / Inc / stm32h7xx_hal_hsem.h
blobdf57b77305811b6ab83a325d0f8431a2fc8dfd63
1 /**
2 ******************************************************************************
3 * @file stm32h7xx_hal_hsem.h
4 * @author MCD Application Team
5 * @brief Header file of HSEM HAL module.
6 ******************************************************************************
7 * @attention
9 * <h2><center>&copy; Copyright (c) 2017 STMicroelectronics.
10 * All rights reserved.</center></h2>
12 * This software component is licensed by ST under BSD 3-Clause license,
13 * the "License"; You may not use this file except in compliance with the
14 * License. You may obtain a copy of the License at:
15 * opensource.org/licenses/BSD-3-Clause
17 ******************************************************************************
20 /* Define to prevent recursive inclusion -------------------------------------*/
21 #ifndef STM32H7xx_HAL_HSEM_H
22 #define STM32H7xx_HAL_HSEM_H
24 #ifdef __cplusplus
25 extern "C" {
26 #endif
28 /* Includes ------------------------------------------------------------------*/
29 #include "stm32h7xx_hal_def.h"
31 /** @addtogroup STM32H7xx_HAL_Driver
32 * @{
35 /** @addtogroup HSEM
36 * @{
39 /* Exported macro ------------------------------------------------------------*/
40 /** @defgroup HSEM_Exported_Macros HSEM Exported Macros
41 * @{
44 /**
45 * @brief SemID to mask helper Macro.
46 * @param __SEMID__: semaphore ID from 0 to 31
47 * @retval Semaphore Mask.
49 #define __HAL_HSEM_SEMID_TO_MASK(__SEMID__) (1 << (__SEMID__))
51 /**
52 * @brief Enables the specified HSEM interrupts.
53 * @param __SEM_MASK__: semaphores Mask
54 * @retval None.
56 #if defined(DUAL_CORE)
57 #define __HAL_HSEM_ENABLE_IT(__SEM_MASK__) ((((SCB->CPUID & 0x000000F0) >> 4 )== 0x7) ? \
58 (HSEM->C1IER |= (__SEM_MASK__)) : \
59 (HSEM->C2IER |= (__SEM_MASK__)))
60 #else
61 #define __HAL_HSEM_ENABLE_IT(__SEM_MASK__) (HSEM->IER |= (__SEM_MASK__))
62 #endif /* DUAL_CORE */
63 /**
64 * @brief Disables the specified HSEM interrupts.
65 * @param __SEM_MASK__: semaphores Mask
66 * @retval None.
68 #if defined(DUAL_CORE)
69 #define __HAL_HSEM_DISABLE_IT(__SEM_MASK__) ((((SCB->CPUID & 0x000000F0) >> 4 )== 0x7) ? \
70 (HSEM->C1IER &= ~(__SEM_MASK__)) : \
71 (HSEM->C2IER &= ~(__SEM_MASK__)))
72 #else
73 #define __HAL_HSEM_DISABLE_IT(__SEM_MASK__) (HSEM->IER &= ~(__SEM_MASK__))
74 #endif /* DUAL_CORE */
76 /**
77 * @brief Checks whether interrupt has occurred or not for semaphores specified by a mask.
78 * @param __SEM_MASK__: semaphores Mask
79 * @retval semaphores Mask : Semaphores where an interrupt occurred.
81 #if defined(DUAL_CORE)
82 #define __HAL_HSEM_GET_IT(__SEM_MASK__) ((((SCB->CPUID & 0x000000F0) >> 4 )== 0x7) ? \
83 ((__SEM_MASK__) & HSEM->C1MISR) : \
84 ((__SEM_MASK__) & HSEM->C2MISR1))
85 #else
86 #define __HAL_HSEM_GET_IT(__SEM_MASK__) ((__SEM_MASK__) & HSEM->MISR)
87 #endif /* DUAL_CORE */
89 /**
90 * @brief Get the semaphores release status flags.
91 * @param __SEM_MASK__: semaphores Mask
92 * @retval semaphores Mask : Semaphores where Release flags rise.
94 #if defined(DUAL_CORE)
95 #define __HAL_HSEM_GET_FLAG(__SEM_MASK__) ((((SCB->CPUID & 0x000000F0) >> 4 )== 0x7) ? \
96 (__SEM_MASK__) & HSEM->C1ISR : \
97 (__SEM_MASK__) & HSEM->C2ISR)
98 #else
99 #define __HAL_HSEM_GET_FLAG(__SEM_MASK__) ((__SEM_MASK__) & HSEM->ISR)
100 #endif /* DUAL_CORE */
103 * @brief Clears the HSEM Interrupt flags.
104 * @param __SEM_MASK__: semaphores Mask
105 * @retval None.
107 #if defined(DUAL_CORE)
108 #define __HAL_HSEM_CLEAR_FLAG(__SEM_MASK__) ((((SCB->CPUID & 0x000000F0) >> 4 )== 0x7) ? \
109 (HSEM->C1ICR |= (__SEM_MASK__)) : \
110 (HSEM->C2ICR |= (__SEM_MASK__)))
111 #else
112 #define __HAL_HSEM_CLEAR_FLAG(__SEM_MASK__) (HSEM->ICR |= (__SEM_MASK__))
113 #endif /* DUAL_CORE */
116 * @}
119 /* Exported functions --------------------------------------------------------*/
120 /** @defgroup HSEM_Exported_Functions HSEM Exported Functions
121 * @{
124 /** @addtogroup HSEM_Exported_Functions_Group1 Take and Release functions
125 * @brief HSEM Take and Release functions
126 * @{
129 /* HSEM semaphore take (lock) using 2-Step method ****************************/
130 HAL_StatusTypeDef HAL_HSEM_Take(uint32_t SemID, uint32_t ProcessID);
131 /* HSEM semaphore fast take (lock) using 1-Step method ***********************/
132 HAL_StatusTypeDef HAL_HSEM_FastTake(uint32_t SemID);
133 /* HSEM Check semaphore state Taken or not **********************************/
134 uint32_t HAL_HSEM_IsSemTaken(uint32_t SemID);
135 /* HSEM Release **************************************************************/
136 void HAL_HSEM_Release(uint32_t SemID, uint32_t ProcessID);
137 /* HSEM Release All************************************************************/
138 void HAL_HSEM_ReleaseAll(uint32_t Key, uint32_t CoreID);
141 * @}
144 /** @addtogroup HSEM_Exported_Functions_Group2 HSEM Set and Get Key functions
145 * @brief HSEM Set and Get Key functions.
146 * @{
148 /* HSEM Set Clear Key *********************************************************/
149 void HAL_HSEM_SetClearKey(uint32_t Key);
150 /* HSEM Get Clear Key *********************************************************/
151 uint32_t HAL_HSEM_GetClearKey(void);
153 * @}
156 /** @addtogroup HSEM_Exported_Functions_Group3
157 * @brief HSEM Notification functions
158 * @{
160 /* HSEM Activate HSEM Notification (When a semaphore is released) ) *****************/
161 void HAL_HSEM_ActivateNotification(uint32_t SemMask);
162 /* HSEM Deactivate HSEM Notification (When a semaphore is released) ****************/
163 void HAL_HSEM_DeactivateNotification(uint32_t SemMask);
164 /* HSEM Free Callback (When a semaphore is released) *******************************/
165 void HAL_HSEM_FreeCallback(uint32_t SemMask);
166 /* HSEM IRQ Handler **********************************************************/
167 void HAL_HSEM_IRQHandler(void);
170 * @}
174 * @}
177 /* Private macros ------------------------------------------------------------*/
178 /** @defgroup HSEM_Private_Macros HSEM Private Macros
179 * @{
182 #define IS_HSEM_SEMID(__SEMID__) ((__SEMID__) <= HSEM_SEMID_MAX )
184 #define IS_HSEM_PROCESSID(__PROCESSID__) ((__PROCESSID__) <= HSEM_PROCESSID_MAX )
186 #define IS_HSEM_KEY(__KEY__) ((__KEY__) <= HSEM_CLEAR_KEY_MAX )
188 #if defined(DUAL_CORE)
189 #define IS_HSEM_COREID(__COREID__) (((__COREID__) == HSEM_CPU1_COREID) || \
190 ((__COREID__) == HSEM_CPU2_COREID))
191 #else
192 #define IS_HSEM_COREID(__COREID__) ((__COREID__) == HSEM_CPU1_COREID)
193 #endif
197 * @}
201 * @}
205 * @}
208 #ifdef __cplusplus
210 #endif
212 #endif /* STM32H7xx_HAL_HSEM_H */
214 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/