STM32的Modbus-RTU接收结束判断

该博客详细介绍了如何在STM32上实现Modbus-RTU模式的接收结束判断程序,包括串口1的配置、接收状态管理、Modbus初始化和CRC校验的实现。通过HAL_UARTEx_RxEventCallback回调函数处理串口1接收完成,并在ModbusEnd()函数中进行CRC校验。示例代码展示了如何根据CRC校验结果执行相应操作。
摘要由CSDN通过智能技术生成

目录

一、简介

1.1、开发环境

1.2、摘要

二、串口1程序内容

三、Modbus程序内容

四、使用示例


一、简介

1.1、开发环境

STM32CubeIDE V1.9。

1.2、摘要

用STM32实现Modbus-RTU模式的接收结束判断程序。

二、串口1程序内容

头文件声明串口1的内容:

#define ReceiveBufferSize	255			//接收缓存大小
extern uint8_t ReceiveBuffer[];         //串口1接收缓存数组

typedef enum
{
	ReceiveFree,						//接收空闲
	ReceiveFinish,						//接收完成
}UartReceiveState_TypeDef;				//串口接收状态

extern struct UartFlag					//串口标志位
{
	UartReceiveState_TypeDef receive_state;	//接收状态标志
}
U1FG;

extern struct UartVariable				//串口变量
{
	uint8_t receive_size;				//接收长度
}
U1VE;

工程文件定义串口1的内容:

uint8_t ReceiveBuffer[ReceiveBufferSize];           //定义接收缓存数组

struct UartFlag U1FG =			//串口1标志位
{
	ReceiveFree,				//初始化:接收状态=接收空闲
};
struct UartVariable	U1VE =		//串口1变量
{
	0,							//初始化:接收字节长度为0
};

串口1的子函数:

/*
 * 功能:重新定义串口回调函数,处理串口1接收完成
 * 输入:@huart:串口号,用于区别哪个串口产生的回调
 * 		@Size:本次接收的字节长度
 * 输出:无
 */
void HAL_UARTEx_RxEventCallback(UART_HandleTypeDef *huart, uint16_t Size)
{
	if(huart == &huart1)                                       		//判定:串口1接收
    {
		U1FG.receive_state = ReceiveFinish;							//设置:串口1接收完成
		U1VE.receive_size = Size;									//读取:串口1接收长度
    }
}

三、Modbus程序内容

头文件声明Modbus的内容:

typedef enum
{
	Modbus_OK,					//执行完成
	Modbus_ERROR,				//执行错误
	Modbus_NOP,					//空操作
}ModbusResult_TypeDef;			//Modbus程序执行结果

typedef enum
{
	CRC_Nop,							//未进行CRC校验
	CRC_Success,						//CRC校验成功
	CRC_Error,							//CRC校验错误
}CrcResult_TypeDef;						//CRC校验结果

ModbusResult_TypeDef ModbusInitialize();
CrcResult_TypeDef ModbusEnd();

Modbus子函数:

/*
 * 功能:Modbus初始化
 * 输入:无
 * 输出:Modbus函数执行结果
 */
ModbusResult_TypeDef ModbusInitialize()
{
	HAL_StatusTypeDef result;

	U1VE.receive_size = 0;						//清零:串口1接收长度
	result = HAL_UARTEx_ReceiveToIdle_IT(
			&huart1, 							//串口1
			ReceiveBuffer, 						//接收缓存
			ReceiveBufferSize);   				//接收缓存字节长度

	if(result == HAL_OK) return Modbus_OK;		//初始化成功
	else return Modbus_ERROR;					//初始化失败
}

/*
 * 功能:ModBus接收结束判断
 * 输入:无
 * 输出:CRC校验结果
 */
CrcResult_TypeDef ModbusEnd()
{
	uint16_t crc_buffer = 0;

	if(U1FG.receive_state == ReceiveFinish)							//判断:串口接收完成
	{
		U1FG.receive_state = ReceiveFree;

		crc_buffer = ReceiveBuffer[-- U1VE.receive_size];
		crc_buffer <<= 8;
		crc_buffer += ReceiveBuffer[-- U1VE.receive_size];

		if(crc_buffer == MdobusCRC(U1VE.receive_size,ReceiveBuffer))//判断:CRC校验成功
		{
			return CRC_Success;										//返回:执行完成
		}
		else														//判断:CRC校验失败
		{
			return CRC_Error;										//返回:执行完成
		}
	}
	else
	{
		return CRC_Nop;											    //返回:未执行
	}
}

注:使用的函数“MdobusCRC”,详见Modbus查表法CRC校验程序_VIFIN的博客-CSDN博客

四、使用示例

/*
 * 功能:ModBus主程序
 * 输入:无
 * 输出:无
 */
void ModbusMain()
{
	switch(ModbusEnd())
	{
		case CRC_Success:

            //此处执行Modbus解码程序
			while(ModbusInitialize() == Modbus_ERROR);				//初始化:串口1的Modbus接收

		break;
		case CRC_Error:

            //此处执行Modbus校验错误程序
			while(ModbusInitialize() == Modbus_ERROR);				//初始化:串口1的Modbus接收

		break;
		default:

            //此处执行Modbus等待数据接收程序
    
		break;
	}
}

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
STM32 Modbus-RTU主机程序是一种针对STM32单片机开发的软件程序,用于实现Modbus通信协议中主站(主机)的功能。Modbus-RTU是一种常见的串行通信协议,用于在工业自动化系统中进行数据交换。 STM32 Modbus-RTU主机程序的设计目的是实现STM32单片机作为Modbus通信系统中的主站,具备与从站进行通信的能力。主机程序中通过串口与从站进行通信,接收和发送数据。主机程序需要实现Modbus协议的相关功能,包括函数码解析、地址解析、数据读写操作等。 在设计STM32 Modbus-RTU主机程序时,需要考虑以下几个关键因素。首先,需要确定从站的地址和通信参数,包括波特率、数据位数、停止位等。其次,需要实现Modbus通信协议的各种功能,如读取保持寄存器、读取输入寄存器、写入单个线圈等。此外,还要考虑主机与从站的通信方式和通信频率,以及数据的处理和解析方式。 在编写STM32 Modbus-RTU主机程序时,可以使用STM32的开发环境进行开发,如Keil等。首先建立串口通信功能,然后根据主机与从站的通信协议,实现相应的Modbus函数码解析和数据读写操作。最后进行测试和调试,确保主机程序能够正确地与从站进行通信,并实现所需的数据交换功能。 总之,STM32 Modbus-RTU主机程序是一种通过STM32单片机实现Modbus通信协议的软件程序。它能够使STM32单片机具备作为主站与从站进行通信的能力,并实现相关的数据读写操作。通过该主机程序,能够在工业自动化系统中实现高效可靠的通信。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

洪恒远

感君意气无所惜,一为歌行歌主客

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值