Serial.c 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967
  1. /*******************************************************************************************
  2. * File Name: Serial.c
  3. * Function Describe:device for serial
  4. * Relate Module:
  5. * Explain:
  6. 接收采用中断方式
  7. UART1: 连接尾插,用于与PC相连 另外,printf映射到UART1
  8. UART2: 连接GPS
  9. UART3: 连接Modem
  10. 全局变量g_ucUARTSel 调试选择控制,决定了3个串口的转发关系,其值通过以下3个宏控分别代表:
  11. COM_SEL_MCU 正常使用不转发,尾插用于MCU打印LOG或 MCU软件升级
  12. COM_SEL_GPS UART1<-->UART2,尾插用于GPS LOG打印
  13. COM_SEL_MODEM UART1<-->UART3,尾插用于MODEM AT momand 或模块软件升级
  14. * Writer: ShiLiangWen
  15. * Date: 2015.1.20
  16. ********************************************************************************************/
  17. #define THIS_FILE_ID 4
  18. /* Includes ------------------------------------------------------------------*/
  19. #include "includes.h"
  20. #define USART1_DR_Base 0x40013804
  21. #define USART2_DR_Base 0x40004404
  22. #define USART3_DR_Base (u32)&USART3->DR
  23. unsigned char g_ucUARTSel=0;//0--MCU 1--Modem 2--GPS
  24. unsigned char g_ucUART1RxMode=0;
  25. //UART1 Trace
  26. unsigned char RxBuffer1[UART1_RX_BUFFER_SIZE];
  27. unsigned char TxBuffer1[UART1_TX_BUFFER_SIZE];
  28. unsigned short rx1_ct;
  29. unsigned short g_usUart1RecvLen;
  30. unsigned char g_ucUart1Sending;
  31. //UART3 用于与GPS通讯
  32. unsigned char RxBuffer3[UART3_RX_BUFFER_SIZE];
  33. unsigned char TxBuffer3[UART3_TX_BUFFER_SIZE];
  34. static unsigned short rx3_ct;
  35. unsigned short g_usUart3RecvLen;
  36. //UART2 用于与MODEM通讯
  37. unsigned char RxBuffer2[UART2_RX_BUFFER_SIZE];
  38. unsigned char TxBuffer2[UART2_TX_BUFFER_SIZE];
  39. static unsigned short rx2_ct;
  40. unsigned short g_usRx2Len;
  41. unsigned short g_usRx2In;
  42. unsigned short g_usRx2Out;
  43. unsigned char g_ucUart2Sending;
  44. /********************************************************************
  45. *Uart1DMAInit
  46. *串口1 DMA设置
  47. *串口1 发送必须用通道4,接收必须用通道5
  48. *********************************************************************/
  49. void Uart1DMAInit(void)
  50. {
  51. NVIC_InitTypeDef NVIC_InitStructure;
  52. DMA_InitTypeDef DMA_InitStructure;
  53. //启动DMA时钟
  54. RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
  55. #if UART1_TX_USE_DMA!=0
  56. //DMA 通道4用于UART1 TX
  57. DMA_DeInit(DMA1_Channel4);
  58. DMA_InitStructure.DMA_PeripheralBaseAddr = (u32)(&USART1->DR);//外设地址
  59. DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)TxBuffer1;//内存地址
  60. DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralDST;//DMA传输方向单向
  61. DMA_InitStructure.DMA_BufferSize = UART1_TX_BUFFER_SIZE; //设置DMA在传输时缓冲区的长度
  62. DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; //设置DMA的外设递增模式
  63. DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable; //设置DMA的内存递增模式
  64. DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;//外设数据字长
  65. DMA_InitStructure.DMA_MemoryDataSize = DMA_PeripheralDataSize_Byte;//内存数据字长
  66. DMA_InitStructure.DMA_Mode = DMA_Mode_Normal; //设置DMA的传输模式
  67. DMA_InitStructure.DMA_Priority = DMA_Priority_Low; //设置DMA的优先级别
  68. DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;//设置DMA的2个memory中的变量互相访问
  69. DMA_Init(DMA1_Channel4,&DMA_InitStructure);
  70. // //DMA中断设置
  71. // NVIC_InitStructure.NVIC_IRQChannel = DMA1_Channel4_IRQn;
  72. // NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
  73. // NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
  74. // NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  75. // NVIC_Init(&NVIC_InitStructure);
  76. DMA_ITConfig(DMA1_Channel4,DMA_IT_TC,ENABLE);//中断设置
  77. DMA_Cmd(DMA1_Channel4, DISABLE); //等到需要发送的时候再使能
  78. #endif
  79. //DMA 通道5用于UART1 RX
  80. DMA_DeInit(DMA1_Channel5);
  81. DMA_InitStructure.DMA_PeripheralBaseAddr = (u32)(&USART1->DR);//外设地址
  82. DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)RxBuffer1;//内存地址
  83. DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;//DMA传输方向单向
  84. DMA_InitStructure.DMA_BufferSize = UART1_RX_BUFFER_SIZE; //设置DMA在传输时缓冲区的长度
  85. DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; //设置DMA的外设递增模式
  86. DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable; //设置DMA的内存递增模式
  87. DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;//外设数据字长
  88. DMA_InitStructure.DMA_MemoryDataSize = DMA_PeripheralDataSize_Byte;//内存数据字长
  89. DMA_InitStructure.DMA_Mode = DMA_Mode_Normal; //设置DMA的传输模式
  90. DMA_InitStructure.DMA_Priority = DMA_Priority_High; //设置DMA的优先级别
  91. DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;//设置DMA的2个memory中的变量互相访问
  92. DMA_Init(DMA1_Channel5,&DMA_InitStructure);
  93. //DMA_Cmd(DMA1_Channel5, ENABLE); //使能通道
  94. }
  95. /********************************************************************
  96. *Uart2DMAInit
  97. *串口2 DMA设置
  98. *串口2 发送必须用通道7,接收必须用通道6
  99. *********************************************************************/
  100. void Uart2DMAInit(void)
  101. {
  102. NVIC_InitTypeDef NVIC_InitStructure;
  103. DMA_InitTypeDef DMA_InitStructure;
  104. //启动DMA时钟
  105. RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
  106. #if UART2_TX_USE_DMA==1
  107. //DMA 通道2用于UART3 TX
  108. DMA_DeInit(DMA1_Channel7);
  109. DMA_InitStructure.DMA_PeripheralBaseAddr = (u32)(&USART2->DR);//外设地址
  110. DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)TxBuffer2;//内存地址
  111. DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralDST;//DMA传输方向单向
  112. DMA_InitStructure.DMA_BufferSize = UART3_TX_BUFFER_SIZE; //设置DMA在传输时缓冲区的长度
  113. DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; //设置DMA的外设递增模式
  114. DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable; //设置DMA的内存递增模式
  115. DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;//外设数据字长
  116. DMA_InitStructure.DMA_MemoryDataSize = DMA_PeripheralDataSize_Byte;//内存数据字长
  117. DMA_InitStructure.DMA_Mode = DMA_Mode_Normal; //设置DMA的传输模式
  118. DMA_InitStructure.DMA_Priority = DMA_Priority_High; //设置DMA的优先级别
  119. DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;//设置DMA的2个memory中的变量互相访问
  120. DMA_Init(DMA1_Channel7,&DMA_InitStructure);
  121. DMA_ITConfig(DMA1_Channel7,DMA_IT_TC,ENABLE);//中断设置
  122. #else
  123. DMA_ITConfig(DMA1_Channel7,DMA_IT_TC,DISABLE);
  124. #endif
  125. DMA_Cmd(DMA1_Channel7, DISABLE);
  126. //DMA 通道3用于UART3 RX
  127. DMA_DeInit(DMA1_Channel6);
  128. DMA_InitStructure.DMA_PeripheralBaseAddr = (u32)(&USART2->DR);//外设地址
  129. DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)RxBuffer2;//内存地址
  130. DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;//DMA传输方向单向
  131. DMA_InitStructure.DMA_BufferSize = UART3_RX_BUFFER_SIZE; //设置DMA在传输时缓冲区的长度
  132. DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; //设置DMA的外设递增模式
  133. DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable; //设置DMA的内存递增模式
  134. DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;//外设数据字长
  135. DMA_InitStructure.DMA_MemoryDataSize = DMA_PeripheralDataSize_Byte;//内存数据字长
  136. DMA_InitStructure.DMA_Mode = DMA_Mode_Normal; //设置DMA的传输模式
  137. DMA_InitStructure.DMA_Priority = DMA_Priority_VeryHigh; //设置DMA的优先级别
  138. DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;//设置DMA的2个memory中的变量互相访问
  139. DMA_Init(DMA1_Channel6,&DMA_InitStructure);
  140. DMA_Cmd(DMA1_Channel6, DISABLE); //使能通道
  141. }
  142. /*********************************************************************************************
  143. *UART2RxTxISRHandler
  144. *串口2中断处理函数
  145. **********************************************************************************************/
  146. void UART2RxTxISRHandler(void)
  147. {
  148. __IO unsigned char uart_data;
  149. //----接收中断--------
  150. if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET)
  151. {
  152. uart_data = USART_ReceiveData(USART2); // Read one byte from the receive data register
  153. //Modem Trace
  154. if(g_ucUARTSel==COM_SEL_MODEM){
  155. USART_SendData(USART1, uart_data);
  156. USART_ClearITPendingBit(USART2, USART_IT_RXNE); //清除中断标志
  157. return;
  158. }
  159. //MCU 处理Modem
  160. if(g_usRx2Len<UART2_RX_BUFFER_SIZE){
  161. RxBuffer2[g_usRx2In]=uart_data;
  162. if(++g_usRx2In>=UART2_RX_BUFFER_SIZE)g_usRx2In=0;
  163. g_usRx2Len++;
  164. }
  165. isr_sem_send(&ModemUartSem);
  166. USART_ClearITPendingBit(USART2, USART_IT_RXNE); //清除中断标志
  167. }
  168. if(USART_GetFlagStatus(USART2,USART_FLAG_ORE)==SET)
  169. {
  170. USART_ReceiveData(USART2); //
  171. USART_ClearFlag(USART2,USART_FLAG_ORE); //
  172. }
  173. }
  174. /**********************************************************************
  175. +CSQ:1/r/n 最少8字节
  176. +POC:83000
  177. +ZIPRECV:
  178. +ZIPRECVU:
  179. +ZIPSTATUS:
  180. ************************************************************************/
  181. void Uart2RecvProcess(void)
  182. {
  183. unsigned short Rx2Len;
  184. unsigned short out;
  185. char preData[20];
  186. unsigned short i,j,len;
  187. char num[5];
  188. char data,flag;
  189. //少于8字节不处理
  190. if(g_usRx2Len<8)return;
  191. //缓冲区满,清空缓冲区
  192. if(g_usRx2Len>(UART2_RX_BUFFER_SIZE-2)){
  193. USART_ITConfig(USART2, USART_IT_RXNE, DISABLE);
  194. g_usRx2In=0;
  195. g_usRx2Len=0;
  196. g_usRx2Out=0;
  197. USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);
  198. SlwTrace(DEBUG,"[Rx2Buf Over]",1);
  199. return;
  200. }
  201. //锁定环形缓冲区当前状态,
  202. Rx2Len=g_usRx2Len;
  203. // USART_ITConfig(USART2, USART_IT_RXNE, DISABLE);
  204. // g_usRx2Len=g_usRx2Len-i;
  205. // USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);
  206. //少于8字节不处理
  207. if(Rx2Len<4)return;
  208. //预读取前n字节 n最少4,最大16 为后续处理提供条件
  209. if(Rx2Len<16)len=Rx2Len;
  210. else len=16;
  211. out=g_usRx2Out;
  212. for(i=0;i<len;i++){
  213. preData[i]=RxBuffer2[out];
  214. if(++out>UART2_RX_BUFFER_SIZE)out=0;
  215. }
  216. RunMake(THIS_FILE_ID);
  217. //判断是否为OK
  218. //判断前8字节是否等于"+TCPRECV",如果等于则特殊处理,如果不等则找到"/r/n"作为结束符
  219. if(0!=ModemStrCmp(preData,"+TCPRECV"))
  220. {
  221. //非"+TCPRECV",则直接找到最近的0x0A作为结束符,读取并形成一包消息
  222. out=g_usRx2Out;
  223. for(i=0;i<Rx2Len;i++)
  224. {
  225. if(RxBuffer2[out]==0x0A)break;
  226. if(++out>=UART2_RX_BUFFER_SIZE)out=0;
  227. }
  228. //123/n/0
  229. if(i<Rx2Len)
  230. {//找到了0x0A,从环形缓冲区中读取数据并拷贝到消息缓冲区,发送消息
  231. len=i+1;//消息长度
  232. RunMake(THIS_FILE_ID);
  233. if(len<(MODEM_AT_MSG_DATA_LEN-2))
  234. {
  235. sutAtm.MsgLen=len;
  236. for(i=0;i<len;i++)
  237. {
  238. sutAtm.MsgData[i]=RxBuffer2[g_usRx2Out];
  239. if(++g_usRx2Out>=UART2_RX_BUFFER_SIZE)g_usRx2Out=0;
  240. }
  241. sutAtm.MsgData[i]=0;//消息最后补0作为结束符,方便打印
  242. //更新g_usRx3Len,需要防止中断修改冲突
  243. USART_ITConfig(USART2, USART_IT_RXNE, DISABLE); //DISABLE UART3 RX IT
  244. g_usRx2Len=g_usRx2Len-len;
  245. USART_ITConfig(USART2, USART_IT_RXNE, ENABLE); //ENABLE UART3 RX IT
  246. RunMake(THIS_FILE_ID);
  247. //发送消息
  248. sutAtm.MsgLen+=1;
  249. if(0 != MsgQueuePost(sutAtm.MsgData,sutAtm.MsgLen)) SlwTrace(INF, "MQueue Full1",1);
  250. return;
  251. }else
  252. {//消息队列的内存块长度不够,需要特殊处理,扔掉后面部分
  253. sutAtm.MsgLen=len;
  254. for(i=0;i<len;i++)
  255. {
  256. data=RxBuffer2[g_usRx2Out];
  257. if(i<(MODEM_AT_MSG_DATA_LEN-2))sutAtm.MsgData[i]=data;
  258. if(++g_usRx2Out>=UART2_RX_BUFFER_SIZE)g_usRx2Out=0;
  259. }
  260. sutAtm.MsgData[MODEM_AT_MSG_DATA_LEN-1]=0;//消息最后补0作为结束符
  261. //更新g_usRx3Len,需要防止中断修改冲突
  262. USART_ITConfig(USART2, USART_IT_RXNE, DISABLE); //DISABLE UART2 RX IT
  263. g_usRx2Len=g_usRx2Len-len;
  264. USART_ITConfig(USART2, USART_IT_RXNE, ENABLE); //ENABLE UART2 RX IT
  265. RunMake(THIS_FILE_ID);
  266. //发送消息
  267. if(0 != MsgQueuePost(sutAtm.MsgData,sutAtm.MsgLen)) SlwTrace(INF, "MQueue Full2",1);
  268. return;
  269. }
  270. }
  271. return;
  272. }
  273. //+TCPRECV:1,24,12
  274. if(Rx2Len<16)return;//最少16字节“+TCPRECV:0,1,d\r\n”
  275. out=g_usRx2Out;
  276. flag=0;//找到','的标志
  277. j=0;//用来存储xxx的下标,xxx范围"1" -> "9999"
  278. for(i=0;i<Rx2Len;i++){
  279. data=RxBuffer2[out];
  280. if(','==data){
  281. if(flag<1)flag++;
  282. else break;
  283. }else if(flag==1 && j<4){
  284. num[j++]=data;
  285. }
  286. if(++out>=UART2_RX_BUFFER_SIZE)out=0;
  287. }
  288. if(i>=Rx2Len){//未找到了2个','则直接忽略
  289. //SlwTrace(DEBUG,"<2<\r\n");
  290. return;
  291. }
  292. RunMake(THIS_FILE_ID);
  293. //找到了2个',' 计算xxx长度
  294. num[j]=0;
  295. len=atoi(num);
  296. if(len<10)j=1;
  297. else if(len<100)j=2;
  298. else if(len<1000)j=3;
  299. else j=4;
  300. len=len+j+14;
  301. if(Rx2Len<len){
  302. return;//长度不够,忽略
  303. }
  304. //长度够,产生消息
  305. if(len<(MODEM_AT_MSG_DATA_LEN-2)){
  306. sutAtm.MsgLen=len;
  307. for(i=0;i<len;i++){
  308. sutAtm.MsgData[i]=RxBuffer2[g_usRx2Out];
  309. if(++g_usRx2Out>=UART2_RX_BUFFER_SIZE)g_usRx2Out=0;
  310. }
  311. sutAtm.MsgData[i]=0;//消息最后补0作为结束符,方便打印
  312. //更新g_usRx3Len,需要防止中断修改冲突
  313. USART_ITConfig(USART2, USART_IT_RXNE, DISABLE); //DISABLE UART3 RX IT
  314. g_usRx2Len=g_usRx2Len-len;
  315. USART_ITConfig(USART2, USART_IT_RXNE, ENABLE); //ENABLE UART3 RX IT
  316. //发送消息
  317. sutAtm.MsgLen +=1;
  318. if(0 != MsgQueuePost(sutAtm.MsgData,sutAtm.MsgLen)) SlwTrace(INF, "MQueue Full3",1);
  319. }else{
  320. snprintf(preData, sizeof(preData),"AtMsgBuf Over [%u]",i);
  321. SlwTrace(DEBUG,preData,1);
  322. return;
  323. }
  324. RunMake(THIS_FILE_ID);
  325. }
  326. /********************************************************************************
  327. *Uart1Send
  328. *串口1启动发送
  329. *********************************************************************************/
  330. /*
  331. void Uart1Send(char *txbuf,int len)
  332. {
  333. int i;
  334. unsigned char data;
  335. unsigned char last_data=~UART_TRANSFORM;
  336. //Send Head
  337. USART_SendData(USART1, UART_HEAD);
  338. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  339. for(i=0;i<len;i++){
  340. data= txbuf[i];
  341. if(UART_TRANSFORM == data){
  342. USART_SendData(USART1,UART_TRANSFORM );
  343. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  344. USART_SendData(USART1,0x01 );
  345. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  346. }else if(UART_HEAD == data){
  347. USART_SendData(USART1,UART_TRANSFORM);
  348. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  349. USART_SendData(USART1,0x02 );
  350. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  351. }else if(UART_END == data){
  352. USART_SendData(USART1,UART_TRANSFORM);
  353. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  354. USART_SendData(USART1,0x03 );
  355. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  356. }else{
  357. USART_SendData(USART1,data);
  358. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  359. }
  360. }
  361. //Send End
  362. USART_SendData(USART1, UART_END);
  363. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  364. }
  365. */
  366. void Uart1Send(char *txbuf,int len)
  367. {
  368. int i;
  369. for(i=0;i<len;i++){
  370. USART_SendData(USART1,txbuf[i]);
  371. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  372. }
  373. }
  374. void Uart2Send(unsigned char *txbuf,unsigned short len)
  375. {
  376. int i;
  377. for(i=0;i<len;i++){
  378. USART_SendData(USART2,txbuf[i]);
  379. while (USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET);
  380. }
  381. }
  382. /*************************************************************************************
  383. * 函数名:USART1_Send
  384. * 描述 :串口1发送数据函数 通过DMA实现
  385. * 输入 :要发送数据的首地址,发送数据的个数。发送数据的地址任意,并不用固定为Txd1Buffer
  386. * 输出 : 无
  387. * 举例 :Usart1_Send("Hello word!",11); Usart1_Send(Txd1Buffer,11);
  388. **************************************************************************************/
  389. void USART1_Send(char *pbuffer, unsigned short size)
  390. {
  391. #if UART1_TX_USE_DMA==1
  392. char buf[20];
  393. unsigned short i;
  394. unsigned short len;
  395. char *pData;
  396. if(size==0)return;
  397. //等待上一次发送完成
  398. while(g_ucUart1Sending!=0){
  399. os_dly_wait(1);
  400. }
  401. #if 0 //增加时间戳
  402. sprintf((char *)TxBuffer1,"%010u: ",os_time_get());
  403. if(size>(UART1_TX_BUFFER_SIZE-12))len=UART1_TX_BUFFER_SIZE-12;
  404. else len=size;
  405. len+=12;
  406. pData=(char *)&TxBuffer1[12];
  407. #else
  408. if(size>UART1_TX_BUFFER_SIZE)len=UART1_TX_BUFFER_SIZE;
  409. else len=size;
  410. pData=(char *)&TxBuffer1[0];
  411. #endif
  412. for(i=0;i<len;i++)pData[i]=pbuffer[i];
  413. DMA_Cmd (DMA1_Channel4,DISABLE);
  414. DMA1_Channel4->CMAR = (u32)TxBuffer1;
  415. DMA1_Channel4->CNDTR = len;
  416. g_ucUart1Sending=1;
  417. DMA_Cmd (DMA1_Channel4,ENABLE); //使能DMA,开始发送 //数据发送中 //灯亮
  418. #endif
  419. }
  420. void USART1_SendNew(char *pbuffer, unsigned short size,char needEnd)
  421. {
  422. #if UART1_TX_USE_DMA==1
  423. char buf[20];
  424. unsigned short i;
  425. unsigned short len;
  426. char *pData;
  427. if(size==0)return;
  428. //等待上一次发送完成
  429. while(g_ucUart1Sending!=0){
  430. os_dly_wait(1);
  431. }
  432. if(size>UART1_TX_BUFFER_SIZE)len=UART1_TX_BUFFER_SIZE;
  433. else len=size;
  434. pData=(char *)&TxBuffer1[0];
  435. for(i=0;i<len;i++)pData[i]=pbuffer[i];
  436. ///////////////////////////////
  437. if(0 != needEnd)
  438. {
  439. if(len <= (UART1_TX_BUFFER_SIZE-2))
  440. {
  441. pData[len++] = '\r';
  442. pData[len++] = '\n';
  443. }
  444. }
  445. ///////////////////////////////
  446. DMA_Cmd (DMA1_Channel4,DISABLE);
  447. DMA1_Channel4->CMAR = (u32)TxBuffer1;
  448. DMA1_Channel4->CNDTR = len;
  449. g_ucUart1Sending=1;
  450. DMA_Cmd (DMA1_Channel4,ENABLE);
  451. #endif
  452. }
  453. void USART1_SendWaitCompleted(void)
  454. {
  455. #if UART1_TX_USE_DMA==1
  456. while(g_ucUart1Sending!=0){
  457. os_dly_wait(1);
  458. }
  459. #endif
  460. }
  461. /*************************************************************************************
  462. * 函数名:USART2_Send
  463. * 描述 :串口1发送数据函数 通过DMA实现
  464. * 输入 :要发送数据的首地址,发送数据的个数。发送数据的地址任意,并不用固定为Txd1Buffer
  465. * 输出 : 无
  466. * 举例 :Usart3_Send("Hello word!",11); Usart3_Send(Txd3Buffer,11);
  467. **************************************************************************************/
  468. void USART2_Send(char *pbuffer, unsigned short size)
  469. {
  470. #if UART2_TX_USE_DMA==1
  471. unsigned short i;
  472. if(size==0 || size>UART2_TX_BUFFER_SIZE)return;
  473. //等待上一次发送完成
  474. while(g_ucUart2Sending!=0){
  475. os_dly_wait(1);
  476. }
  477. for(i=0;i<size;i++){
  478. TxBuffer2[i]=pbuffer[i];
  479. }
  480. DMA_Cmd (DMA1_Channel7,DISABLE);
  481. DMA1_Channel7->CMAR = (u32)TxBuffer2;
  482. DMA1_Channel7->CNDTR = size;
  483. g_ucUart2Sending=1;
  484. DMA_Cmd (DMA1_Channel7,ENABLE); //使能DMA,开始发送 //数据发送中 //灯亮
  485. #endif
  486. }
  487. void USART3_SendWaitCompleted(void)
  488. {
  489. #if UART3_TX_USE_DMA==1
  490. while(g_ucUart3Sending!=0){
  491. os_dly_wait(1);
  492. }
  493. #endif
  494. }
  495. /*********************************************************************************************
  496. *UART1RxTxISRHandler
  497. *串口1中断处理函数
  498. **********************************************************************************************/
  499. void UART1RxTxISRHandler(void)
  500. {
  501. __IO unsigned char uart_data;
  502. __IO static unsigned char uart_last_data=0;
  503. char *p;
  504. unsigned char i;
  505. uint32_t temp = 0;
  506. //----接收中断--------
  507. if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)
  508. {
  509. uart_data = USART_ReceiveData(USART1);
  510. USART_ClearITPendingBit(USART1, USART_IT_RXNE); //清除中断标志
  511. if(g_ucUARTSel==COM_SEL_MODEM){//Modem Trace
  512. USART_SendData(USART2, uart_data);
  513. }else if(g_ucUARTSel==COM_SEL_GPS){//GPS Trace
  514. USART_SendData(USART3, uart_data);
  515. }else if(g_ucUARTSel==COM_SEL_MCU){
  516. // USART_SendData(USART1, uart_data);
  517. if(g_usUart1RecvLen!=0){//上一包数据未处理完,不处理新来的数据,直接扔掉!
  518. rx1_ct=0;
  519. RxBuffer1[0]=0;
  520. return;
  521. }
  522. RxBuffer1[rx1_ct++]=uart_data;
  523. if(uart_last_data==0x0d &&uart_data==0x0a){
  524. if(RxBuffer1[0]=='G' && RxBuffer1[1]=='T'){
  525. g_usUart1RecvLen=rx1_ct;
  526. RxBuffer1[rx1_ct]=0;
  527. }else{
  528. rx1_ct=0;
  529. RxBuffer1[0]=0;
  530. }
  531. }
  532. if(rx1_ct>=(UART1_RX_BUFFER_SIZE-1)){//数据超过缓冲区的数据,过滤不处理
  533. rx1_ct=0;
  534. g_usUart1RecvLen=0;
  535. }
  536. }
  537. }
  538. uart_last_data=uart_data;
  539. // //---异常中断---
  540. if(USART_GetFlagStatus(USART1,USART_FLAG_ORE)==SET)
  541. {
  542. USART_ReceiveData(USART1); //
  543. USART_ClearFlag(USART1,USART_FLAG_ORE); //
  544. }
  545. }
  546. /*******************************************************************************
  547. Uart1Init
  548. Use for Trace
  549. *******************************************************************************/
  550. void Uart1Init(void)
  551. {
  552. NVIC_InitTypeDef NVIC_InitStructure;
  553. GPIO_InitTypeDef GPIO_InitStructure;
  554. USART_InitTypeDef USART_InitStructure;
  555. RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOA | RCC_APB2Periph_USART1,ENABLE);
  556. /*
  557. * USART1_TX -> PA9 , USART1_RX -> PA10
  558. */
  559. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
  560. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  561. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  562. GPIO_Init(GPIOA, &GPIO_InitStructure);
  563. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
  564. GPIO_InitStructure.GPIO_Mode =GPIO_Mode_IN_FLOATING;// GPIO_Mode_IPU;//GPIO_Mode_IN_FLOATING;
  565. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  566. GPIO_Init(GPIOA, &GPIO_InitStructure);
  567. USART_InitStructure.USART_BaudRate =115200;// 115200;
  568. USART_InitStructure.USART_WordLength = USART_WordLength_8b;
  569. USART_InitStructure.USART_StopBits = USART_StopBits_1;
  570. USART_InitStructure.USART_Parity = USART_Parity_No;
  571. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  572. USART_InitStructure.USART_Mode = USART_Mode_Tx;//USART_Mode_Rx |
  573. USART_Init(USART1, &USART_InitStructure);
  574. USART_Cmd(USART1, ENABLE);
  575. USART_ClearFlag(USART1,USART_FLAG_TC);
  576. USART_ITConfig(USART1, USART_IT_TXE, DISABLE); //ENABLE DISABLE
  577. USART_ITConfig(USART1, USART_IT_RXNE, DISABLE); //ENABLE//DISABLE
  578. }
  579. void Uart1RxEnable(int en)
  580. {
  581. static unsigned char sucEn=0;
  582. USART_InitTypeDef USART_InitStructure;
  583. if(sucEn!=en)sucEn=en;
  584. else return;
  585. if(en){
  586. USART_InitStructure.USART_BaudRate =115200;// 115200;
  587. USART_InitStructure.USART_WordLength = USART_WordLength_8b;
  588. USART_InitStructure.USART_StopBits = USART_StopBits_1;
  589. USART_InitStructure.USART_Parity = USART_Parity_No;
  590. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  591. USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;//
  592. USART_Init(USART1, &USART_InitStructure);
  593. USART_Cmd(USART1, ENABLE);
  594. USART_ITConfig(USART1, USART_IT_RXNE, ENABLE); //USART_IT_IDLE USART_IT_RXNE
  595. }else{
  596. USART_InitStructure.USART_BaudRate =115200;// 115200;
  597. USART_InitStructure.USART_WordLength = USART_WordLength_8b;
  598. USART_InitStructure.USART_StopBits = USART_StopBits_1;
  599. USART_InitStructure.USART_Parity = USART_Parity_No;
  600. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  601. USART_InitStructure.USART_Mode = USART_Mode_Tx;//
  602. USART_Init(USART1, &USART_InitStructure);
  603. USART_Cmd(USART1, ENABLE);
  604. }
  605. }
  606. /***************************************************************************
  607. Uart2Init
  608. Use for MainBoard
  609. ****************************************************************************/
  610. void Uart2Init(void)
  611. {
  612. GPIO_InitTypeDef GPIO_InitStructure;
  613. USART_InitTypeDef USART_InitStructure;
  614. /*使能串口2使用的GPIO时钟*/
  615. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
  616. /*使能串口2时钟*/
  617. RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE);
  618. /*串口2 RX管脚配置*/
  619. /* Configure USART2 Rx as input floating */
  620. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;
  621. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;
  622. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  623. GPIO_Init(GPIOA, &GPIO_InitStructure);
  624. /*串口2 TX管脚配置*/
  625. /* Configure USART2 Tx as alternate function push-pull */
  626. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
  627. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  628. GPIO_Init(GPIOA, &GPIO_InitStructure);
  629. USART_InitStructure.USART_BaudRate = 115200;
  630. USART_InitStructure.USART_WordLength = USART_WordLength_8b;
  631. USART_InitStructure.USART_StopBits = USART_StopBits_1;
  632. USART_InitStructure.USART_Parity = USART_Parity_No;
  633. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  634. USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
  635. USART_Init(USART2, &USART_InitStructure);
  636. USART_ClearFlag(USART2,USART_FLAG_TC);
  637. USART_ITConfig(USART2, USART_IT_TXE, DISABLE); //ENABLE DISABLE
  638. USART_ITConfig(USART2, USART_IT_RXNE, ENABLE); //ENABLE DISABLE
  639. USART_ITConfig(USART2, USART_IT_IDLE, DISABLE);//USART_IT_IDLE USART_IT_RXNE
  640. USART_ITConfig(USART2, USART_IT_PE, ENABLE);
  641. USART_ITConfig(USART2, USART_IT_ERR, ENABLE);
  642. USART_Cmd(USART2, ENABLE);
  643. Uart2DMAInit();
  644. #if UART2_TX_USE_DMA==1
  645. USART_DMACmd(USART2,USART_DMAReq_Tx,ENABLE); //使能USART3 TX 的DMA请求
  646. #endif
  647. USART_DMACmd(USART2,USART_DMAReq_Rx,ENABLE);
  648. rx2_ct=0;
  649. g_usRx2Len=0;
  650. g_usRx2In=0;
  651. g_usRx2Out=0;
  652. g_ucUart2Sending=0;
  653. memset(RxBuffer2,0,sizeof(RxBuffer2));
  654. }
  655. void UART3RxTxISRHandler(void)
  656. {
  657. //uint32_t temp = 0;
  658. uint16_t i = 0;
  659. //char *p;
  660. //char *msg;
  661. __IO unsigned char uart_data;
  662. __IO static unsigned char uart_last_data=0;
  663. if(USART_GetITStatus(USART3, USART_IT_RXNE) != RESET){
  664. uart_data = USART_ReceiveData(USART3);
  665. if(g_ucUARTSel==COM_SEL_GPS){
  666. USART_SendData(USART1, uart_data);
  667. }else if(0==g_usUart3RecvLen){
  668. RxBuffer3[rx3_ct]= uart_data;
  669. if(RxBuffer3[0]!='$')rx3_ct=0;
  670. else rx3_ct++;
  671. if(rx3_ct>=(UART3_RX_BUFFER_SIZE-1))rx3_ct=0;
  672. if(uart_last_data==0x0d && uart_data==0x0a){ //收到回车换行符
  673. if((RxBuffer3[1]=='G' && RxBuffer3[3]=='R' && RxBuffer3[5]=='C')||(RxBuffer3[1]=='G' && RxBuffer3[4]=='G' && RxBuffer3[5]=='A')){//$GPRMC
  674. //Send message
  675. // SlwTrace(DEBUG,"GPRMCisg_usUart2RecvLen=rx2_ct?Send message?!\r\n");
  676. RxBuffer3[rx3_ct-1]=0;
  677. g_usUart3RecvLen=rx3_ct;
  678. }else{
  679. rx3_ct=0;
  680. }
  681. }
  682. }else{
  683. rx3_ct=0;
  684. }
  685. USART_ClearITPendingBit(USART3, USART_IT_RXNE); //Clean interrupt flag
  686. uart_last_data=uart_data;
  687. }
  688. if(USART_GetFlagStatus(USART3,USART_FLAG_ORE)==SET)
  689. {
  690. USART_ReceiveData(USART3); //
  691. USART_ClearFlag(USART3,USART_FLAG_ORE); //
  692. }
  693. }
  694. /***************************************************************************
  695. Uart3Init
  696. ****************************************************************************/
  697. void Uart3Init(void)
  698. {
  699. GPIO_InitTypeDef GPIO_InitStructure;
  700. USART_InitTypeDef USART_InitStructure;
  701. /*使能串口3使用的GPIO时钟*/
  702. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
  703. /*使能串口3时钟*/
  704. RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3, ENABLE);
  705. /*串口3 RX管脚配置*/
  706. /* Configure USART3 Rx as input floating */
  707. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;
  708. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;
  709. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  710. GPIO_Init(GPIOB, &GPIO_InitStructure);
  711. /*串口3 TX管脚配置*/
  712. /* Configure USART2 Tx as alternate function push-pull */
  713. // GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
  714. // GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;//GPIO_Mode_AF_PP;
  715. // GPIO_Init(GPIOB, &GPIO_InitStructure);
  716. USART_InitStructure.USART_BaudRate = 9600;
  717. USART_InitStructure.USART_WordLength = USART_WordLength_8b;
  718. USART_InitStructure.USART_StopBits = USART_StopBits_1;
  719. USART_InitStructure.USART_Parity = USART_Parity_No;;
  720. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  721. USART_InitStructure.USART_Mode = USART_Mode_Rx;
  722. USART_Init(USART3, &USART_InitStructure);
  723. USART_ClearFlag(USART3,USART_FLAG_TC);
  724. USART_ITConfig(USART3, USART_IT_TXE, DISABLE); //ENABLE DISABLE
  725. USART_ITConfig(USART3, USART_IT_RXNE, ENABLE); //ENABLE DISABLE
  726. USART_ITConfig(USART3, USART_IT_IDLE, DISABLE);//USART_IT_IDLE USART_IT_RXNE
  727. USART_Cmd(USART3, ENABLE);
  728. rx3_ct=0;
  729. g_usUart3RecvLen=0;
  730. memset(RxBuffer3, 0, sizeof(RxBuffer3));
  731. }
  732. /***********************************************************************************
  733. *
  734. ************************************************************************************/
  735. void SlwTrace(TRACE_TYPE type,char *buf,char needEnd)
  736. {
  737. int len;
  738. char endbady[3]={13,10,0};
  739. #ifndef SLW_DEBUG
  740. if(type==DEBUG)return;
  741. #endif
  742. if(g_ucUARTSel!=COM_SEL_MCU)return;
  743. #if UART1_TX_USE_DMA==0
  744. len=strlen(buf);
  745. Uart1Send(buf,len);
  746. if(needEnd)Uart1Send(endbady,strlen(endbady));
  747. #else
  748. len=strlen(buf);
  749. if(len>UART1_TX_BUFFER_SIZE)len=UART1_TX_BUFFER_SIZE;
  750. //USART1_Send(buf,len);
  751. USART1_SendNew(buf,len,needEnd);
  752. #endif
  753. }
  754. /*******************************************************************************
  755. ComSelect
  756. 调试口选择
  757. #define COM_SEL_MCU 0
  758. #define COM_SEL_GPS 1
  759. #define COM_SEL_MODEM 2
  760. *******************************************************************************/
  761. void ComSelect(unsigned char sel)
  762. {
  763. switch(sel)
  764. {
  765. case COM_SEL_MCU:
  766. SlwTrace(INF,"COM<-->MCU!",1);
  767. os_dly_wait(10);
  768. g_ucUARTSel=sel;
  769. USART_ITConfig(USART1, USART_IT_RXNE, DISABLE); //ENABLE DISABLE
  770. USART_ITConfig(USART1, USART_IT_IDLE, ENABLE); //USART_IT_IDLE USART_IT_RXNE
  771. USART_ITConfig(USART2, USART_IT_RXNE, DISABLE); //ENABLE DISABLE
  772. USART_ITConfig(USART2, USART_IT_IDLE, ENABLE); //USART_IT_IDLE USART_IT_RXNE
  773. break;
  774. case COM_SEL_GPS:
  775. SlwTrace(INF,"COM<-->GPS!",1);
  776. os_dly_wait(10);
  777. g_ucUARTSel=sel;
  778. USART_ITConfig(USART1, USART_IT_RXNE, ENABLE); //ENABLE DISABLE
  779. USART_ITConfig(USART1, USART_IT_IDLE, DISABLE); //USART_IT_IDLE USART_IT_RXNE
  780. USART_ITConfig(USART3, USART_IT_RXNE, ENABLE); //ENABLE DISABLE
  781. USART_ITConfig(USART3, USART_IT_IDLE, DISABLE); //USART_IT_IDLE USART_IT_RXNE
  782. break;
  783. case COM_SEL_MODEM:
  784. SlwTrace(INF,"COM<-->Modem!",1);
  785. os_dly_wait(10);
  786. g_ucUARTSel=sel;
  787. USART_ITConfig(USART1, USART_IT_RXNE, ENABLE); //ENABLE DISABLE
  788. USART_ITConfig(USART1, USART_IT_IDLE, DISABLE); //USART_IT_IDLE USART_IT_RXNE
  789. USART_ITConfig(USART2, USART_IT_RXNE, ENABLE); //ENABLE DISABLE
  790. USART_ITConfig(USART2, USART_IT_IDLE, DISABLE); //USART_IT_IDLE USART_IT_RXNE
  791. break;
  792. }
  793. }
  794. /**************************************************************************
  795. * USART1_SendOK_IQ
  796. * 串口1发送数据完毕后,会调用的中断函数,将发送标志置0
  797. * 此函数需在stm32f10x_it.c 的 DMA1_Channel4_IRQHandler()中被调用
  798. ***************************************************************************/
  799. void USART1_SendOK_IQ(void)
  800. {
  801. //判断是否为DMA发送完成中断
  802. if(DMA_GetFlagStatus(DMA1_FLAG_TC4)==SET)
  803. {
  804. DMA_ClearITPendingBit(DMA1_IT_GL4);
  805. DMA_ClearFlag(DMA1_FLAG_TC4);
  806. DMA_Cmd (DMA1_Channel4,DISABLE);
  807. g_ucUart1Sending = 0; //数据发送完毕
  808. }
  809. //printf("USART1_SendOK_IQ\r\n");
  810. }
  811. /**************************************************************************
  812. * USART2_SendOK_IQ
  813. * 串口3发送数据完毕后,会调用的中断函数,将发送标志置0
  814. * 此函数需在stm32f10x_it.c 的 DMA1_Channel2_IRQHandler()中被调用
  815. ***************************************************************************/
  816. void USART2_SendOK_IQ(void)
  817. {
  818. //判断是否为DMA发送完成中断
  819. if(DMA_GetFlagStatus(DMA1_FLAG_TC7)==SET)
  820. {
  821. DMA_ClearITPendingBit(DMA1_IT_GL7);
  822. DMA_ClearFlag(DMA1_FLAG_TC7);
  823. DMA_Cmd (DMA1_Channel7,DISABLE);
  824. g_ucUart2Sending = 0; //数据发送完毕
  825. }
  826. //printf("USART3_SendOK_IQ\r\n");
  827. }
  828. #ifdef __GNUC__
  829. /* With GCC/RAISONANCE, small printf (option LD Linker->Libraries->Small printf
  830. set to 'Yes') calls __io_putchar() */
  831. #define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
  832. #else
  833. #define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
  834. #endif /* __GNUC__ */
  835. /**
  836. * @brief Retargets the C library printf function to the USART.
  837. * @param None
  838. * @retval None
  839. */
  840. PUTCHAR_PROTOTYPE
  841. {
  842. /* Place your implementation of fputc here */
  843. /* e.g. write a character to the USART */
  844. USART_SendData(USART1, (uint8_t) ch);
  845. /* Loop until the end of transmission */
  846. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET)
  847. {
  848. }
  849. return ch;
  850. }
  851. void RTCAlarm_IRQHandler(void)
  852. {
  853. if(RTC_GetITStatus(RTC_IT_ALR) != RESET)
  854. {
  855. /* Set the RTC alarm flag */
  856. g_bRTCAlarm = 1;
  857. /* Clear EXTI line17 pending bit */
  858. EXTI_ClearITPendingBit(EXTI_Line17);
  859. /* Check if the Wake-Up flag is set */
  860. if(PWR_GetFlagStatus(PWR_FLAG_WU) != RESET)
  861. {
  862. /* Clear Wake Up flag */
  863. PWR_ClearFlag(PWR_FLAG_WU);
  864. }
  865. /* Wait until last write operation on RTC registers has finished */
  866. RTC_WaitForLastTask();
  867. /* Clear RTC Alarm interrupt pending bit */
  868. RTC_ClearITPendingBit(RTC_IT_ALR);
  869. /* Wait until last write operation on RTC registers has finished */
  870. RTC_WaitForLastTask();
  871. }
  872. }