stm32f7xx_hal_uart_ex.h 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364
  1. /**
  2. ******************************************************************************
  3. * @file stm32f7xx_hal_uart_ex.h
  4. * @author MCD Application Team
  5. * @brief Header file of UART HAL Extension module.
  6. ******************************************************************************
  7. * @attention
  8. *
  9. * <h2><center>&copy; COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
  10. *
  11. * Redistribution and use in source and binary forms, with or without modification,
  12. * are permitted provided that the following conditions are met:
  13. * 1. Redistributions of source code must retain the above copyright notice,
  14. * this list of conditions and the following disclaimer.
  15. * 2. Redistributions in binary form must reproduce the above copyright notice,
  16. * this list of conditions and the following disclaimer in the documentation
  17. * and/or other materials provided with the distribution.
  18. * 3. Neither the name of STMicroelectronics nor the names of its contributors
  19. * may be used to endorse or promote products derived from this software
  20. * without specific prior written permission.
  21. *
  22. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  23. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  24. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  25. * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
  26. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  27. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  28. * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  29. * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  30. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  31. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  32. *
  33. ******************************************************************************
  34. */
  35. /* Define to prevent recursive inclusion -------------------------------------*/
  36. #ifndef __STM32F7xx_HAL_UART_EX_H
  37. #define __STM32F7xx_HAL_UART_EX_H
  38. #ifdef __cplusplus
  39. extern "C" {
  40. #endif
  41. /* Includes ------------------------------------------------------------------*/
  42. #include "stm32f7xx_hal_def.h"
  43. /** @addtogroup STM32F7xx_HAL_Driver
  44. * @{
  45. */
  46. /** @addtogroup UARTEx
  47. * @{
  48. */
  49. /* Exported types ------------------------------------------------------------*/
  50. /* Exported constants --------------------------------------------------------*/
  51. /** @defgroup UARTEx_Exported_Constants UARTEx Exported Constants
  52. * @{
  53. */
  54. /** @defgroup UARTEx_Word_Length UARTEx Word Length
  55. * @{
  56. */
  57. #define UART_WORDLENGTH_7B ((uint32_t)USART_CR1_M_1)
  58. #define UART_WORDLENGTH_8B ((uint32_t)0x0000U)
  59. #define UART_WORDLENGTH_9B ((uint32_t)USART_CR1_M_0)
  60. #define IS_UART_WORD_LENGTH(__LENGTH__) (((__LENGTH__) == UART_WORDLENGTH_7B) || \
  61. ((__LENGTH__) == UART_WORDLENGTH_8B) || \
  62. ((__LENGTH__) == UART_WORDLENGTH_9B))
  63. #define IS_LIN_WORD_LENGTH(LENGTH) (((LENGTH) == UART_WORDLENGTH_8B))
  64. /**
  65. * @}
  66. */
  67. /** @defgroup UARTEx_WakeUp_Address_Length UARTEx WakeUp Address Length
  68. * @{
  69. */
  70. #define UART_ADDRESS_DETECT_4B ((uint32_t)0x00000000U)
  71. #define UART_ADDRESS_DETECT_7B ((uint32_t)USART_CR2_ADDM7)
  72. #define IS_UART_ADDRESSLENGTH_DETECT(__ADDRESS__) (((__ADDRESS__) == UART_ADDRESS_DETECT_4B) || \
  73. ((__ADDRESS__) == UART_ADDRESS_DETECT_7B))
  74. /**
  75. * @}
  76. */
  77. /**
  78. * @}
  79. */
  80. /* Exported macro ------------------------------------------------------------*/
  81. /** @defgroup UARTEx_Exported_Macros UARTEx Exported Macros
  82. * @{
  83. */
  84. /** @brief Reports the UART clock source.
  85. * @param __HANDLE__ specifies the UART Handle
  86. * @param __CLOCKSOURCE__ output variable
  87. * @retval UART clocking source, written in __CLOCKSOURCE__.
  88. */
  89. #define UART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \
  90. do { \
  91. if((__HANDLE__)->Instance == USART1) \
  92. { \
  93. switch(__HAL_RCC_GET_USART1_SOURCE()) \
  94. { \
  95. case RCC_USART1CLKSOURCE_PCLK2: \
  96. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK2; \
  97. break; \
  98. case RCC_USART1CLKSOURCE_HSI: \
  99. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \
  100. break; \
  101. case RCC_USART1CLKSOURCE_SYSCLK: \
  102. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \
  103. break; \
  104. case RCC_USART1CLKSOURCE_LSE: \
  105. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \
  106. break; \
  107. default: \
  108. break; \
  109. } \
  110. } \
  111. else if((__HANDLE__)->Instance == USART2) \
  112. { \
  113. switch(__HAL_RCC_GET_USART2_SOURCE()) \
  114. { \
  115. case RCC_USART2CLKSOURCE_PCLK1: \
  116. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \
  117. break; \
  118. case RCC_USART2CLKSOURCE_HSI: \
  119. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \
  120. break; \
  121. case RCC_USART2CLKSOURCE_SYSCLK: \
  122. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \
  123. break; \
  124. case RCC_USART2CLKSOURCE_LSE: \
  125. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \
  126. break; \
  127. default: \
  128. break; \
  129. } \
  130. } \
  131. else if((__HANDLE__)->Instance == USART3) \
  132. { \
  133. switch(__HAL_RCC_GET_USART3_SOURCE()) \
  134. { \
  135. case RCC_USART3CLKSOURCE_PCLK1: \
  136. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \
  137. break; \
  138. case RCC_USART3CLKSOURCE_HSI: \
  139. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \
  140. break; \
  141. case RCC_USART3CLKSOURCE_SYSCLK: \
  142. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \
  143. break; \
  144. case RCC_USART3CLKSOURCE_LSE: \
  145. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \
  146. break; \
  147. default: \
  148. break; \
  149. } \
  150. } \
  151. else if((__HANDLE__)->Instance == UART4) \
  152. { \
  153. switch(__HAL_RCC_GET_UART4_SOURCE()) \
  154. { \
  155. case RCC_UART4CLKSOURCE_PCLK1: \
  156. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \
  157. break; \
  158. case RCC_UART4CLKSOURCE_HSI: \
  159. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \
  160. break; \
  161. case RCC_UART4CLKSOURCE_SYSCLK: \
  162. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \
  163. break; \
  164. case RCC_UART4CLKSOURCE_LSE: \
  165. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \
  166. break; \
  167. default: \
  168. break; \
  169. } \
  170. } \
  171. else if ((__HANDLE__)->Instance == UART5) \
  172. { \
  173. switch(__HAL_RCC_GET_UART5_SOURCE()) \
  174. { \
  175. case RCC_UART5CLKSOURCE_PCLK1: \
  176. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \
  177. break; \
  178. case RCC_UART5CLKSOURCE_HSI: \
  179. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \
  180. break; \
  181. case RCC_UART5CLKSOURCE_SYSCLK: \
  182. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \
  183. break; \
  184. case RCC_UART5CLKSOURCE_LSE: \
  185. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \
  186. break; \
  187. default: \
  188. break; \
  189. } \
  190. } \
  191. else if((__HANDLE__)->Instance == USART6) \
  192. { \
  193. switch(__HAL_RCC_GET_USART6_SOURCE()) \
  194. { \
  195. case RCC_USART6CLKSOURCE_PCLK2: \
  196. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK2; \
  197. break; \
  198. case RCC_USART6CLKSOURCE_HSI: \
  199. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \
  200. break; \
  201. case RCC_USART6CLKSOURCE_SYSCLK: \
  202. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \
  203. break; \
  204. case RCC_USART6CLKSOURCE_LSE: \
  205. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \
  206. break; \
  207. default: \
  208. break; \
  209. } \
  210. } \
  211. else if ((__HANDLE__)->Instance == UART7) \
  212. { \
  213. switch(__HAL_RCC_GET_UART7_SOURCE()) \
  214. { \
  215. case RCC_UART7CLKSOURCE_PCLK1: \
  216. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \
  217. break; \
  218. case RCC_UART7CLKSOURCE_HSI: \
  219. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \
  220. break; \
  221. case RCC_UART7CLKSOURCE_SYSCLK: \
  222. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \
  223. break; \
  224. case RCC_UART7CLKSOURCE_LSE: \
  225. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \
  226. break; \
  227. default: \
  228. break; \
  229. } \
  230. } \
  231. else if ((__HANDLE__)->Instance == UART8) \
  232. { \
  233. switch(__HAL_RCC_GET_UART8_SOURCE()) \
  234. { \
  235. case RCC_UART8CLKSOURCE_PCLK1: \
  236. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \
  237. break; \
  238. case RCC_UART8CLKSOURCE_HSI: \
  239. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \
  240. break; \
  241. case RCC_UART8CLKSOURCE_SYSCLK: \
  242. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \
  243. break; \
  244. case RCC_UART8CLKSOURCE_LSE: \
  245. (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \
  246. break; \
  247. default: \
  248. break; \
  249. } \
  250. } \
  251. } while(0)
  252. /** @brief Reports the UART mask to apply to retrieve the received data
  253. * according to the word length and to the parity bits activation.
  254. * If PCE = 1, the parity bit is not included in the data extracted
  255. * by the reception API().
  256. * This masking operation is not carried out in the case of
  257. * DMA transfers.
  258. * @param __HANDLE__ specifies the UART Handle
  259. * @retval mask to apply to UART RDR register value.
  260. */
  261. #define UART_MASK_COMPUTATION(__HANDLE__) \
  262. do { \
  263. if ((__HANDLE__)->Init.WordLength == UART_WORDLENGTH_9B) \
  264. { \
  265. if ((__HANDLE__)->Init.Parity == UART_PARITY_NONE) \
  266. { \
  267. (__HANDLE__)->Mask = 0x01FF ; \
  268. } \
  269. else \
  270. { \
  271. (__HANDLE__)->Mask = 0x00FF ; \
  272. } \
  273. } \
  274. else if ((__HANDLE__)->Init.WordLength == UART_WORDLENGTH_8B) \
  275. { \
  276. if ((__HANDLE__)->Init.Parity == UART_PARITY_NONE) \
  277. { \
  278. (__HANDLE__)->Mask = 0x00FF ; \
  279. } \
  280. else \
  281. { \
  282. (__HANDLE__)->Mask = 0x007F ; \
  283. } \
  284. } \
  285. else if ((__HANDLE__)->Init.WordLength == UART_WORDLENGTH_7B) \
  286. { \
  287. if ((__HANDLE__)->Init.Parity == UART_PARITY_NONE) \
  288. { \
  289. (__HANDLE__)->Mask = 0x007F ; \
  290. } \
  291. else \
  292. { \
  293. (__HANDLE__)->Mask = 0x003F ; \
  294. } \
  295. } \
  296. } while(0)
  297. /**
  298. * @}
  299. */
  300. /* Exported functions --------------------------------------------------------*/
  301. /** @addtogroup UARTEx_Exported_Functions
  302. * @{
  303. */
  304. /** @addtogroup UARTEx_Exported_Functions_Group1
  305. * @{
  306. */
  307. /* Initialization and de-initialization functions ****************************/
  308. HAL_StatusTypeDef HAL_RS485Ex_Init(UART_HandleTypeDef *huart, uint32_t Polarity, uint32_t AssertionTime, uint32_t DeassertionTime);
  309. /**
  310. * @}
  311. */
  312. /**
  313. * @}
  314. */
  315. /** @addtogroup UARTEx_Exported_Functions_Group3
  316. * @{
  317. */
  318. /* Peripheral Control functions **********************************************/
  319. HAL_StatusTypeDef HAL_MultiProcessorEx_AddressLength_Set(UART_HandleTypeDef *huart, uint32_t AddressLength);
  320. /**
  321. * @}
  322. */
  323. /**
  324. * @}
  325. */
  326. /**
  327. * @}
  328. */
  329. #ifdef __cplusplus
  330. }
  331. #endif
  332. #endif /* __STM32F7xx_HAL_UART_EX_H */
  333. /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/