[技术手册] 单片机可靠性差?可以弄个软件陷阱!

[复制链接]
 楼主| robincotton 发表于 2025-2-23 20:13 | 显示全部楼层 |阅读模式
1、软件陷阱是什么?

软件陷阱是一种用于捕获并处理单片机程序“跑飞”现象的技术,当程序执行过程中因干扰而偏离正常轨道时,软件陷阱可及时发现并将程序拉回正常执行路径。

2、软件陷阱如何构建?
①未使用ERROM空间的填充
在程序存储器中未使用的EPROM空间,首先填入窄操作指令NOP(无操作指令)。
在NOP指令后,填入一条跳转指令LJMP,跳转到预设的跑飞处理程序(如FLY)。
若未使用空间较大,可均匀分布NOP指令和LJMP指令,形成“软件陷阱”。
②数据表及子程序间的陷阱设置
在数据表的结尾处设置软件陷阱,确保程序跑飞到数据区时能及时转入正轨。
若数据表较大,可在中间位置也设置软件陷阱。
在每两个子程序之间设置一个软件陷阱,以捕获可能的程序跑飞。
③中断服务程序中的陷阱
当使用的中断因干扰而开放时,在对应的中断服务程序中设置软件陷阱。
这样能够及时捕获错误的中断,避免程序进一步失控。

3、代码示例

; 假设FLY为跑飞处理子程序的标签
FLY:
    ; 跑飞处理代码(如复位、重新初始化等)
    ; ...
    ; 跳转到正常程序执行起点
    LJMP START

; 未使用EPROM空间填充示例
NOP
NOP
LJMP FLY

; 数据表及子程序间陷阱设置示例
DATA_TABLE_END:
    NOP
    NOP
    LJMP FLY

SUB_PROGRAM1_END:
    NOP
    NOP
    LJMP FLY

SUB_PROGRAM2_START:
    ; 子程序2的代码
    ; ...

4、注意事项

软件陷阱的数量应根据实际干扰情况和程序存储器容量来确定。
陷阱的设置应尽可能均匀分布,以提高捕获程序跑飞的效率。
跑飞处理子程序应包含必要的复位或重新初始化操作,以确保程序能够恢复正常执行。

LOVEEVER 发表于 2025-2-23 21:49 | 显示全部楼层
软件陷阱是一种用于捕获并处理单片机程序“跑飞”现象的技术
小小蚂蚁举千斤 发表于 2025-2-23 22:16 | 显示全部楼层
数据表及子程序间的陷阱设置
pe66ak 发表于 2025-3-7 13:48 | 显示全部楼层
其实MCU来说没必要,直接优化等级打开,再编译看看程序是否有问题就可以了
suiziq 发表于 2025-3-7 15:12 | 显示全部楼层
你可以考虑使用看门狗,试试,也许会有改善
miltk 发表于 2025-3-7 16:26 | 显示全部楼层
你这种软件陷阱确实给我提出了一个很好的创意
nuan11nuan 发表于 2025-3-7 17:39 | 显示全部楼层
一般来说,这种软件陷阱对MCU来说不合适,MCU本身的容量就不大的
清芯芯清 发表于 2025-3-7 18:51 | 显示全部楼层
你说的怎么有点像看门狗呢?
yuliangren 发表于 2025-3-7 20:01 | 显示全部楼层
这种可靠性差的话确实用看门狗就行了,但是你说的是程序防止跑飞的技术是么
teaccch 发表于 2025-3-7 22:28 | 显示全部楼层
建议就是用个外置看门狗,稳得很啊
gongqijuns 发表于 2025-3-8 09:34 | 显示全部楼层
就用看门狗吧,解决死机或者会重启的操作
canfeil 发表于 2025-3-8 12:09 | 显示全部楼层
不是很懂这句话“在程序存储器中未使用的EPROM空间,首先填入窄操作指令NOP(无操作指令)。在NOP指令后,填入一条跳转指令LJMP,跳转到预设的跑飞处理程序(如FLY)。若未使用空间较大,可均匀分布NOP指令和LJMP指令,形成“软件陷阱”。”
hhdhy 发表于 2025-3-8 13:47 | 显示全部楼层
就是开启看门狗吧,解决跑飞问题,然后配合芯片加密,更加稳定可靠
您需要登录后才可以回帖 登录 | 注册

本版积分规则

33

主题

1512

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部

33

主题

1512

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部