Serial.c 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583
  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. #include "Serial.h"
  18. #include "stm32f10x_dma.h"
  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. //UART1 Trace
  25. unsigned char RxBuffer1[UART1_RX_BUFFER_SIZE];
  26. unsigned char TxBuffer1[UART1_TX_BUFFER_SIZE];
  27. unsigned char g_ucUart1Received=0;//接受到一包数据标志位
  28. unsigned char g_ucUart1Sending=0;//仍有数据待发送标志
  29. unsigned short rx1_ct=0,rx1_len=0;
  30. unsigned short tx1_ct=0,tx1_len=0;
  31. //UART3 用于与MODEM通讯
  32. unsigned char RxBuffer3[UART3_RX_BUFFER_SIZE];
  33. unsigned char TxBuffer3[UART3_TX_BUFFER_SIZE];
  34. unsigned char g_ucUart3Received=0;//接受到一包数据标志位
  35. unsigned char g_ucUart3Sending=0;//仍有数据待发送标志
  36. static unsigned short rx3_ct=0,rx3_ct_max=0,rx3_len=0;
  37. static unsigned short tx3_ct=0,tx3_len=0;
  38. /********************************************************************
  39. *Uart1DMAInit
  40. *串口1 DMA设置
  41. *串口1 发送必须用通道4,接收必须用通道5
  42. *********************************************************************/
  43. void Uart1DMAInit(void)
  44. {
  45. NVIC_InitTypeDef NVIC_InitStructure;
  46. DMA_InitTypeDef DMA_InitStructure;
  47. //启动DMA时钟
  48. RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
  49. //DMA 通道4用于UART1 TX
  50. DMA_DeInit(DMA1_Channel4);
  51. DMA_InitStructure.DMA_PeripheralBaseAddr = (u32)(&USART1->DR);//外设地址
  52. DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)TxBuffer1;//内存地址
  53. DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralDST;//DMA传输方向单向
  54. DMA_InitStructure.DMA_BufferSize = UART1_TX_BUFFER_SIZE; //设置DMA在传输时缓冲区的长度
  55. DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; //设置DMA的外设递增模式
  56. DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable; //设置DMA的内存递增模式
  57. DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;//外设数据字长
  58. DMA_InitStructure.DMA_MemoryDataSize = DMA_PeripheralDataSize_Byte;//内存数据字长
  59. DMA_InitStructure.DMA_Mode = DMA_Mode_Normal; //设置DMA的传输模式
  60. DMA_InitStructure.DMA_Priority = DMA_Priority_Low; //设置DMA的优先级别
  61. DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;//设置DMA的2个memory中的变量互相访问
  62. DMA_Init(DMA1_Channel4,&DMA_InitStructure);
  63. //DMA中断设置
  64. NVIC_InitStructure.NVIC_IRQChannel = DMA1_Channel4_IRQn;
  65. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 3;
  66. NVIC_InitStructure.NVIC_IRQChannelSubPriority = 2;
  67. NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  68. NVIC_Init(&NVIC_InitStructure);
  69. DMA_ITConfig(DMA1_Channel4,DMA_IT_TC,ENABLE);//中断设置
  70. DMA_Cmd(DMA1_Channel4, DISABLE); //等到需要发送的时候再使能
  71. //DMA 通道5用于UART1 RX
  72. DMA_DeInit(DMA1_Channel5);
  73. DMA_InitStructure.DMA_PeripheralBaseAddr = (u32)(&USART1->DR);//外设地址
  74. DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)RxBuffer1;//内存地址
  75. DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;//DMA传输方向单向
  76. DMA_InitStructure.DMA_BufferSize = UART1_RX_BUFFER_SIZE; //设置DMA在传输时缓冲区的长度
  77. DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; //设置DMA的外设递增模式
  78. DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable; //设置DMA的内存递增模式
  79. DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;//外设数据字长
  80. DMA_InitStructure.DMA_MemoryDataSize = DMA_PeripheralDataSize_Byte;//内存数据字长
  81. DMA_InitStructure.DMA_Mode = DMA_Mode_Normal; //设置DMA的传输模式
  82. DMA_InitStructure.DMA_Priority = DMA_Priority_High; //设置DMA的优先级别
  83. DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;//设置DMA的2个memory中的变量互相访问
  84. DMA_Init(DMA1_Channel5,&DMA_InitStructure);
  85. DMA_Cmd(DMA1_Channel5, ENABLE); //使能通道
  86. }
  87. /********************************************************************
  88. *Uart3DMAInit
  89. *串口3 DMA设置
  90. *串口3 发送必须用通道2,接收必须用通道3
  91. *********************************************************************/
  92. void Uart3DMAInit(void)
  93. {
  94. NVIC_InitTypeDef NVIC_InitStructure;
  95. DMA_InitTypeDef DMA_InitStructure;
  96. //启动DMA时钟
  97. RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
  98. //DMA 通道2用于UART3 TX
  99. DMA_DeInit(DMA1_Channel2);
  100. DMA_InitStructure.DMA_PeripheralBaseAddr = (u32)(&USART3->DR);//外设地址
  101. DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)TxBuffer3;//内存地址
  102. DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralDST;//DMA传输方向单向
  103. DMA_InitStructure.DMA_BufferSize = UART3_TX_BUFFER_SIZE; //设置DMA在传输时缓冲区的长度
  104. DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; //设置DMA的外设递增模式
  105. DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable; //设置DMA的内存递增模式
  106. DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;//外设数据字长
  107. DMA_InitStructure.DMA_MemoryDataSize = DMA_PeripheralDataSize_Byte;//内存数据字长
  108. DMA_InitStructure.DMA_Mode = DMA_Mode_Normal; //设置DMA的传输模式
  109. DMA_InitStructure.DMA_Priority = DMA_Priority_High; //设置DMA的优先级别
  110. DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;//设置DMA的2个memory中的变量互相访问
  111. DMA_Init(DMA1_Channel2,&DMA_InitStructure);
  112. //DMA中断设置
  113. NVIC_InitStructure.NVIC_IRQChannel = DMA1_Channel2_IRQn;
  114. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 3;
  115. NVIC_InitStructure.NVIC_IRQChannelSubPriority = 2;
  116. NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  117. NVIC_Init(&NVIC_InitStructure);
  118. DMA_ITConfig(DMA1_Channel2,DMA_IT_TC,ENABLE);//中断设置
  119. DMA_Cmd(DMA1_Channel2, DISABLE); //等到需要发送的时候再使能
  120. //DMA 通道3用于UART3 RX
  121. DMA_DeInit(DMA1_Channel3);
  122. DMA_InitStructure.DMA_PeripheralBaseAddr = (u32)(&USART3->DR);//外设地址
  123. DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)RxBuffer3;//内存地址
  124. DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;//DMA传输方向单向
  125. DMA_InitStructure.DMA_BufferSize = UART3_RX_BUFFER_SIZE; //设置DMA在传输时缓冲区的长度
  126. DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; //设置DMA的外设递增模式
  127. DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable; //设置DMA的内存递增模式
  128. DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;//外设数据字长
  129. DMA_InitStructure.DMA_MemoryDataSize = DMA_PeripheralDataSize_Byte;//内存数据字长
  130. DMA_InitStructure.DMA_Mode = DMA_Mode_Normal; //设置DMA的传输模式
  131. DMA_InitStructure.DMA_Priority = DMA_Priority_VeryHigh; //设置DMA的优先级别
  132. DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;//设置DMA的2个memory中的变量互相访问
  133. DMA_Init(DMA1_Channel3,&DMA_InitStructure);
  134. DMA_Cmd(DMA1_Channel3, ENABLE); //使能通道
  135. }
  136. /*********************************************************************************************
  137. *UART3RxTxISRHandler
  138. *串口3中断处理函数
  139. **********************************************************************************************/
  140. void UART3RxTxISRHandler(void)
  141. {
  142. /*
  143. __IO unsigned char uart_data;
  144. __IO unsigned short datalen;
  145. __IO int i;
  146. __IO int temp;
  147. static __IO unsigned char uart_last_data;
  148. __IO char *p;
  149. //----接收中断--------
  150. if(USART_GetITStatus(USART3, USART_IT_RXNE) != RESET)
  151. {
  152. uart_data = USART_ReceiveData(USART3); // Read one byte from the receive data register
  153. //MCU 处理Modem
  154. RxBuffer3[rx3_ct++]= uart_data;
  155. if(rx3_ct>=UART3_RX_BUFFER_SIZE) rx3_ct=0;
  156. if(uart_last_data==0x0d && uart_data==0x0a){ //收到回车换行符
  157. if(rx3_ct<2){ //独立的回车换行直接忽略
  158. rx3_ct=0;
  159. }else{
  160. //先判断是否+ZIPRECVU,如果是则需特殊处理
  161. datalen=0;
  162. if(RxBuffer3[0]=='+' && RxBuffer3[7]=='V' && RxBuffer3[1]=='Z' && RxBuffer3[3]=='P' && RxBuffer3[5]=='E') {//+ZIPRECVU
  163. //获取ZIPRECV接收数据长度 +ZIPRECVU:0,1024,xxxx/r/n
  164. if(RxBuffer3[12]>0x2f && RxBuffer3[12]<0x3a){
  165. if(RxBuffer3[13]>0x2f && RxBuffer3[13]<0x3a){
  166. if(RxBuffer3[14]>0x2f && RxBuffer3[14]<0x3a){
  167. if(RxBuffer3[15]>0x2f && RxBuffer3[15]<0x3a){
  168. datalen=1000*(RxBuffer3[12]-0x30);
  169. datalen+=100*(RxBuffer3[13]-0x30);
  170. datalen+=10*(RxBuffer3[14]-0x30);
  171. datalen+=(RxBuffer3[15]-0x30);
  172. datalen+=19;
  173. }else{
  174. datalen=100*(RxBuffer3[12]-0x30);
  175. datalen+=10*(RxBuffer3[13]-0x30);
  176. datalen+=(RxBuffer3[14]-0x30);
  177. datalen+=18;
  178. }
  179. }else{
  180. datalen=10*(RxBuffer3[12]-0x30);
  181. datalen+=(RxBuffer3[13]-0x30);
  182. datalen+=17;
  183. }
  184. }else{
  185. datalen= RxBuffer3[12]-0x30;
  186. datalen+=16;
  187. }
  188. }
  189. }
  190. //非+ZIPRECVU包,或大于+ZIPRECV包长的包,则认为完成一包数据接收
  191. if(rx3_ct>=datalen && rx3_ct>0){
  192. //以'+'开头的才处理 或 OK
  193. if((RxBuffer3[0]=='+') || (RxBuffer3[0]=='O' && RxBuffer3[1]=='K')){
  194. //发消息
  195. MsgQueuePost(&ModemMsgQueue,(char *)RxBuffer3,rx3_ct);
  196. }
  197. rx3_ct=0;
  198. }
  199. }
  200. }
  201. uart_last_data = uart_data;
  202. USART_ClearITPendingBit(USART3, USART_IT_RXNE); //清除中断标志
  203. }
  204. if(USART_GetFlagStatus(USART3,USART_FLAG_ORE)==SET)
  205. {
  206. assert_param(IS_USART_CLEAR_FLAG(USART_FLAG_ORE));
  207. USART_ReceiveData(USART3); //
  208. USART_ClearFlag(USART3,USART_FLAG_ORE); //
  209. }
  210. */
  211. }
  212. /********************************************************************************
  213. *Uart1Send
  214. *串口1启动发送
  215. *********************************************************************************/
  216. /*
  217. void Uart1Send(char *txbuf,int len)
  218. {
  219. int i;
  220. unsigned char data;
  221. unsigned char last_data=~UART_TRANSFORM;
  222. //Send Head
  223. USART_SendData(USART1, UART_HEAD);
  224. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  225. for(i=0;i<len;i++){
  226. data= txbuf[i];
  227. if(UART_TRANSFORM == data){
  228. USART_SendData(USART1,UART_TRANSFORM );
  229. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  230. USART_SendData(USART1,0x01 );
  231. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  232. }else if(UART_HEAD == data){
  233. USART_SendData(USART1,UART_TRANSFORM);
  234. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  235. USART_SendData(USART1,0x02 );
  236. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  237. }else if(UART_END == data){
  238. USART_SendData(USART1,UART_TRANSFORM);
  239. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  240. USART_SendData(USART1,0x03 );
  241. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  242. }else{
  243. USART_SendData(USART1,data);
  244. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  245. }
  246. }
  247. //Send End
  248. USART_SendData(USART1, UART_END);
  249. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  250. }
  251. */
  252. void Uart1Send(char *txbuf,int len)
  253. {
  254. int i;
  255. for(i=0;i<len;i++){
  256. USART_SendData(USART1,txbuf[i]);
  257. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  258. }
  259. }
  260. /*********************************************************************************************
  261. *UART1RxTxISRHandler
  262. *串口1中断处理函数
  263. 通讯协议
  264. RxBuffer1接收缓冲区
  265. sutMsg.Uart1Recv为1表明接受到一包数据,需要应用层处理数据后将其清零以便接受新的数据包
  266. 每包数据均以UART_HEAD开头,UART_END结尾。如解决数据包内容刚好有与UART_HEAD或UART_END相等的值,则需要转义
  267. 转义字符为UART_TRANSFORM,当收到UART_TRANSFORM开头时将根据紧挨其后的字符决定转义
  268. 如UART_HEAD=0x7a UART_END=0x7b UART_TRANSFORM=0x7c
  269. 如拟发送数据为: 01 02 7a 03 04 7b 05 06 7c 08 09 经过转换后的数据包为:
  270. 01 02 7c 02 03 04 7c 03 05 06 7c 01 08 09
  271. 加上包头包尾后:
  272. 7a 01 02 7c 02 03 04 7c 03 05 06 7c 01 08 09 7b
  273. **********************************************************************************************
  274. void UART1RxTxISRHandler(void)
  275. {
  276. __IO unsigned char uart_data;
  277. __IO static unsigned char last_data;
  278. //----接收中断--------
  279. if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)
  280. {
  281. uart_data = USART_ReceiveData(USART1);
  282. if(sutMsg.Uart1Recv){//上一批没处理,不接受新数据
  283. USART_ClearITPendingBit(USART1, USART_IT_RXNE); //清除中断标志
  284. rx1_ct=0;
  285. return;
  286. }
  287. if(uart_data==UART_HEAD){//包头
  288. RxBuffer1[0]=UART_HEAD;
  289. rx1_ct=1;
  290. }else if(rx1_ct>=(UART1_RX_BUFFER_SIZE-1)){//超出接受缓冲区,丢掉此包数据,复位重新接收
  291. rx1_ct=0;
  292. }else if(rx1_ct>0){
  293. if(uart_data==UART_END){//包尾
  294. RxBuffer1[rx1_ct++]=uart_data;
  295. rx1_len=rx1_ct;
  296. rx1_ct=0;
  297. sutMsg.Uart1Recv=1;
  298. }else if(uart_data==UART_TRANSFORM){//转义字符,忽略
  299. }else{
  300. if(last_data==UART_TRANSFORM){
  301. if(0x01==uart_data)RxBuffer1[rx1_ct++]=UART_TRANSFORM;
  302. else if(0x02==uart_data)RxBuffer1[rx1_ct++]=UART_HEAD;
  303. else if(0x03==uart_data)RxBuffer1[rx1_ct++]=UART_END;
  304. }else{
  305. RxBuffer1[rx1_ct++]=uart_data;
  306. }
  307. }
  308. }
  309. last_data=uart_data;
  310. USART_ClearITPendingBit(USART1, USART_IT_RXNE); //清除中断标志
  311. }
  312. }
  313. */
  314. /*********************************************************************************************
  315. *UART1RxTxISRHandler
  316. *串口1中断处理函数
  317. **********************************************************************************************/
  318. void UART1RxTxISRHandler(void)
  319. {
  320. __IO unsigned long temp;
  321. //接收空闲中断
  322. if(USART_GetITStatus(USART1, USART_IT_IDLE) != RESET){
  323. temp = USART1->SR;//先读SR,再读DR
  324. temp = USART1->DR;//方可清USART_IT_IDLE标志
  325. temp = UART1_RX_BUFFER_SIZE - DMA1_Channel5->CNDTR;
  326. DMA_Cmd(DMA1_Channel5,DISABLE);
  327. //处理数据
  328. //if(RxBuffer1[0]=='P' && RxBuffer1[1]=='C' && RxBuffer1[2]=='T' && RxBuffer1[3]=='A'){
  329. if(sutMsg.Uart1Recv){//上一批没处理,不接受新数据
  330. }else{
  331. //数据拷贝
  332. memcpy(IapRxBuf,RxBuffer1,temp);
  333. IapRxLen=temp;
  334. sutMsg.Uart1Recv=1;
  335. }
  336. //}
  337. //重设DMA传输数据长度
  338. DMA1_Channel5->CNDTR = UART1_RX_BUFFER_SIZE;
  339. //打开DMA
  340. DMA_Cmd(DMA1_Channel5,ENABLE);
  341. }
  342. if(USART_GetFlagStatus(USART3,USART_FLAG_ORE)==SET)
  343. {
  344. assert_param(IS_USART_CLEAR_FLAG(USART_FLAG_ORE));
  345. USART_ReceiveData(USART1); //
  346. USART_ClearFlag(USART1,USART_FLAG_ORE); //
  347. }
  348. }
  349. /*******************************************************************************
  350. Uart1Init
  351. Use for Trace
  352. *******************************************************************************/
  353. void Uart1Init(void)
  354. {
  355. NVIC_InitTypeDef NVIC_InitStructure;
  356. GPIO_InitTypeDef GPIO_InitStructure;
  357. USART_InitTypeDef USART_InitStructure;
  358. RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOA | RCC_APB2Periph_USART1,ENABLE);
  359. /*
  360. * USART1_TX -> PA9 , USART1_RX -> PA10
  361. */
  362. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
  363. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  364. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  365. GPIO_Init(GPIOA, &GPIO_InitStructure);
  366. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
  367. GPIO_InitStructure.GPIO_Mode =GPIO_Mode_IN_FLOATING;// GPIO_Mode_IPU;//GPIO_Mode_IN_FLOATING;
  368. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  369. GPIO_Init(GPIOA, &GPIO_InitStructure);
  370. USART_InitStructure.USART_BaudRate =115200;// 115200;
  371. USART_InitStructure.USART_WordLength = USART_WordLength_8b;
  372. USART_InitStructure.USART_StopBits = USART_StopBits_1;
  373. USART_InitStructure.USART_Parity = USART_Parity_No;
  374. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  375. USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
  376. USART_Init(USART1, &USART_InitStructure);
  377. USART_Cmd(USART1, ENABLE);
  378. /* Configure the NVIC Preemption Priority Bits */
  379. NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);
  380. /* Enable the USART1 Interrupt */
  381. NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
  382. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
  383. NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
  384. NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  385. NVIC_Init(&NVIC_InitStructure);
  386. USART_ClearFlag(USART1,USART_FLAG_TC);
  387. USART_ITConfig(USART1, USART_IT_TXE, DISABLE); //ENABLE DISABLE
  388. USART_ITConfig(USART1, USART_IT_RXNE, DISABLE); //ENABLE DISABLE
  389. USART_ITConfig(USART1, USART_IT_IDLE, ENABLE); //USART_IT_IDLE USART_IT_RXNE
  390. USART_DMACmd(USART1,USART_DMAReq_Rx,ENABLE); //使能USART1的接收DMA请求
  391. USART_DMACmd(USART1,USART_DMAReq_Tx,DISABLE); //使能USART1的发送DMA请求
  392. Uart1DMAInit();
  393. }
  394. void UART2RxTxISRHandler(void)
  395. {
  396. }
  397. /***************************************************************************
  398. Uart3Init
  399. ****************************************************************************/
  400. void Uart3Init(void)
  401. {
  402. NVIC_InitTypeDef NVIC_InitStructure;
  403. GPIO_InitTypeDef GPIO_InitStructure;
  404. USART_InitTypeDef USART_InitStructure;
  405. /*使能串口3使用的GPIO时钟*/
  406. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
  407. /*使能串口3时钟*/
  408. RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3, ENABLE);
  409. /*串口3 RX管脚配置*/
  410. /* Configure USART3 Rx as input floating */
  411. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;
  412. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;//GPIO_Mode_IPU;//GPIO_Mode_IN_FLOATING;
  413. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  414. GPIO_Init(GPIOB, &GPIO_InitStructure);
  415. /*串口3 TX管脚配置*/
  416. /* Configure USART2 Tx as alternate function push-pull */
  417. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
  418. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;//GPIO_Mode_AF_PP;
  419. GPIO_Init(GPIOB, &GPIO_InitStructure);
  420. USART_InitStructure.USART_BaudRate = 115200;//115200;//57600;//115200;
  421. USART_InitStructure.USART_WordLength = USART_WordLength_8b;
  422. USART_InitStructure.USART_StopBits = USART_StopBits_1;
  423. USART_InitStructure.USART_Parity = USART_Parity_No;;
  424. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  425. USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
  426. USART_Init(USART3, &USART_InitStructure);
  427. /* Configure the NVIC Preemption Priority Bits */
  428. NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);
  429. /* Enable the USART3 Interrupt */
  430. NVIC_InitStructure.NVIC_IRQChannel = USART3_IRQn;
  431. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
  432. NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
  433. NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  434. NVIC_Init(&NVIC_InitStructure);
  435. USART_ClearFlag(USART3,USART_FLAG_TC);
  436. USART_ITConfig(USART3, USART_IT_TXE, DISABLE); //ENABLE DISABLE
  437. USART_ITConfig(USART3, USART_IT_RXNE, ENABLE); //ENABLE DISABLE
  438. USART_ITConfig(USART3, USART_IT_IDLE, DISABLE);//USART_IT_IDLE USART_IT_RXNE
  439. USART_ITConfig(USART1, USART_IT_PE, ENABLE);
  440. USART_ITConfig(USART1, USART_IT_ERR, ENABLE);
  441. USART_Cmd(USART3, ENABLE);
  442. USART_DMACmd(USART3,USART_DMAReq_Tx,DISABLE); //使能USART1的DMA请求
  443. USART_DMACmd(USART3,USART_DMAReq_Rx,DISABLE); //使能USART1的DMA请求
  444. //Uart3DMAInit();
  445. }
  446. /********************************************************************************
  447. *Uart3Send
  448. *串口3启动发送
  449. *********************************************************************************/
  450. void Uart3Send(void)
  451. {
  452. if(tx3_len==0 || tx3_len>UART3_TX_BUFFER_SIZE)return;
  453. // //启动新一轮发送
  454. // g_ucUart2Sending=tx2_len;
  455. // tx2_ct=0;
  456. // //发送
  457. // //USART_ClearITPendingBit(USART2, USART_IT_TXE); //清除中断标志
  458. // USART_ITConfig(USART2, USART_IT_TXE, ENABLE);
  459. for(tx3_ct=0;tx3_ct<tx3_len;tx3_ct++){
  460. USART_SendData(USART3, TxBuffer3[tx3_ct]);
  461. while (USART_GetFlagStatus(USART3, USART_FLAG_TC) == RESET);
  462. }
  463. }
  464. //调用函数:
  465. //my_func(data, "%s:%d\n", str, n);
  466. /*
  467. void IapTrace(char* format, ...)
  468. {
  469. static char TraceBuffer[512];
  470. va_list argptr;
  471. int cnt;
  472. va_start(argptr, format);
  473. cnt = vsprintf(TraceBuffer, format, argptr);
  474. va_end(argptr);
  475. if(cnt>152){
  476. printf("TraceBuffer Error!\r\n");
  477. return;
  478. }
  479. DelayTick(10);
  480. printf("[IAP]");
  481. printf(TraceBuffer);
  482. DelayTick(10);
  483. }
  484. */
  485. /***********************************************************************************
  486. *
  487. ************************************************************************************/
  488. void IapTrace(char *buf)
  489. {
  490. char *p=buf;
  491. DelayTick(10);
  492. printf("[IAP]");
  493. while(0!=*p){
  494. USART_SendData(USART1, *p);
  495. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  496. p++;
  497. }
  498. DelayTick(10);
  499. }
  500. void SlwTrace(char *buf)
  501. {
  502. char *p=buf;
  503. while(0!=*p){
  504. USART_SendData(USART1, *p);
  505. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  506. p++;
  507. }
  508. }
  509. #ifdef __GNUC__
  510. /* With GCC/RAISONANCE, small printf (option LD Linker->Libraries->Small printf
  511. set to 'Yes') calls __io_putchar() */
  512. #define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
  513. #else
  514. #define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
  515. #endif /* __GNUC__ */
  516. /**
  517. * @brief Retargets the C library printf function to the USART.
  518. * @param None
  519. * @retval None
  520. */
  521. PUTCHAR_PROTOTYPE
  522. {
  523. /* Place your implementation of fputc here */
  524. /* e.g. write a character to the USART */
  525. USART_SendData(USART1, (uint8_t) ch);
  526. /* Loop until the end of transmission */
  527. while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET)
  528. {}
  529. return ch;
  530. }