Chinaunix首页 | 论坛 | 博客
  • 博客访问: 58926
  • 博文数量: 11
  • 博客积分: 1400
  • 博客等级: 上尉
  • 技术积分: 140
  • 用 户 组: 普通用户
  • 注册时间: 2009-01-09 15:19
文章分类
文章存档

2017年(2)

2011年(1)

2010年(1)

2009年(7)

我的朋友

分类:

2009-01-12 15:16:43

自从完成Redboot的启动工作以来,一直有一个问题困扰着我,只是由于影响不大,所以都没有进行研究。这个问题就是在使用reset命令重启的时候,总是会在“... Resetting.”之后打印出乱码,和前面在cs8900驱动中遇到的乱码类似的。
今天有点闲工夫,于是决定解决这个问题,首先看了一下代码,发现经过了好几次的宏替换,实际上在do_reset函数里面最终调用的是\common\current\src\hal_if.c中的reset函数。reset函数采用了两种方式来重启系统,一种是调用平台提供的HAL_PLATFORM_RESET()函数;另一种就是简单的goto到入口地址HAL_PLATFORM_RESET_ENTRY处执行。
本来想通过加入while(1)死循环定位函数,然后用AxD进行单步调试来找到问题所在。先将死循环放到reset函数的起始位置,发现还没有出现乱码,但是单步执行却没有发生重启;然后将死循环的位置往后挪,却突然发现将死循环放到HAL_PLATFORM_RESET()之后,系统运行reset命令时竟然没有出现乱码并成功重启了。
屏蔽掉HAL_PLATFORM_RESET()和死循环后,再下载试运行reset命令,重启成功时乱码又出现了。这说明乱码是由于简单的采用goto语句跳转到入口地址时出现的,具体是怎么引起的还不清楚。实际上reset函数里面的注释也表明这种方法Not quite as good as a reset, but it is often enough.再看看HAL_PLATFORM_RESET(),实际上就是通过采用一个很短时间的看门狗复位来实现的。由于reset函数在两种复位的实现之间没有等待看门狗复位的时间,所以实际上起作用的是后面这个方法,在之间插入了死循环之后就使得看门狗复位成功了。于是修改了一下reset函数,在HAL_PLATFORM_RESET()之后加入了一段延时程序,以便保证看门狗复位能够起作用。即使在看门狗复位无法工作的情况下,还可以使用goto语句直接重启!
阅读(7390) | 评论(16) | 转发(0) |
0

上一篇:Drive CS8900

下一篇:都是中断惹的祸

给主人留下些什么吧!~~

chinaunix网友2009-01-15 17:12:51

好,谢谢你的回答。 共同学习。

chinaunix网友2009-01-15 17:12:50

好,谢谢你的回答。 共同学习。

chinaunix网友2009-01-15 17:12:47

好,谢谢你的回答。 共同学习。

chinaunix网友2009-01-15 17:12:42

好,谢谢你的回答。 共同学习。

leo_johncn2009-01-15 16:18:37

您好。实际上我也是初学者,我也还在摸索之中,所以我也无法给您回答这个问题! 据我了解,eCos在编译完成之后只会得到libtarget.a,extras.o,...等几个库文件,您需要将自己的应用程序和eCos的库进行链接,才能得到一个完整的eCos程序下载到目标板运行。 对于我而言,我一般是先用eCos的Redboot模板做出Redboot来,当然在Redboot上最主要是实现串口、eth以及flash的驱动,之后则用Redboot将编译的eCos装载到目标板运行,Redboot提供go或者exec(for linux)命令来运行你的程序。 另外,用于eCos的开发工具一般是linux平台下的交叉编译工具,这时候用ADS可能就不是很方便了,大多采用gnu-tools、gnu-make之类的工具来编译、链接你的程序。不过在调试Redboot的时候,还可以采用AxD和Jtag结合的办法,当有了Redboot之后,调试程序就可以使用arm-elf-gdb了。