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

 转自 http://blog.csdn.net/zhzht19861011/article/details/6249318

微处理器:LPC2114

编译环境:Keil MDK V4.10

思路:

常把单片机系统的复位分为冷启动和热启动。所谓冷启动,也就是一般所说的上电复位冷启动后片内外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),如下图:

clip_image002

然后使用__at关键字将冷、热启动标志位定位到这个NoInit区域:

uint32 unStartFlag __at (0x40003FF4);

这样,当热启动时,变量unStartFlag所在的内存区域就不会被初始化为0,也实现了冷热启动的判断。

定义铁电0xFF7~0xFF8区域存储冷启动次数

0xFF9~0xFFA区域存储热启动次数

0xFFB~0xFFC区域存储总启动次数

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Keil-51和Keil-ARM合并为一个软件工具的方法如下: 1. 确定合并的目的:首先需要明确合并的目的是为了提高开发效率、减少工具使用成本还是其他目的,以便确定合并的方向和重点。 2. 了解Keil-51和Keil-ARM:对于两个工具的特点、功能、兼容性等进行充分了解,以便确定合并的策略。 3. 分析项目需求:根据项目需求确定合并后的工具应该具备的功能和特性,比如支持哪些硬件平台、哪些编程语言等。 4. 寻找替代方案:如果Keil-51和Keil-ARM无法直接合并,需要寻找能够替代的工具软件,比如其他集成开发环境(IDE)或编译器。 5. 迁移代码和项目:如果已经在使用Keil-51或Keil-ARM进行开发,需要将代码和项目迁移到合并后的工具中。这个过程可能需要进行代码的调整和修改,以保证代码在新的工具中能够正常编译和运行。 6. 测试和验证:在合并完成后,需要对代码和项目进行充分的测试和验证,以确保合并后的工具的稳定性和功能完整性。 7. 培训和支持:合并工具后,需要给开发人员提供相应的培训和支持,帮助他们熟悉新的工具和使用方式。 8. 持续改进:合并完成后,需要不断跟进工具的发展和改进,及采用新的版本和功能,以提高开发效率和开发质量。 总的来说,Keil-51和Keil-ARM的合并需要明确目标、了解需求,找到合适的替代方案,迁移代码和项目,进行充分的测试和验证,然后提供培训和支持。合并后需要持续跟进改进,以确保工具的稳定性和持续提高开发效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值