专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
modbus做主机,大家有没有写过,说说心得
2019-12-21 12:08
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
5899
38
39
最近在做一个modbus采集数据的设备,有4个modbus从站。目前想到一些问题。
准备用状态机轮训的办法,分别读取4个从站的数据
1、带动4个modbus设备时,我给其中一个从站读取数,但是从站没有返回怎么办?
2、怎样确定各个从站之间轮训的间隔?
还有大神有没有好的代码或者思想参考照下
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
38条回答
youkebing
2019-12-23 08:54
12楼的方法:
1. 发送 req 数据报文
2. 等待从机响应最多100ms。
3. 若从机无响应,报告 warning 信息
4. 最多3次轮询后无响应,报告设备失效 fatal 信息,通知维护人员检查
5. 同一条总线上的所有设备无响应,报告总线失效 fatal 信息,通知维护人员检查
先谈一下该策略可能存在的一点点问题(假设下挂了3个从端 A, B, C):
其中A可能不太稳定。
那么按照以上策略,可能导致总线上另外两个从端响应也难于快起来。
因此我想了一种时间片的方法,对以上也是一种改进:
1. 给每个从端分配一个时间片,A(100毫秒)B(100毫秒)C(200毫秒),那么这个时间周期是400毫秒
2. 给每个从端分配一个数据块
{
int timersize; //该从端每次分配的时间片
int timer; //该从端可用的时间片
int err; //从端发生的错误次数
}
3. 每个从端的数据块 timer = 0。
while(1) {
4. 调度程序搜索每个数据块,寻找timer大于0的一个。如果找到跳转到第5步。找不到,跳转到第8步
5. 记录下当前系统时间T1,发送当前从端数据包。延时100ms(可以优化)跳转到 6
6. 如果收到完整包,err=0,如果数据包不合法,err += 1; 处理完毕后跳转到 7
7. 如果err == 0x03 显示提示信息。记录下当前系统时间T2,计算剩余时间片, timer -= T2 - T1 . 跳转到 4
8. 遍历数据块,每个数据块的时间 timer = timer + timersize; 跳转到 4
}
这个策略可以进行一些变形,比如如果一个从端发生错误太多,可以在下次分配的时候减少 timersize
比如:
if(err > 3) {
timer = timer + timersize / 2;
}
else{
timer = timer + timersize;
}
当然,这里面可以进行一些细化。
加载中...
查看其它38个回答
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
1. 发送 req 数据报文
2. 等待从机响应最多100ms。
3. 若从机无响应,报告 warning 信息
4. 最多3次轮询后无响应,报告设备失效 fatal 信息,通知维护人员检查
5. 同一条总线上的所有设备无响应,报告总线失效 fatal 信息,通知维护人员检查
先谈一下该策略可能存在的一点点问题(假设下挂了3个从端 A, B, C):
其中A可能不太稳定。
那么按照以上策略,可能导致总线上另外两个从端响应也难于快起来。
因此我想了一种时间片的方法,对以上也是一种改进:
1. 给每个从端分配一个时间片,A(100毫秒)B(100毫秒)C(200毫秒),那么这个时间周期是400毫秒
2. 给每个从端分配一个数据块
{
int timersize; //该从端每次分配的时间片
int timer; //该从端可用的时间片
int err; //从端发生的错误次数
}
3. 每个从端的数据块 timer = 0。
while(1) {
4. 调度程序搜索每个数据块,寻找timer大于0的一个。如果找到跳转到第5步。找不到,跳转到第8步
5. 记录下当前系统时间T1,发送当前从端数据包。延时100ms(可以优化)跳转到 6
6. 如果收到完整包,err=0,如果数据包不合法,err += 1; 处理完毕后跳转到 7
7. 如果err == 0x03 显示提示信息。记录下当前系统时间T2,计算剩余时间片, timer -= T2 - T1 . 跳转到 4
8. 遍历数据块,每个数据块的时间 timer = timer + timersize; 跳转到 4
}
这个策略可以进行一些变形,比如如果一个从端发生错误太多,可以在下次分配的时候减少 timersize
比如:
if(err > 3) {
timer = timer + timersize / 2;
}
else{
timer = timer + timersize;
}
当然,这里面可以进行一些细化。
一周热门 更多>