- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ARM的启动过程及睡眠模式
作者:尹纪平 2011-3-12 Page. 1
ARM 的启动过程
1、 初始化中断
在程序的开始(即:地址为 0)存放的是中断向量表。这个是固定的不能改的。向量表的入口是一些跳转指令,跳到
专门的处理异常或中断的子程序。这个程序地址是处理器自己寻找的,注意的处理器寻找的是 CP 的偏移量,而不是物理地址。
硬件规定存放是这样的
说明一点,这个和我们 PC 不同,intel 的是把这个入口地址写到相应的寄存器中了。当然有些处理器还可以把偏移量到 0xfff0000\
的高地址去。
b HandlerUndef ;handler for Undefined mode
b HandlerSWI ;handler for SWI interrupt
b HandlerPabort ;handler for PAbort
b HandlerDabort ;handler for DAbort
b . ;reserved
b HandlerIRQ ;handler for IRQ interrupt
b HandlerFIQ ;handler for FIQ interrupt
;@0x20
b EnterPWDN ; Must be @0x20.
每个处理中断的程序,实际上还要中转一次 查询中断地址表,才真正跳转过去。
注意的一点就是当发生 IRQ 中断的时候,他会跳转到IRQ 的地址去执行,但是这个IRQ 的地址存放的是 IsrIRQ 的地址
实际上是 ARM 把所有的中断都定义成了 IRQ 或者 FIQ.我们知道了中断是 IRQ 或者是 FIQ
但是具体哪个设备发出的中断呢?就是 IsrIRQ 的作用了。从INTOFFSET 寄存器里边就能找到。;INTOFFSET 中断偏移寄存器
显示哪个 IRQ 模式的中断请求在 INTPND 寄存器中,
INTPND 中断未决寄存器,他在优先级逻辑当中,所以只有一位可以值 1
真正的设备中断处理程序的地址 =[ IRQ + INTOFFSET]
在数据区,我们设置一块结构化的内存表,存放各种中断的地址。我们把它叫做中断地址表。
他的大小是 160Bytes(40 个项,每项 4 个字节) 他的起始地址是:0x33FF_FF00
其中一般中断 IRQ,是第六项(第 0 项是复位 Reset ) 偏移 24 字节,从第 8 项开始 存放就是 IRQ 的各种各样的子中断地址。
上电的第一条指令,就是复位中断处理程序。
2、 复位中断处理程序
① 关看门狗(=WTCON ) --
② 屏蔽所以中断(=INTMSK ) --
③ 屏蔽所有的次中断 IRQ 中断(=INTSUBMSK )--
作者:尹纪平 2011-3-12 Page.2
④ 调整 LOCKTIME 寄存器 --
⑤ Fclk:Hclk:Pclk 时钟分配比率(这里还有一步总线选择异步模式才算完成)CLKDIVN 5=1:4:8
⑥ 设置 UPLL ,Fin = 12.0MHz, UCLK = 48MHz ,计算好MDIV,PDIV,SDIV 写进去 UPLLCON
⑦ 设置 MPLL ,Fin = 12.0MHz, UCLK = 400MHz ,计算好MDIV,PDIV,SDIV 写进去 MPLLCON
下面就要判断导成重启的原因。
应该在一个叫做 GSTATUS2 寄存器里边,来判断 Reset 的原因。具体是这样的。
WDTRST [2] Boot is caused by Watch Do
文档评论(0)