stm32f3xx_hal_usart_ex.h 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404
  1. /**
  2. ******************************************************************************
  3. * @file stm32f3xx_hal_usart_ex.h
  4. * @author MCD Application Team
  5. * @brief Header file of USART HAL Extended module.
  6. ******************************************************************************
  7. * @attention
  8. *
  9. * Copyright (c) 2016 STMicroelectronics.
  10. * All rights reserved.
  11. *
  12. * This software is licensed under terms that can be found in the LICENSE file
  13. * in the root directory of this software component.
  14. * If no LICENSE file comes with this software, it is provided AS-IS.
  15. *
  16. ******************************************************************************
  17. */
  18. /* Define to prevent recursive inclusion -------------------------------------*/
  19. #ifndef STM32F3xx_HAL_USART_EX_H
  20. #define STM32F3xx_HAL_USART_EX_H
  21. #ifdef __cplusplus
  22. extern "C" {
  23. #endif
  24. /* Includes ------------------------------------------------------------------*/
  25. #include "stm32f3xx_hal_def.h"
  26. /** @addtogroup STM32F3xx_HAL_Driver
  27. * @{
  28. */
  29. /** @addtogroup USARTEx
  30. * @{
  31. */
  32. /* Exported types ------------------------------------------------------------*/
  33. /* Exported constants --------------------------------------------------------*/
  34. /** @defgroup USARTEx_Exported_Constants USARTEx Exported Constants
  35. * @{
  36. */
  37. /** @defgroup USARTEx_Word_Length USARTEx Word Length
  38. * @{
  39. */
  40. #if defined(USART_CR1_M0)&& defined(USART_CR1_M1)
  41. #define USART_WORDLENGTH_7B (USART_CR1_M1) /*!< 7-bit long USART frame */
  42. #define USART_WORDLENGTH_8B (0x00000000U) /*!< 8-bit long USART frame */
  43. #define USART_WORDLENGTH_9B (USART_CR1_M0) /*!< 9-bit long USART frame */
  44. #elif defined(USART_CR1_M)
  45. #define USART_WORDLENGTH_8B (0x00000000U) /*!< 8-bit long USART frame */
  46. #define USART_WORDLENGTH_9B (USART_CR1_M) /*!< 9-bit long USART frame */
  47. #endif /* USART_CR1_M0 && USART_CR1_M */
  48. /**
  49. * @}
  50. */
  51. /**
  52. * @}
  53. */
  54. /* Private macros ------------------------------------------------------------*/
  55. /** @defgroup USARTEx_Private_Macros USARTEx Private Macros
  56. * @{
  57. */
  58. /** @brief Report the USART clock source.
  59. * @param __HANDLE__ specifies the USART Handle.
  60. * @param __CLOCKSOURCE__ output variable.
  61. * @retval the USART clocking source, written in __CLOCKSOURCE__.
  62. */
  63. /** @brief Report the USART clock source.
  64. * @param __HANDLE__ specifies the USART Handle.
  65. * @param __CLOCKSOURCE__ output variable.
  66. * @retval USART clocking source, written in __CLOCKSOURCE__.
  67. */
  68. #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx) || defined(STM32F302xC) \
  69. || defined(STM32F303xC) || defined(STM32F358xx)
  70. #define USART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \
  71. do { \
  72. if((__HANDLE__)->Instance == USART1) \
  73. { \
  74. switch(__HAL_RCC_GET_USART1_SOURCE()) \
  75. { \
  76. case RCC_USART1CLKSOURCE_PCLK2: \
  77. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK2; \
  78. break; \
  79. case RCC_USART1CLKSOURCE_HSI: \
  80. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \
  81. break; \
  82. case RCC_USART1CLKSOURCE_SYSCLK: \
  83. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \
  84. break; \
  85. case RCC_USART1CLKSOURCE_LSE: \
  86. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \
  87. break; \
  88. default: \
  89. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \
  90. break; \
  91. } \
  92. } \
  93. else if((__HANDLE__)->Instance == USART2) \
  94. { \
  95. switch(__HAL_RCC_GET_USART2_SOURCE()) \
  96. { \
  97. case RCC_USART2CLKSOURCE_PCLK1: \
  98. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \
  99. break; \
  100. case RCC_USART2CLKSOURCE_HSI: \
  101. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \
  102. break; \
  103. case RCC_USART2CLKSOURCE_SYSCLK: \
  104. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \
  105. break; \
  106. case RCC_USART2CLKSOURCE_LSE: \
  107. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \
  108. break; \
  109. default: \
  110. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \
  111. break; \
  112. } \
  113. } \
  114. else if((__HANDLE__)->Instance == USART3) \
  115. { \
  116. switch(__HAL_RCC_GET_USART3_SOURCE()) \
  117. { \
  118. case RCC_USART3CLKSOURCE_PCLK1: \
  119. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \
  120. break; \
  121. case RCC_USART3CLKSOURCE_HSI: \
  122. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \
  123. break; \
  124. case RCC_USART3CLKSOURCE_SYSCLK: \
  125. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \
  126. break; \
  127. case RCC_USART3CLKSOURCE_LSE: \
  128. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \
  129. break; \
  130. default: \
  131. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \
  132. break; \
  133. } \
  134. } \
  135. else \
  136. { \
  137. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \
  138. } \
  139. } while(0U)
  140. #elif defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx) || defined(STM32F301x8) \
  141. || defined(STM32F302x8) || defined(STM32F318xx)
  142. #define USART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \
  143. do { \
  144. if((__HANDLE__)->Instance == USART1) \
  145. { \
  146. switch(__HAL_RCC_GET_USART1_SOURCE()) \
  147. { \
  148. case RCC_USART1CLKSOURCE_PCLK1: \
  149. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \
  150. break; \
  151. case RCC_USART1CLKSOURCE_HSI: \
  152. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \
  153. break; \
  154. case RCC_USART1CLKSOURCE_SYSCLK: \
  155. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \
  156. break; \
  157. case RCC_USART1CLKSOURCE_LSE: \
  158. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \
  159. break; \
  160. default: \
  161. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \
  162. break; \
  163. } \
  164. } \
  165. else if((__HANDLE__)->Instance == USART2) \
  166. { \
  167. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \
  168. } \
  169. else if((__HANDLE__)->Instance == USART3) \
  170. { \
  171. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \
  172. } \
  173. else \
  174. { \
  175. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \
  176. } \
  177. } while(0U)
  178. #else
  179. #define USART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \
  180. do { \
  181. if((__HANDLE__)->Instance == USART1) \
  182. { \
  183. switch(__HAL_RCC_GET_USART1_SOURCE()) \
  184. { \
  185. case RCC_USART1CLKSOURCE_PCLK2: \
  186. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK2; \
  187. break; \
  188. case RCC_USART1CLKSOURCE_HSI: \
  189. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \
  190. break; \
  191. case RCC_USART1CLKSOURCE_SYSCLK: \
  192. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \
  193. break; \
  194. case RCC_USART1CLKSOURCE_LSE: \
  195. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \
  196. break; \
  197. default: \
  198. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \
  199. break; \
  200. } \
  201. } \
  202. else if((__HANDLE__)->Instance == USART2) \
  203. { \
  204. switch(__HAL_RCC_GET_USART2_SOURCE()) \
  205. { \
  206. case RCC_USART2CLKSOURCE_PCLK1: \
  207. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \
  208. break; \
  209. case RCC_USART2CLKSOURCE_HSI: \
  210. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \
  211. break; \
  212. case RCC_USART2CLKSOURCE_SYSCLK: \
  213. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \
  214. break; \
  215. case RCC_USART2CLKSOURCE_LSE: \
  216. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \
  217. break; \
  218. default: \
  219. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \
  220. break; \
  221. } \
  222. } \
  223. else if((__HANDLE__)->Instance == USART3) \
  224. { \
  225. switch(__HAL_RCC_GET_USART3_SOURCE()) \
  226. { \
  227. case RCC_USART3CLKSOURCE_PCLK1: \
  228. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \
  229. break; \
  230. case RCC_USART3CLKSOURCE_HSI: \
  231. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \
  232. break; \
  233. case RCC_USART3CLKSOURCE_SYSCLK: \
  234. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \
  235. break; \
  236. case RCC_USART3CLKSOURCE_LSE: \
  237. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \
  238. break; \
  239. default: \
  240. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \
  241. break; \
  242. } \
  243. } \
  244. else \
  245. { \
  246. (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \
  247. } \
  248. } while(0U)
  249. #endif /* STM32F302xE || STM32F303xE || STM32F398xx || STM32F302xC || STM32F303xC || STM32F358xx */
  250. /** @brief Compute the USART mask to apply to retrieve the received data
  251. * according to the word length and to the parity bits activation.
  252. * @note If PCE = 1, the parity bit is not included in the data extracted
  253. * by the reception API().
  254. * This masking operation is not carried out in the case of
  255. * DMA transfers.
  256. * @param __HANDLE__ specifies the USART Handle.
  257. * @retval None, the mask to apply to USART RDR register is stored in (__HANDLE__)->Mask field.
  258. */
  259. #if defined(USART_CR1_M0)&& defined(USART_CR1_M1)
  260. #define USART_MASK_COMPUTATION(__HANDLE__) \
  261. do { \
  262. if ((__HANDLE__)->Init.WordLength == USART_WORDLENGTH_9B) \
  263. { \
  264. if ((__HANDLE__)->Init.Parity == USART_PARITY_NONE) \
  265. { \
  266. (__HANDLE__)->Mask = 0x01FFU; \
  267. } \
  268. else \
  269. { \
  270. (__HANDLE__)->Mask = 0x00FFU; \
  271. } \
  272. } \
  273. else if ((__HANDLE__)->Init.WordLength == USART_WORDLENGTH_8B) \
  274. { \
  275. if ((__HANDLE__)->Init.Parity == USART_PARITY_NONE) \
  276. { \
  277. (__HANDLE__)->Mask = 0x00FFU; \
  278. } \
  279. else \
  280. { \
  281. (__HANDLE__)->Mask = 0x007FU; \
  282. } \
  283. } \
  284. else if ((__HANDLE__)->Init.WordLength == USART_WORDLENGTH_7B) \
  285. { \
  286. if ((__HANDLE__)->Init.Parity == USART_PARITY_NONE) \
  287. { \
  288. (__HANDLE__)->Mask = 0x007FU; \
  289. } \
  290. else \
  291. { \
  292. (__HANDLE__)->Mask = 0x003FU; \
  293. } \
  294. } \
  295. else \
  296. { \
  297. (__HANDLE__)->Mask = 0x0000U; \
  298. } \
  299. } while(0U)
  300. #elif defined(USART_CR1_M)
  301. #define USART_MASK_COMPUTATION(__HANDLE__) \
  302. do { \
  303. if ((__HANDLE__)->Init.WordLength == USART_WORDLENGTH_9B) \
  304. { \
  305. if ((__HANDLE__)->Init.Parity == USART_PARITY_NONE) \
  306. { \
  307. (__HANDLE__)->Mask = 0x01FFU; \
  308. } \
  309. else \
  310. { \
  311. (__HANDLE__)->Mask = 0x00FFU; \
  312. } \
  313. } \
  314. else if ((__HANDLE__)->Init.WordLength == USART_WORDLENGTH_8B) \
  315. { \
  316. if ((__HANDLE__)->Init.Parity == USART_PARITY_NONE) \
  317. { \
  318. (__HANDLE__)->Mask = 0x00FFU; \
  319. } \
  320. else \
  321. { \
  322. (__HANDLE__)->Mask = 0x007FU; \
  323. } \
  324. } \
  325. else \
  326. { \
  327. (__HANDLE__)->Mask = 0x0000U; \
  328. } \
  329. } while(0U)
  330. #endif /* USART_CR1_M0 && USART_CR1_M */
  331. /**
  332. * @brief Ensure that USART frame length is valid.
  333. * @param __LENGTH__ USART frame length.
  334. * @retval SET (__LENGTH__ is valid) or RESET (__LENGTH__ is invalid)
  335. */
  336. #if defined(USART_CR1_M0)&& defined(USART_CR1_M1)
  337. #define IS_USART_WORD_LENGTH(__LENGTH__) (((__LENGTH__) == USART_WORDLENGTH_7B) || \
  338. ((__LENGTH__) == USART_WORDLENGTH_8B) || \
  339. ((__LENGTH__) == USART_WORDLENGTH_9B))
  340. #elif defined(USART_CR1_M)
  341. #define IS_USART_WORD_LENGTH(__LENGTH__) (((__LENGTH__) == USART_WORDLENGTH_8B) || \
  342. ((__LENGTH__) == USART_WORDLENGTH_9B))
  343. #endif /* USART_CR1_M0 && USART_CR1_M */
  344. /**
  345. * @}
  346. */
  347. /* Exported functions --------------------------------------------------------*/
  348. /** @addtogroup USARTEx_Exported_Functions
  349. * @{
  350. */
  351. /** @addtogroup USARTEx_Exported_Functions_Group1
  352. * @{
  353. */
  354. /* IO operation functions *****************************************************/
  355. /**
  356. * @}
  357. */
  358. /** @addtogroup USARTEx_Exported_Functions_Group2
  359. * @{
  360. */
  361. /* Peripheral Control functions ***********************************************/
  362. /**
  363. * @}
  364. */
  365. /**
  366. * @}
  367. */
  368. /**
  369. * @}
  370. */
  371. /**
  372. * @}
  373. */
  374. #ifdef __cplusplus
  375. }
  376. #endif
  377. #endif /* STM32F3xx_HAL_USART_EX_H */