SWM341_uart.c 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463
  1. /******************************************************************************************************************************************
  2. * 文件名称: SWM341_uart.c
  3. * 功能说明: SWM341单片机的UART串口功能驱动库
  4. * 技术支持: http://www.synwit.com.cn/e/tool/gbook/?bid=1
  5. * 注意事项: 没有编写LIN功能相关的函数
  6. * 版本日期: V1.0.0 2016年1月30日
  7. * 升级记录:
  8. *
  9. *
  10. *******************************************************************************************************************************************
  11. * @attention
  12. *
  13. * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS WITH CODING INFORMATION
  14. * REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME. AS A RESULT, SYNWIT SHALL NOT BE HELD LIABLE
  15. * FOR ANY DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE CONTENT
  16. * OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING INFORMATION CONTAINED HEREIN IN CONN-
  17. * -ECTION WITH THEIR PRODUCTS.
  18. *
  19. * COPYRIGHT 2012 Synwit Technology
  20. *******************************************************************************************************************************************/
  21. #include "SWM341.h"
  22. #include "SWM341_uart.h"
  23. /******************************************************************************************************************************************
  24. * 函数名称: UART_Init()
  25. * 功能说明: UART串口初始化
  26. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  27. * UART_InitStructure * initStruct 包含UART串口相关设定值的结构体
  28. * 输 出: 无
  29. * 注意事项: 无
  30. ******************************************************************************************************************************************/
  31. void UART_Init(UART_TypeDef * UARTx, UART_InitStructure * initStruct)
  32. {
  33. switch((uint32_t)UARTx)
  34. {
  35. case ((uint32_t)UART0):
  36. SYS->CLKEN0 |= (0x01 << SYS_CLKEN0_UART0_Pos);
  37. break;
  38. case ((uint32_t)UART1):
  39. SYS->CLKEN0 |= (0x01 << SYS_CLKEN0_UART1_Pos);
  40. break;
  41. case ((uint32_t)UART2):
  42. SYS->CLKEN0 |= (0x01 << SYS_CLKEN0_UART2_Pos);
  43. break;
  44. case ((uint32_t)UART3):
  45. SYS->CLKEN0 |= (0x01 << SYS_CLKEN0_UART3_Pos);
  46. break;
  47. }
  48. UART_Close(UARTx); //一些关键寄存器只能在串口关闭时设置
  49. UARTx->BAUD &= ~(UART_BAUD_BAUD_Msk | UART_BAUD_FRAC_Msk);
  50. UARTx->BAUD |= (((SystemCoreClock/initStruct->Baudrate - 1) / 16) << UART_BAUD_BAUD_Pos) |
  51. (((SystemCoreClock/initStruct->Baudrate - 1) % 16) << UART_BAUD_FRAC_Pos);
  52. UARTx->CTRL &= ~(UART_CTRL_DATA9b_Msk | UART_CTRL_PARITY_Msk | UART_CTRL_STOP2b_Msk);
  53. UARTx->CTRL |= (initStruct->DataBits << UART_CTRL_DATA9b_Pos) |
  54. (initStruct->Parity << UART_CTRL_PARITY_Pos) |
  55. (initStruct->StopBits << UART_CTRL_STOP2b_Pos);
  56. UARTx->FIFO &= ~(UART_FIFO_RXTHR_Msk | UART_FIFO_TXTHR_Msk);
  57. UARTx->FIFO |= (initStruct->RXThreshold << UART_FIFO_RXTHR_Pos) |
  58. (initStruct->TXThreshold << UART_FIFO_TXTHR_Pos);
  59. UARTx->TOCR &= ~UART_TOCR_TIME_Msk;
  60. UARTx->TOCR |= (1 << UART_TOCR_MODE_Pos) |
  61. (initStruct->TimeoutTime << UART_TOCR_TIME_Pos);
  62. UARTx->CTRL &= ~(UART_CTRL_RXIE_Msk | UART_CTRL_TXIE_Msk | UART_CTRL_TOIE_Msk);
  63. UARTx->CTRL |= (initStruct->RXThresholdIEn << UART_CTRL_RXIE_Pos) |
  64. (initStruct->TXThresholdIEn << UART_CTRL_TXIE_Pos) |
  65. (initStruct->TimeoutIEn << UART_CTRL_TOIE_Pos);
  66. switch((uint32_t)UARTx)
  67. {
  68. case ((uint32_t)UART0):
  69. if(initStruct->RXThresholdIEn | initStruct->TXThresholdIEn | initStruct->TimeoutIEn)
  70. {
  71. NVIC_EnableIRQ(UART0_IRQn);
  72. }
  73. else
  74. {
  75. NVIC_DisableIRQ(UART0_IRQn);
  76. }
  77. break;
  78. case ((uint32_t)UART1):
  79. if(initStruct->RXThresholdIEn | initStruct->TXThresholdIEn | initStruct->TimeoutIEn)
  80. {
  81. NVIC_EnableIRQ(UART1_IRQn);
  82. }
  83. else
  84. {
  85. NVIC_DisableIRQ(UART1_IRQn);
  86. }
  87. break;
  88. case ((uint32_t)UART2):
  89. if(initStruct->RXThresholdIEn | initStruct->TXThresholdIEn | initStruct->TimeoutIEn)
  90. {
  91. NVIC_EnableIRQ(UART2_IRQn);
  92. }
  93. else
  94. {
  95. NVIC_DisableIRQ(UART2_IRQn);
  96. }
  97. break;
  98. case ((uint32_t)UART3):
  99. if(initStruct->RXThresholdIEn | initStruct->TXThresholdIEn | initStruct->TimeoutIEn)
  100. {
  101. NVIC_EnableIRQ(UART3_IRQn);
  102. }
  103. else
  104. {
  105. NVIC_DisableIRQ(UART3_IRQn);
  106. }
  107. break;
  108. }
  109. }
  110. /******************************************************************************************************************************************
  111. * 函数名称: UART_Open()
  112. * 功能说明: UART串口打开
  113. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  114. * 输 出: 无
  115. * 注意事项: 无
  116. ******************************************************************************************************************************************/
  117. void UART_Open(UART_TypeDef * UARTx)
  118. {
  119. UARTx->CTRL |= (0x01 << UART_CTRL_EN_Pos);
  120. }
  121. /******************************************************************************************************************************************
  122. * 函数名称: UART_Close()
  123. * 功能说明: UART串口关闭
  124. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  125. * 输 出: 无
  126. * 注意事项: 无
  127. ******************************************************************************************************************************************/
  128. void UART_Close(UART_TypeDef * UARTx)
  129. {
  130. UARTx->CTRL &= ~(0x01 << UART_CTRL_EN_Pos);
  131. }
  132. /******************************************************************************************************************************************
  133. * 函数名称: UART_WriteByte()
  134. * 功能说明: 发送一个字节数据
  135. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,可取值包括UART0、UART1、UART2、UART3、UART4
  136. * uint8_t data 要发送的字节
  137. * 输 出: 无
  138. * 注意事项: 无
  139. ******************************************************************************************************************************************/
  140. void UART_WriteByte(UART_TypeDef * UARTx, uint8_t data)
  141. {
  142. UARTx->DATA = data;
  143. }
  144. /******************************************************************************************************************************************
  145. * 函数名称: UART_ReadByte()
  146. * 功能说明: 读取一个字节数据,并指出数据是否Valid
  147. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,可取值包括UART0、UART1、UART2、UART3、UART4
  148. * uint32_t * data 接收到的数据
  149. * 输 出: uint32_t 0 无错误 UART_ERR_PARITY 奇偶校验错误
  150. * 注意事项: 无
  151. ******************************************************************************************************************************************/
  152. uint32_t UART_ReadByte(UART_TypeDef * UARTx, uint32_t * data)
  153. {
  154. uint32_t reg = UARTx->DATA;
  155. *data = (reg & UART_DATA_DATA_Msk);
  156. if(reg & UART_DATA_PAERR_Msk) return UART_ERR_PARITY;
  157. return 0;
  158. }
  159. /******************************************************************************************************************************************
  160. * 函数名称: UART_IsTXBusy()
  161. * 功能说明: UART是否正在发送数据
  162. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  163. * 输 出: uint32_t 1 UART正在发送数据 0 数据已发完
  164. * 注意事项: 无
  165. ******************************************************************************************************************************************/
  166. uint32_t UART_IsTXBusy(UART_TypeDef * UARTx)
  167. {
  168. return (UARTx->CTRL & UART_CTRL_TXIDLE_Msk) ? 0 : 1;
  169. }
  170. /******************************************************************************************************************************************
  171. * 函数名称: UART_IsRXFIFOEmpty()
  172. * 功能说明: 接收FIFO是否为空,如果不空则说明其中有数据可以读取
  173. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  174. * 输 出: uint32_t 1 接收FIFO空 0 接收FIFO非空
  175. * 注意事项: 无
  176. ******************************************************************************************************************************************/
  177. uint32_t UART_IsRXFIFOEmpty(UART_TypeDef * UARTx)
  178. {
  179. return (UARTx->CTRL & UART_CTRL_RXNE_Msk) ? 0 : 1;
  180. }
  181. /******************************************************************************************************************************************
  182. * 函数名称: UART_IsTXFIFOFull()
  183. * 功能说明: 发送FIFO是否为满,如果不满则可以继续向其中写入数据
  184. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  185. * 输 出: uint32_t 1 发送FIFO满 0 发送FIFO不满
  186. * 注意事项: 无
  187. ******************************************************************************************************************************************/
  188. uint32_t UART_IsTXFIFOFull(UART_TypeDef * UARTx)
  189. {
  190. return (UARTx->CTRL & UART_CTRL_TXFF_Msk) ? 1 : 0;
  191. }
  192. /******************************************************************************************************************************************
  193. * 函数名称: UART_SetBaudrate()
  194. * 功能说明: 设置波特率
  195. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  196. * uint32_t baudrate 要设置的波特率
  197. * 输 出: 无
  198. * 注意事项: 不要在串口工作时更改波特率,使用此函数前请先调用UART_Close()关闭串口
  199. ******************************************************************************************************************************************/
  200. void UART_SetBaudrate(UART_TypeDef * UARTx, uint32_t baudrate)
  201. {
  202. UARTx->BAUD &= ~(UART_BAUD_BAUD_Msk | UART_BAUD_FRAC_Msk);
  203. UARTx->BAUD |= (((SystemCoreClock/baudrate - 1) / 16) << UART_BAUD_BAUD_Pos) |
  204. (((SystemCoreClock/baudrate - 1) % 16) << UART_BAUD_FRAC_Pos);
  205. }
  206. /******************************************************************************************************************************************
  207. * 函数名称: UART_GetBaudrate()
  208. * 功能说明: 查询波特率
  209. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  210. * 输 出: uint32_t 当前波特率
  211. * 注意事项: 无
  212. ******************************************************************************************************************************************/
  213. uint32_t UART_GetBaudrate(UART_TypeDef * UARTx)
  214. {
  215. return SystemCoreClock/(((UARTx->BAUD & UART_BAUD_BAUD_Msk) >> UART_BAUD_BAUD_Pos) * 16 +
  216. ((UARTx->BAUD & UART_BAUD_FRAC_Msk) >> UART_BAUD_FRAC_Pos) + 1);
  217. }
  218. /******************************************************************************************************************************************
  219. * 函数名称: UART_CTSConfig()
  220. * 功能说明: UART CTS流控配置
  221. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  222. * uint32_t enable 1 使能CTS流控 0 禁止CTS流控
  223. * uint32_t polarity 0 CTS输入为低表示可以发送数据 1 CTS输入为高表示可以发送数据
  224. * 输 出: 无
  225. * 注意事项: 无
  226. ******************************************************************************************************************************************/
  227. void UART_CTSConfig(UART_TypeDef * UARTx, uint32_t enable, uint32_t polarity)
  228. {
  229. UARTx->CTSCR &= ~(UART_CTSCR_EN_Msk | UART_CTSCR_POL_Msk);
  230. UARTx->CTSCR |= (enable << UART_CTSCR_EN_Pos) |
  231. (polarity << UART_CTSCR_POL_Pos);
  232. }
  233. /******************************************************************************************************************************************
  234. * 函数名称: UART_CTSLineState()
  235. * 功能说明: UART CTS线当前状态
  236. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  237. * 输 出: uint32_t 0 CTS线当前为低电平 1 CTS线当前为高电平
  238. * 注意事项: 无
  239. ******************************************************************************************************************************************/
  240. uint32_t UART_CTSLineState(UART_TypeDef * UARTx)
  241. {
  242. return (UARTx->CTSCR & UART_CTSCR_STAT_Msk) ? 1 : 0;
  243. }
  244. /******************************************************************************************************************************************
  245. * 函数名称: UART_RTSConfig()
  246. * 功能说明: UART RTS流控配置
  247. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  248. * uint32_t enable 1 使能RTS流控 0 禁止RTS流控
  249. * uint32_t polarity 0 RTS输出低表示可以接收数据 1 RTS输出高表示可以接收数据
  250. * uint32_t threshold RTS流控的触发阈值,可取值UART_RTS_1BYTE、UART_RTS_2BYTE、UART_RTS_4BYTE、UART_RTS_6BYTE
  251. * 输 出: 无
  252. * 注意事项: 无
  253. ******************************************************************************************************************************************/
  254. void UART_RTSConfig(UART_TypeDef * UARTx, uint32_t enable, uint32_t polarity, uint32_t threshold)
  255. {
  256. UARTx->RTSCR &= ~(UART_RTSCR_EN_Msk | UART_RTSCR_POL_Msk | UART_RTSCR_THR_Msk);
  257. UARTx->RTSCR |= (enable << UART_RTSCR_EN_Pos) |
  258. (polarity << UART_RTSCR_POL_Pos) |
  259. (threshold << UART_RTSCR_THR_Pos);
  260. }
  261. /******************************************************************************************************************************************
  262. * 函数名称: UART_RTSLineState()
  263. * 功能说明: UART RTS线当前状态
  264. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  265. * 输 出: uint32_t 0 RTS线当前为低电平 1 RTS线当前为高电平
  266. * 注意事项: 无
  267. ******************************************************************************************************************************************/
  268. uint32_t UART_RTSLineState(UART_TypeDef * UARTx)
  269. {
  270. return (UARTx->RTSCR & UART_RTSCR_STAT_Msk) ? 1 : 0;
  271. }
  272. /******************************************************************************************************************************************
  273. * 函数名称: UART_LINConfig()
  274. * 功能说明: UART LIN功能配置
  275. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  276. * uint32_t detectedLen 检测到Break需要的低电平长度(位数),取值1--16
  277. * uint32_t detectedIEn 检测到Break中断使能
  278. * uint32_t generatedLen Break发送低电平长度,取值1--15
  279. * uint32_t generatedIEn Break发送完成中断使能
  280. * 输 出: 无
  281. * 注意事项: 无
  282. ******************************************************************************************************************************************/
  283. void UART_LINConfig(UART_TypeDef * UARTx, uint32_t detectedLen, uint32_t detectedIEn, uint32_t generatedLen, uint32_t generatedIEn)
  284. {
  285. UARTx->CFG &= ~(UART_CFG_BRKTXLEN_Msk | UART_CFG_BRKRXLEN_Msk);
  286. UARTx->CFG |= ((detectedLen-1) << UART_CFG_BRKRXLEN_Pos) |
  287. (generatedLen << UART_CFG_BRKTXLEN_Pos);
  288. UARTx->LINCR &= ~(UART_LINCR_BRKDETIE_Msk | UART_LINCR_GENBRKIE_Msk);
  289. UARTx->LINCR |= (detectedIEn << UART_LINCR_BRKDETIE_Pos) |
  290. (generatedIEn << UART_LINCR_GENBRKIE_Pos);
  291. }
  292. /******************************************************************************************************************************************
  293. * 函数名称: UART_LINGenerate()
  294. * 功能说明: UART LIN产生/发送Break
  295. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  296. * 输 出: 无
  297. * 注意事项: 无
  298. ******************************************************************************************************************************************/
  299. void UART_LINGenerate(UART_TypeDef * UARTx)
  300. {
  301. UARTx->LINCR |= (1 << UART_LINCR_GENBRK_Pos);
  302. }
  303. /******************************************************************************************************************************************
  304. * 函数名称: UART_LINIsDetected()
  305. * 功能说明: UART LIN是否检测到Break
  306. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  307. * 输 出: uint32_t 1 检测到LIN Break 0 未检测到LIN Break
  308. * 注意事项: 无
  309. ******************************************************************************************************************************************/
  310. uint32_t UART_LINIsDetected(UART_TypeDef * UARTx)
  311. {
  312. return (UARTx->LINCR & UART_LINCR_BRKDETIF_Msk) ? 1 : 0;
  313. }
  314. /******************************************************************************************************************************************
  315. * 函数名称: UART_LINIsGenerated()
  316. * 功能说明: UART LIN Break是否发送完成
  317. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  318. * 输 出: uint32_t 1 LIN Break 发送完成 0 LIN Break发送未完成
  319. * 注意事项: 无
  320. ******************************************************************************************************************************************/
  321. uint32_t UART_LINIsGenerated(UART_TypeDef * UARTx)
  322. {
  323. return (UARTx->LINCR & UART_LINCR_GENBRKIF_Msk) ? 1 : 0;
  324. }
  325. /******************************************************************************************************************************************
  326. * 函数名称: UART_ABRStart()
  327. * 功能说明: UART 自动波特率检测开始
  328. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  329. * uint32_t detectChar 用于自动检测、计算波特率的检测字符
  330. * 8位数据时可取值:0xFF、0xFE、0xF8、0x80,分别表示发送方必须发送0xFF、0xFE、0xF8、0x80
  331. * 9位数据时可取值:0x1FF、0x1FE、0x1F8、0x180,分别表示发送方必须发送0x1FF、0x1FE、0x1F8、0x180
  332. * 输 出: 无
  333. * 注意事项: 自动波特率检测时不能开启奇偶校验
  334. ******************************************************************************************************************************************/
  335. void UART_ABRStart(UART_TypeDef * UARTx, uint32_t detectChar)
  336. {
  337. uint32_t bits = 0;
  338. if((detectChar == 0xFF) || (detectChar == 0x1FF)) bits = 0;
  339. else if((detectChar == 0xFE) || (detectChar == 0x1FE)) bits = 1;
  340. else if((detectChar == 0xF8) || (detectChar == 0x1F8)) bits = 2;
  341. else if((detectChar == 0x80) || (detectChar == 0x180)) bits = 3;
  342. else while(1);
  343. UARTx->BAUD &= ~(UART_BAUD_ABREN_Msk | UART_BAUD_ABRBIT_Msk);
  344. UARTx->BAUD |= (1 << UART_BAUD_ABREN_Pos) |
  345. (bits << UART_BAUD_ABRBIT_Pos);
  346. }
  347. /******************************************************************************************************************************************
  348. * 函数名称: UART_ABRIsDone()
  349. * 功能说明: UART 自动波特率是否完成
  350. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  351. * 输 出: uint32_t 0 未完成 UART_ABR_RES_OK 已完成,且成功 UART_ABR_RES_ERR 已完成,但失败、出错
  352. * 注意事项: 无
  353. ******************************************************************************************************************************************/
  354. uint32_t UART_ABRIsDone(UART_TypeDef * UARTx)
  355. {
  356. if(UARTx->BAUD & UART_BAUD_ABREN_Msk)
  357. {
  358. return 0;
  359. }
  360. else if(UARTx->BAUD & UART_BAUD_ABRERR_Msk)
  361. {
  362. return UART_ABR_RES_ERR;
  363. }
  364. else
  365. {
  366. return UART_ABR_RES_OK;
  367. }
  368. }
  369. /******************************************************************************************************************************************
  370. * 函数名称: UART_INTEn()
  371. * 功能说明: 中断使能
  372. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  373. * uint32_t it interrupt type,有效值有 UART_IT_RX_THR、UART_IT_RX_TOUT、UART_IT_TX_THR、UART_IT_TX_DONE 及其“或”
  374. * 输 出: 无
  375. * 注意事项: 无
  376. ******************************************************************************************************************************************/
  377. void UART_INTEn(UART_TypeDef * UARTx, uint32_t it)
  378. {
  379. UARTx->CTRL |= it;
  380. }
  381. /******************************************************************************************************************************************
  382. * 函数名称: UART_INTDis()
  383. * 功能说明: 中断禁止
  384. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  385. * uint32_t it interrupt type,有效值有 UART_IT_RX_THR、UART_IT_RX_TOUT、UART_IT_TX_THR、UART_IT_TX_DONE 及其“或”
  386. * 输 出: 无
  387. * 注意事项: 无
  388. ******************************************************************************************************************************************/
  389. void UART_INTDis(UART_TypeDef * UARTx, uint32_t it)
  390. {
  391. UARTx->CTRL &= ~it;
  392. }
  393. /******************************************************************************************************************************************
  394. * 函数名称: UART_INTClr()
  395. * 功能说明: 中断标志清除
  396. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  397. * uint32_t it interrupt type,有效值有 UART_IT_RX_TOUT
  398. * 输 出: 无
  399. * 注意事项: 无
  400. ******************************************************************************************************************************************/
  401. void UART_INTClr(UART_TypeDef * UARTx, uint32_t it)
  402. {
  403. if(it & UART_IT_RX_TOUT)
  404. UARTx->TOCR |= UART_TOCR_IFCLR_Msk;
  405. }
  406. /******************************************************************************************************************************************
  407. * 函数名称: UART_INTStat()
  408. * 功能说明: 中断状态查询
  409. * 输 入: UART_TypeDef * UARTx 指定要被设置的UART串口,有效值包括UART0、UART1、UART2、UART3
  410. * uint32_t it interrupt type,有效值有 UART_IT_RX_THR、UART_IT_RX_TOUT、UART_IT_TX_THR、UART_IT_TX_DONE 及其“或”
  411. * 输 出: uint32_t 1 中断已发生 0 中断未发生
  412. * 注意事项: 无
  413. ******************************************************************************************************************************************/
  414. uint32_t UART_INTStat(UART_TypeDef * UARTx, uint32_t it)
  415. {
  416. return (((it & UART_IT_RX_THR) && (UARTx->BAUD & UART_BAUD_RXIF_Msk)) ||
  417. ((it & UART_IT_RX_TOUT) && (UARTx->BAUD & UART_BAUD_TOIF_Msk)) ||
  418. ((it & UART_IT_TX_THR) && (UARTx->BAUD & UART_BAUD_TXIF_Msk)) ||
  419. ((it & UART_IT_TX_DONE) && (UARTx->BAUD & UART_BAUD_TXDOIF_Msk)));
  420. }