- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
启动代码的分析
2410启动代码的分析
板子上电,那么cpu从地址0开始取得指令,然后一步一步的按照我们的程序执行下去。我
们试着来画一下程序最开始时运行的流程图。
程序入口
b ResetHandler
b HandlerUndef
b HandlerSWI
中断/异常向量表
b HandlerPabort
b HandlerDabort
b .
b HandlerIRQ
b HandlerFIQ
那么可以从上面图里看出,程序第一条指令执行的就是 b ResetHandler 。即跳入我
们正常执行程序里。那么这指令的下面,就是一些异常的入口。
这个异常入应该很好理解,每当异常发生时,cpu就会自动跳到相应的地址上来。比如,
现在发生了一个外部中断IRQ,那么cpu就会自动的跳到 0这个地址来扫行指令。
在上面的中断向量表里,正好可以看到 0这个地址里的指令是 b HandlerIRQ
,即跳到HandlerIRQ 这个位置去。那么只要我们在 HandlerIRQ 下面放上我们的IRQ 处理
子程序,就可以了。
关于中断,在下面再讨论。现在我们给板子上电了,那么它就执行最开始的一条指令 b
ResetHandler 。即我们要跳到 ResetHandler 这个位置去执行程序。
再来画一下 ResetHandler 的简易流程图。
ResetHandler
1. 关看门狗
2. 关中断
3. 系统时钟初始
化
是的
10. 进入掉电唤醒
4. 是从掉电模式唤醒的么?
不是
5. 初始化内存控制器
6. 初始化堆栈
7. 保存IRQ地址
8. 运行域初始化
9. 跳入C程序
上面各步骤我给标了号,是为了方便对各子程序的分析,并不是刻意指它们之间的执行
顺序。
1.关看门狗
;watch dog disable
代码很简单,就是对控制看门狗的特殊功能寄存器赋值。
ldr r0,=WTCON
为什么关掉看门狗呢?
ldr r1,=0x0
其实就是为了防止看门狗计数溢出,引起系统再次复位,
str r1,[r0]
因为此时我们还没有完成我们对系统的初始化。
2. 关中断
如右边的代码,给相应寄存器赋值即可。 ;all interrupt disable
具体的可以看2410的数据手册。 ldr r0,=INTMSK
为中断源比较多,所以它的控制起来会显得复杂一些。 ldr r1,=0xffffffff
您可能关注的文档
最近下载
- 电气联锁保护培训课件.pptx VIP
- 视觉引导类应用总结( 包含详细的旋转中心计算公式).pptx VIP
- 鲁棒控制-01.ppt VIP
- 第一单元-第2课-《国色之韵》课件+-2025—2026学年+人教版(2024)初中美术八年级上册.pptx VIP
- 中医康复技术专业专业自评报告.docx VIP
- 断路器及GIS多型号液压操动机构动作原理及故障处理方法.pptx
- 水质石油类的测定紫外分光光度法.pdf VIP
- 北师大版五年级上册数学第一单元测试卷.doc VIP
- GB50974-2014 消防给水及消火栓系统技术规范.docx
- 2024年高考作文哲思化写作素材4 ——《西方现代思想讲义》(弗洛伊德、萨特).docx VIP
文档评论(0)