- 1、本文档共49页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
5.1 操作模式和状态
5.2 寄存器
5.3 栈指针和栈的操作
5.4 异常与中断
5.5 程序映像和启动流程
5.6 指令集简介
第五章 Cortex-M0体系结构
Cortex-M0处理器包含
2种状态:Thumb状态、调试状态
2种操作模式:线程模式、异常处理模式
5.1 操作模式和状态
Cortex-M0处理器的2种状态
Thumb状态
处理器正常运行的状态
在这种状态下,处理器可以处于线程模式或异常处理模式
调试状态
处理器内核被暂停,仅用于调试操作
调试器读取和改写内核寄存器、也能访问存储器
Cortex-M0处理器的2种模拟
线程模式
执行正常运行的代码
可以选择使用“影子”栈指针
异常处理模式
执行异常处理代码
寄存器:
通用寄存器:数据处理过程中暂存数据
16(13)个通用寄存器
load-store:数据先从内存加载到寄存器再运算,结果写回存储器
寄存减少了内存的访问次数和性能要求
专用寄存器:
赋予特殊的功能或操作方式
控制处理器的工作状态
5.2 Cortex-M0处理器的寄存器
5.2 Cortex-M0处理器的寄存器
都是32位,系统上电后初始值不确定
可以用作指令的源操作数和目的操作数
可用load、store指令与内存交换数据
R0~R12完全用来运算过程中暂存数据
R0~R7又称作低寄存器(low register)
通用寄存器
R13,栈指针(SP)
用于对栈空间存取操作(PUSH、POP指令)
对应R13(SP)有两个物理寄存器:
主栈指针MSP
进程栈指针PSP
MSP的初始值来自程序映像中特殊位置的值
通用寄存器
R14,链接寄存器(LR)
存储子程序调用的返回地址
发生异常时,LR用来实现正确的异常返回
Cortex-M0的指令地址始终是偶数(最低位为0),但为了指明当前处于Thumb状态,一些指令要求地址值最低位为1!
通用寄存器
R15,程序计数器(PC)
用来指向正在“取指”的地址
读:值为当前正在执行指令的地址加上4写:导致程序跳转执行
通用寄存器
xPSR程序状态寄存器
应用程序状态寄存器(APSR)
中断程序状态寄存器(IPSR)
执行程序状态寄存器(EPSR)
PRIMASK:中断屏蔽特殊寄存器
CONTROL:控制寄存器
专用寄存器
xPSR程序状态寄存器
应用程序状态寄存器(APSR)
中断程序状态寄存器(IPSR)
执行程序状态寄存器(EPSR)
专用寄存器
CONTROL:控制寄存器
只有一个有效位,选择使用MSP还是PSP
专用寄存器
PRIMASK:中断屏蔽特殊寄存器
只有一个有效位,置位后屏蔽中断(除了NMI和硬件错误异常)
专用寄存器
“栈”,存储货物或供旅客住宿的地方, 引申为仓库、中转站。引入到计算机领域里,就是指数据暂时存储的地方,所以才有进栈、出栈的说法。
是一种存储器使用方式,用作临时数据存储
后入先出
向栈中存储数据叫做“压栈”(PUSH),从栈里取出数据叫做“弹栈”(POP)
5.3 程序运行的重要数据结构:栈
Cortex-M0使用“满递减”模型
向下生长,指针指向最后一个数据
执行数据存储前,先减小栈指针的值,……
栈指针(SP,R13)用作追踪最“新”的元素
程序运行的重要数据结构:栈
PUSH和POP通常成对地出现在子程序的开始和结尾处
寄存器+栈,构成了程序工作数据子集
压栈、弹栈的最小单位是4字节(32位)
具有操作系统的应用中,操作系统内核使用MSP,应用程序使用PSP
程序运行的重要数据结构:栈
异常是指处理器执行中遇到“未预料”的情况,引起程序控制流的变化
异常事件可以是处理器内部产生的也可以是外部输入的。其中,中断是来自外设的请求事件
异常发生时,处理器停止当前的任务,转而执行“紧急预案”——异常处理程序
异常处理程序存在于程序映像中
异常处理完再返回到之前被中断的程序
5.4 异常与中断
ARM Cortex-M0的异常
中断是来自外设的请求事件
通常需要一个中断控制器管理多个中断来源
中断(Interrupt)
Cortex-M0 集成了NVIC (Nested Vectored Interrupt Controller)
中断(Interrupt)
中断(Interrupt)——NVIC
(Interrupt Latency) 中断延迟
是指从硬件中断发生到开始执行中断处理程序第一条指令之间的这段时间。也就是:计算机接收到中断信号到操作系统作出响应,并完成换到转入中断服务程序的时间。
通俗地表述为:(外部)硬件(设备)发生中断,到系统执行中断服务子程序(ISR)的第一条指令的时间。
中断延迟=关中断的最长时间+开始执行中断服务程序第1条指令的时间
中
文档评论(0)