STM32 串口收发数据包

接线图

HEX数据包接收

文本数据包接收

代码配置

发送HEX数据包

cs 复制代码
//存储发送或接收的载荷数据
uint8_t TX_Packet[4];
uint8_t RX_Packet[4];

void Serial_SendPacket(void)
{
	Serial_SendByte(0xFF);//发送包头
	Serial_SendArray(TX_Packet, 4);//发送4个载荷数据
	Serial_SendByte(0xFE);//发送包尾
	
	
}

主函数

cs 复制代码
#include "USART.h"
int main(void)
{
	OLED_Init();
	USART_Config();
	TX_Packet[0] = 0x01;
	TX_Packet[1] = 0x02;
	TX_Packet[2] = 0x03;
	TX_Packet[3] = 0x04;
	Serial_SendPacket();
	while(1)
	{
		
		
	}
	
	
}

接收HEX数据包

需要在中断函数里写

cs 复制代码
//存储发送或接收的载荷数据
uint8_t TX_Packet[4];
uint8_t RX_Packet[4];

//中断函数
void USART1_IRQHandler(void)
{
	static uint8_t RX_State = 0;
	static uint8_t pRX_Packet = 0;
	//判断中断标志位
	if(USART_GetITStatus(USART1, USART_IT_RXNE) == SET)
	{
		RX_Data = USART_ReceiveData(USART1);//读取数据寄存器,并存放在数据变量里
		if(RX_State == 0)
		{
			//如果接收到了包头
			if(RX_Data == 0xFF)
			{
				RX_State = 1;
				pRX_Packet = 0;
			}
		}
		else if(RX_State == 1)
		{
			RX_Packet[pRX_Packet] = RX_Data;//将RX_Data存在接收数组里
			pRX_Packet++;
			if(pRX_Packet >= 4)
			{
				RX_State = 2;
			}
		}
		else if(RX_State == 2)
		{
			//判断是不是包尾
			if(RX_Data == 0xFE)
			{
				RX_State = 0;
				RX_Flag = 1;//标志位置1
			}
		}
		
		//清除标志位
		USART_ClearITPendingBit(USART1, USART_IT_RXNE);
	}
	
}

主函数

cs 复制代码
#include "USART.h"
int main(void)
{
	OLED_Init();
	USART_Config();
	TX_Packet[0] = 0x01;
	TX_Packet[1] = 0x02;
	TX_Packet[2] = 0x03;
	TX_Packet[3] = 0x04;
	Serial_SendPacket();
	while(1)
	{
		if(Serial_GetRXFlag() == 1)
		{
			OLED_ShowHexNum(1, 1, RX_Packet[0], 2);
			OLED_ShowHexNum(1, 4, RX_Packet[1], 2);
			OLED_ShowHexNum(1, 7, RX_Packet[2], 2);
			OLED_ShowHexNum(1, 10,RX_Packet[3], 2);
		}
		
	}
	
	
}

按键控制

cs 复制代码
int main(void)
{
	KEY_Init();
	OLED_Init();
	USART_Config();
	TX_Packet[0] = 0x01;
	TX_Packet[1] = 0x02;
	TX_Packet[2] = 0x03;
	TX_Packet[3] = 0x04;
	OLED_ShowString(1, 1, "TXPacket");
	OLED_ShowString(3, 1, "RXPacket");
	while(1)
	{
		if(KEY_Scanf(GPIOB, GPIO_Pin_0) == 1)
		{
				TX_Packet[0]++;
				TX_Packet[1]++;
				TX_Packet[2]++;
				TX_Packet[3]++;
				Serial_SendPacket();
			OLED_ShowHexNum(2, 1, TX_Packet[0], 2);
			OLED_ShowHexNum(2, 4, TX_Packet[1], 2);
			OLED_ShowHexNum(2, 7, TX_Packet[2], 2);
			OLED_ShowHexNum(2, 10,TX_Packet[3], 2);
		}
		if(Serial_GetRXFlag() == 1)
		{
			OLED_ShowHexNum(4, 1, RX_Packet[0], 2);
			OLED_ShowHexNum(4, 4, RX_Packet[1], 2);
			OLED_ShowHexNum(4, 7, RX_Packet[2], 2);
			OLED_ShowHexNum(4, 10,RX_Packet[3], 2);
		}
		
	}

发送与接收文本数据包

cs 复制代码
char RX_Packet2[100];

//中断函数
void USART1_IRQHandler(void)
{
	static uint8_t RX_State = 0;
	static uint8_t pRX_Packet = 0;
	//判断中断标志位
	if(USART_GetITStatus(USART1, USART_IT_RXNE) == SET)
	{
		RX_Data = USART_ReceiveData(USART1);//读取数据寄存器,并存放在数据变量里
		if(RX_State == 0)
		{
			//如果接收到了包头
			if(RX_Data == '@' && RX_Flag == 0)
			{
				RX_State = 1;
				pRX_Packet = 0;
			}
		}
		else if(RX_State == 1)
		{
			//判断是不是第一个包尾
			if(RX_Data == '\r')
			{
				RX_State = 2;
			}
			else
			{
				RX_Packet2[pRX_Packet] = RX_Data;//将RX_Data存在接收数组里
				pRX_Packet++;
			}
		}
		else if(RX_State == 2)
		{
			//判断是不是第二个包尾
			if(RX_Data == '\n')
			{
				RX_State = 0;
				RX_Packet2[pRX_Packet] = '\0';//加结束标志位
				RX_Flag = 1;//标志位置1
			}
		}
		
		//清除标志位
		USART_ClearITPendingBit(USART1, USART_IT_RXNE);
	}
	
}

主函数:

cs 复制代码
int main(void)
{
	
	OLED_Init();
	LED_Init();
	USART_Config();
	OLED_ShowString(1, 1, "TXPacket");
	OLED_ShowString(3, 1, "RXPacket");
	while(1)
	{
		if(RX_Flag == 1)
		{
			OLED_ShowString(4, 1, "            ");
			OLED_ShowString(4, 1, RX_Packet2);
			
			if(strcmp(RX_Packet2, "LED_ON") == 0)
			{
				LED2(0);
				Serial_SendString("LED_ON_OK\r\n");
				OLED_ShowString(2, 1, "           ");
				OLED_ShowString(2, 1, "LED_ON_OK");
			}
			else if(strcmp(RX_Packet2, "LED_OFF") == 0)
			{
				LED2(1);
				Serial_SendString("LED_OFF_OK\r\n");
				OLED_ShowString(2, 1, "            ");
				OLED_ShowString(2, 1, "LED_OFF_OK");
			}
			else
			{
				Serial_SendString("ERROR_COMMAND\r\n");
				OLED_ShowString(2, 1, "              ");
				OLED_ShowString(2, 1, "ERROR_COMMAND");
			}
			RX_Flag = 0;
		}
		
	}
	
	
}
相关推荐
会员果汁1 小时前
网络工程-路由策略概述
网络
mounter6257 小时前
【硬核前沿】CXL 深度解析:重塑数据中心架构的“高速公路”,Linux 内核如何应对挑战?-- CXL 协议详解与 LSF/MM 最新动态
linux·服务器·网络·架构·kernel
LCMICRO-133108477467 小时前
长芯微LPS123完全P2P替代ADP123,高性能、低压差的线性稳压器
单片机·嵌入式硬件·fpga开发·硬件工程·dsp开发·线性稳压器
守护安静星空9 小时前
esp32开发笔记-工程搭建
笔记·单片机·嵌入式硬件·物联网·visual studio code
ACP广源盛139246256739 小时前
破局 Type‑C 切换器痛点@ACP#GSV6155+LH3828/GSV2221+LH3828 黄金方案
c语言·开发语言·网络·人工智能·嵌入式硬件·计算机外设·电脑
嵌入式小企鹅10 小时前
蓝牙学习系列(八):BLE L2CAP 协议详解
网络·学习·蓝牙·ble·协议栈·l2cap
金戈鐡馬11 小时前
BetaFlight中的定时器引脚绑定详解
stm32·单片机·嵌入式硬件·无人机
广州灵眸科技有限公司11 小时前
为RK3588注入澎湃算力:RK1820 AI加速卡完整适配与评测指南
linux·网络·人工智能·物联网·算法
byoass12 小时前
csdn_upload_005
网络·安全·云计算
Wave84512 小时前
FreeRTOS软件定时器详解
stm32·单片机·freertos