使用keil判断ARM的冷启动和热启动的方法

使用keil判断ARM的冷启动和热启动的方法
思路:
常把单片机系统的复位分为冷启动和热启动。所谓冷启动,也就是一般所说的上电复位,冷
启动后片内外 RAM 的内容是随机的,通常是 0x00 或 0xFF;单片机的热启动是通过外部电
路给运行中的单片机的复位端一复位电平而实现的,也就是所说的按键复位或看门狗复位。
复位后,RAM 的内容都没有改变。在某些场合,必须区分出设备的重启是热重启还是冷重
启。常用的方法是:确定某内存单位为标志位(如 0x40003FF4~0x40003FF7 RAM 单元),
启动时首先读该内存单元的内容,如果它等于一个特定的值(例如为 0xAA55AA55),就认为
是热启动,否则就是冷启动。
根据以上的设计思路思路定义一个变量:
uint32 unStartFlag;
在程序启动时判断:
if(unStartFlag==0xAA55AA55)
{
//热启动处理
}
else
{
//冷启动处理
unStartFlag=0xAA55AA55;
}
然而实际调试中发现,无论是热启动还是冷启动,开机后所有内存单元的值都被复位为 0,
当然也实现不了热启动的要求。通过看 keil MDK 自带的启动代码 Startup.s,在这个启动代
码中也并没有发现将整个 RAM 区域清零的语句。反汇编程序,发现从启动代码执行结束到
跳转到 main 函数过程中,编译器还执行了很多库函数,其中__scatterload_zeroinit 函数
将所有 W/R RAM 都初始化为 0(默认设置下)。为了判断冷、热启动,必须人为控制某些
特定 RAM 在复位时不被编译器初始化为 0。通过查找编译器手册,在为处理器的 RAM 中
分出一块小片 RAM,设置为 NoInit 格式(不对其初始化为 0),如下图:
在这里插入图片描述
然后使用__at 关键字将冷、热启动标志位定位到这个 NoInit 区域:
uint32 unStartFlag __at (0x40003FF4);
这样,当热启动时,变量 unStartFlag 所在的内存区域就不会被初始化为 0,也实现了冷热
启动的判断。
定义铁电 0xFF7~0xFF8 区域存储冷启动次数
0xFF9~0xFFA 区域存储热启动次数
0xFFB~0xFFC 区域存储总启动次数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

2401_87496566

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值