#include "usart.h" #include "delay.h" #include "timer.h" #include "EC800M.h" ////////////////////////////////////////////////////////////////////////////////// //如果使用os,则包括下面的头文件即可. #if 1 #pragma import(__use_no_semihosting) //标准库需要的支持函数 struct __FILE { int handle; }; FILE __stdout; //定义_sys_exit()以避免使用半主机模式 void _sys_exit(int x) { x = x; } //重定义fputc函数 int fputc(int ch, FILE *f) { while((USART1->SR&0X40)==0);//循环发送,直到发送完毕 USART1->DR = (u8) ch; return ch; } #endif u8 RX1_len; //定义接收数据的字符长度 u8 RX2_len; //定义接收数据的字符长度 u8 RX3_len; //定义接收数据的字符长度 #if 1 //如果使能了接收 //串口1中断服务程序 //注意,读取USARTx->SR能避免莫名其妙的错误 u8 USART_RX_BUF[USART_REC_LEN]; //接收缓冲,最大USART_REC_LEN个字节. u8 USART2_RX_BUF[USART_REC_LEN]; //接收缓冲,最大USART_REC_LEN个字节. //USART3.C内容: u8 USART3_RX_BUF[USART3_MAX_RECV_LEN]; //接收缓冲,最大USART3_MAX_RECV_LEN个字节. u8 USART3_TX_BUF[USART3_MAX_SEND_LEN]; //发送缓冲,最大USART3_MAX_SEND_LEN字节 u16 _tmpx_RX_STA,USART_RX_STA=0; //接收状态标记 u16 _tmpy_RX_STA,USART2_RX_STA=0; //接收状态标记 u16 _tmpz_RX_STA,USART3_RX_STA=0; //接收状态标记 u8 aRxBuffer[RXBUFFERSIZE];//HAL库使用的串口接收缓冲 u8 aRxBuffer2[RXBUFFERSIZE];//HAL库使用的串口接收缓冲 u8 aRxBuffer3[RXBUFFERSIZE];//HAL库使用的串口接收缓冲 //USART句柄 UART_HandleTypeDef UART1_Handler; UART_HandleTypeDef UART2_Handler; UART_HandleTypeDef UART3_Handler; extern char rec_1; UART_BUF buf_uart2; //NBIOT UART_BUF buf_uart1; //TTL //串口发送 void Uart2_SendStr(char*SendBuf)//串口6打印数据 { while(*SendBuf) { while((USART2->SR&0X40)==0);//等待发送完成 USART2->DR = (u8) *SendBuf; SendBuf++; } } void Uart1_SendStr(char*SendBuf)//串口1打印数据 { while(*SendBuf) { while((USART1->SR&0X40)==0);//等待发送完成 USART1->DR = (u8) *SendBuf; SendBuf++; } } void UART1_receive_process_event(char ch ) { if(buf_uart1.index >= BUFLEN) { buf_uart1.index = 0 ; } else { buf_uart1.buf[buf_uart1.index++] = ch; } } void ec200x_receive_process_event(unsigned char ch ) { if(buf_uart2.index >= BUFLEN) { buf_uart2.index = 0 ; } else { buf_uart2.buf[buf_uart2.index++] = ch; } } //初始化 void usart_init1(u32 bound) { //UART 初始化设置 UART1_Handler.Instance=USART1; //USART1 UART1_Handler.Init.BaudRate=bound; //波特率 UART1_Handler.Init.WordLength=UART_WORDLENGTH_8B; //字长为8位数据格式 UART1_Handler.Init.StopBits=UART_STOPBITS_1; //一个停止位 UART1_Handler.Init.Parity=UART_PARITY_NONE; //无奇偶校验位 UART1_Handler.Init.HwFlowCtl=UART_HWCONTROL_NONE; //无硬件流控 UART1_Handler.Init.Mode=UART_MODE_TX_RX; //收发模式 HAL_UART_Init(&UART1_Handler); //HAL_UART_Init()会使能UART1 //HAL_UART_Receive_IT(&UART1_Handler, (u8 *)aRxBuffer, RXBUFFERSIZE);//该函数会开启接收中断:标志位UART_IT_RXNE,并且设置接收缓冲以及接收缓冲接收最大数据量(使用回调函数处理中断需要调用该函数) } void usart_init2(u32 bound) { UART2_Handler.Instance=USART2; //USART1 UART2_Handler.Init.BaudRate=bound; //波特率 UART2_Handler.Init.WordLength=UART_WORDLENGTH_8B; //字长为8位数据格式 UART2_Handler.Init.StopBits=UART_STOPBITS_1; //一个停止位 UART2_Handler.Init.Parity=UART_PARITY_NONE; //无奇偶校验位 UART2_Handler.Init.HwFlowCtl=UART_HWCONTROL_NONE; //无硬件流控 UART2_Handler.Init.Mode=UART_MODE_TX_RX; //收发模式 HAL_UART_Init(&UART2_Handler); //HAL_UART_Init()会使能UART1 HAL_UART_Receive_IT(&UART2_Handler, (u8 *)aRxBuffer2, RXBUFFERSIZE);//该函数会开启接收中断:标志位UART_IT_RXNE,并且设置接收缓冲以及接收缓冲接收最大数据量 } void usart_init3(u32 bound) { UART3_Handler.Instance=USART3; //UART3 UART3_Handler.Init.BaudRate=bound; //波特率 UART3_Handler.Init.WordLength=UART_WORDLENGTH_8B; //字长为8位数据格式 UART3_Handler.Init.StopBits=UART_STOPBITS_1; //一个停止位 UART3_Handler.Init.Parity=UART_PARITY_NONE; //无奇偶校验位 UART3_Handler.Init.Mode=UART_MODE_TX_RX; //收发模式 HAL_UART_Init(&UART3_Handler); //HAL_UART_Init()会使能UART3 HAL_UART_Receive_IT(&UART3_Handler, (u8 *)aRxBuffer3, RXBUFFERSIZE);//该函数会开启接收中断:标志位UART_IT_RXNE,并且设置接收缓冲以及接收缓冲接收最大数据量 } //GPIO端口设置 void HAL_UART_MspInit(UART_HandleTypeDef *huart) { GPIO_InitTypeDef GPIO_Initure; if(huart->Instance==USART1)//如果是串口1,进行串口1 MSP初始化 { __HAL_RCC_GPIOA_CLK_ENABLE(); //使能GPIOA时钟 __HAL_RCC_USART1_CLK_ENABLE(); //使能USART1时钟 GPIO_Initure.Pin=GPIO_PIN_9; //PA9 GPIO_Initure.Mode=GPIO_MODE_AF_PP; //复用推挽输出 GPIO_Initure.Pull=GPIO_PULLUP; //上拉 GPIO_Initure.Speed=GPIO_SPEED_FAST; //高速 GPIO_Initure.Alternate=GPIO_AF7_USART1; //复用为USART1 HAL_GPIO_Init(GPIOA,&GPIO_Initure); //初始化PA9 GPIO_Initure.Pin=GPIO_PIN_10; //PA10 HAL_GPIO_Init(GPIOA,&GPIO_Initure); //初始化PA10 __HAL_UART_DISABLE_IT(huart,UART_IT_TC); #if EN_USART1_RX __HAL_UART_ENABLE_IT(huart,UART_IT_RXNE); //开启接收中断 HAL_NVIC_EnableIRQ(USART1_IRQn); //使能USART1中断通道 HAL_NVIC_SetPriority(USART1_IRQn,3,3); //抢占优先级3,子优先级3 #endif } if(huart->Instance==USART2)//如果是串口1,进行串口2 MSP初始化 { __HAL_RCC_GPIOA_CLK_ENABLE(); //使能GPIOA时钟 __HAL_RCC_USART2_CLK_ENABLE(); //使能USART1时钟 GPIO_Initure.Pin=GPIO_PIN_2; //PA2 GPIO_Initure.Mode=GPIO_MODE_AF_PP; //复用推挽输出 GPIO_Initure.Pull=GPIO_PULLUP; //上拉 GPIO_Initure.Speed=GPIO_SPEED_FREQ_HIGH; //高速 GPIO_Initure.Alternate=GPIO_AF7_USART2; //复用为USART2 HAL_GPIO_Init(GPIOA,&GPIO_Initure); //初始化PA2 GPIO_Initure.Pin=GPIO_PIN_3; //PA3 HAL_GPIO_Init(GPIOA,&GPIO_Initure); //初始化PA3 #if 1 HAL_NVIC_EnableIRQ(USART2_IRQn); //使能USART1中断通道 HAL_NVIC_SetPriority(USART2_IRQn,1,1); //抢占优先级3,子优先级3 #endif } if(huart->Instance==USART3)//如果是串口3,进行串口3 MSP初始化 { __HAL_RCC_GPIOB_CLK_ENABLE(); //使能GPIOB时钟 __HAL_RCC_USART3_CLK_ENABLE(); //使能USART3时钟 GPIO_Initure.Pin=GPIO_PIN_10; //PB10 GPIO_Initure.Mode = GPIO_MODE_AF_PP; // 复用推挽 GPIO_Initure.Pull = GPIO_PULLUP; // 不上拉不下拉 GPIO_Initure.Speed=GPIO_SPEED_FREQ_MEDIUM; //50mhz GPIO_Initure.Alternate=GPIO_AF7_USART3; //复用为USART3 HAL_GPIO_Init(GPIOB,&GPIO_Initure); //初始化PB10 GPIO_Initure.Pin=GPIO_PIN_11; //PB11 HAL_GPIO_Init(GPIOB,&GPIO_Initure); //初始化PB11 #if 1 HAL_NVIC_EnableIRQ(USART3_IRQn); //使能USART3中断通道 HAL_NVIC_SetPriority(USART3_IRQn,2,1); //抢占优先级2,子优先级3 #endif } //以下为usart3.c内容 USART3_RX_STA=0; //清零 } //回调函数 void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart) { //int _time1,_time2,_time3; if(huart->Instance==USART2)//如果是串口2 { #define USARTy_RX_STA USART2_RX_STA #define aRxBuffery aRxBuffer2 #define USARTy_RX_BUF USART2_RX_BUF USARTy_RX_BUF[USARTy_RX_STA&0X3FFF]=aRxBuffery[0]; USARTy_RX_STA++; if(USARTy_RX_STA >= (USART_REC_LEN-1))USARTy_RX_STA=0;//接收数据错误,重新开始接收 } if(huart->Instance==USART3)//如果是串口3 { USART3_RX_BUF[USART3_RX_STA&0X3FFF]=aRxBuffer3[0]; //0011 1111 1111 1111 USART3_RX_STA++; if(USART3_RX_STA >= (USART_REC_LEN-1))USART3_RX_STA=0;//接收数据错误,重新开始接收 if(strstr((char*)USART3_RX_BUF, "$GPTXT")){USART3_RX_STA|=0x8000;} } } //串口1中断服务程序 void USART1_IRQHandler(void) { u8 Res; #if SYSTEM_SUPPORT_OS //使用OS OSIntEnter(); #endif if((__HAL_UART_GET_FLAG(&UART1_Handler,UART_FLAG_RXNE)!=RESET)) //接收中断(接收到的数据必须是0x0d 0x0a结尾) { HAL_UART_Receive(&UART1_Handler,&Res,1,1000); if((USART_RX_STA&0x8000)==0)//接收未完成 { if(USART_RX_STA&0x4000)//接收到了0x0d { if(Res!=0x0a)USART_RX_STA=0;//接收错误,重新开始 else USART_RX_STA|=0x8000; //接收完成了 } else //还没收到0X0D { if(Res==0x0d)USART_RX_STA|=0x4000; else { USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ; USART_RX_STA++; if(USART_RX_STA>(USART_REC_LEN-1))USART_RX_STA=0;//接收数据错误,重新开始接收 } } } } HAL_UART_IRQHandler(&UART1_Handler); #if SYSTEM_SUPPORT_OS //使用OS OSIntExit(); #endif } void USART2_IRQHandler(void) { u32 timeout=0; u32 maxDelay=0x1FFFF; #if SYSTEM_SUPPORT_OS //使用OS OSIntEnter(); #endif HAL_UART_IRQHandler(&UART2_Handler); //调用HAL库中断处理公用函数 timeout=0; while (HAL_UART_GetState(&UART2_Handler) != HAL_UART_STATE_READY)//等待就绪 { timeout++;////超时处理 if(timeout>maxDelay) break; } timeout=0; while(HAL_UART_Receive_IT(&UART2_Handler, (u8 *)aRxBuffer2, RXBUFFERSIZE) != HAL_OK)//一次处理完成之后,重新开启中断并设置RxXferCount为1 { timeout++; //超时处理 if(timeout>maxDelay) break; } #if SYSTEM_SUPPORT_OS //使用OS OSIntExit(); #endif } void USART3_IRQHandler(void) { u32 timeout=0; #if SYSTEM_SUPPORT_OS //使用OS OSIntEnter(); #endif HAL_UART_IRQHandler(&UART3_Handler); //调用HAL库中断处理公用函数 timeout=0; u32 maxDelay=0x1FFFF; while (HAL_UART_GetState(&UART3_Handler) != HAL_UART_STATE_READY)//等待就绪 { timeout++;////超时处理 if(timeout>maxDelay) {break;} } timeout=0; while(HAL_UART_Receive_IT(&UART3_Handler, (u8 *)aRxBuffer3, RXBUFFERSIZE) != HAL_OK)//一次处理完成之后,重新开启中断并设置RxXferCount为1 { timeout++; //超时处理 if(timeout>maxDelay) {break;} } #if SYSTEM_SUPPORT_OS //使用OS OSIntExit(); #endif } #endif