0221 STM32 UART不定长数据中断接收

//串口相关变量
extern uint8_t RxdCnt;
extern uint8_t RxdOver;
extern uint8_t RxdBuf[20];
//UART缓冲变量
extern uint16_t USART_REC_LEN;  
extern uint16_t g_usart_rx_sta; 
extern uint8_t  g_rx_buffer[1]; 

void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
{
	if (huart->Instance == USART1)                     /* 如果是串口1 */
	{
		if ((g_usart_rx_sta & 0x8000) == 0)             /* 接收未完成 */
		{
			if (g_usart_rx_sta & 0x4000)                /* 接收到了0x0d(即回车键) */
			{
				if (g_rx_buffer[0] != 0x0a)             /* 接收到的不是0x0a(即不是换行键) */
				{
					g_usart_rx_sta = 0;                 /* 接收错误,重新开始 */
				}
				else                                    /* 接收到的是0x0a(即换行键) */
				{
					g_usart_rx_sta |= 0x8000;           /* 接收完成了 */
				}
			}
			else                                        /* 还没收到0X0d(即回车键) */
			{
				if (g_rx_buffer[0] == 0x0d)
					g_usart_rx_sta |= 0x4000;
				else
				{
					RxdBuf[g_usart_rx_sta & 0X3FFF] = g_rx_buffer[0];
					g_usart_rx_sta++;

					if (g_usart_rx_sta > (USART_REC_LEN - 1))      /* 定义最大接收字节数 - 1*/
					{
						g_usart_rx_sta = 0;                        /* 接收数据错误,重新开始接收 */
					}
				}
			}
		}
		HAL_UART_Receive_IT(&huart1, (uint8_t *)g_rx_buffer, 1);//接收的数据处理完毕后打开接收中断 	
	}	
}
/* 定义最大接收字节数 */
uint16_t USART_REC_LEN = 20;  
/*bit15:接收完成标志,bit14:接收到0x0d,bit13~0:接收到的有效字节数目*/
uint16_t g_usart_rx_sta = 0;
/* HAL库使用的串口接收缓冲 */
uint8_t  g_rx_buffer[1];      

uint8_t len;
f (g_usart_rx_sta & 0x8000)        /* 接收到了数据 */
{
  len = g_usart_rx_sta & 0x3fff;  /* 得到此次接收到的数据长度 */
  g_usart_rx_sta = 0;
}	

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值