- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第五章 Cortex-M0体系结构5.1 操作模式和状态5.2 寄存器5.3 栈指针和栈的操作5.4 异常与中断5.5 程序映像和启动流程5.6 指令集简介5.1 操作模式和状态Cortex-M0处理器包含2种状态:Thumb状态、调试状态2种操作模式:线程模式、异常处理模式Cortex-M0处理器的2种状态Thumb状态处理器正常运行的状态在这种状态下,处理器可以处于线程模式或异常处理模式调试状态处理器内核被暂停,仅用于调试操作调试器读取和改写内核寄存器、也能访问存储器Cortex-M0处理器的2种模拟线程模式执行正常运行的代码可以选择使用“影子”栈指针异常处理模式执行异常处理代码5.2 Cortex-M0处理器的寄存器寄存器:通用寄存器:数据处理过程中暂存数据16(13)个通用寄存器load-store:数据先从内存加载到寄存器再运算,结果写回存储器寄存减少了内存的访问次数和性能要求专用寄存器:赋予特殊的功能或操作方式控制处理器的工作状态5.2 Cortex-M0处理器的寄存器通用寄存器都是32位,系统上电后初始值不确定可以用作指令的源操作数和目的操作数可用load、store指令与内存交换数据R0~R12完全用来运算过程中暂存数据R0~R7又称作低寄存器(low register)通用寄存器R13,栈指针(SP)用于对栈空间存取操作(PUSH、POP指令)对应R13(SP)有两个物理寄存器:主栈指针MSP进程栈指针PSPMSP的初始值来自程序映像中特殊位置的值通用寄存器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和硬件错误异常)5.3 程序运行的重要数据结构:栈“栈”,存储货物或供旅客住宿的地方, 引申为仓库、中转站。引入到计算机领域里,就是指数据暂时存储的地方,所以才有进栈、出栈的说法。是一种存储器使用方式,用作临时数据存储后入先出向栈中存储数据叫做“压栈”(PUSH),从栈里取出数据叫做“弹栈”(POP)程序运行的重要数据结构:栈Cortex-M0使用“满递减”模型向下生长,指针指向最后一个数据执行数据存储前,先减小栈指针的值,……栈指针(SP,R13)用作追踪最“新”的元素程序运行的重要数据结构:栈PUSH和POP通常成对地出现在子程序的开始和结尾处寄存器+栈,构成了程序工作数据子集压栈、弹栈的最小单位是4字节(32位)具有操作系统的应用中,操作系统内核使用MSP,应用程序使用PSP5.4 异常与中断异常是指处理器执行中遇到“未预料”的情况,引起程序控制流的变化异常事件可以是处理器内部产生的也可以是外部输入的。其中,中断是来自外设的请求事件异常发生时,处理器停止当前的任务,转而执行“紧急预案”——异常处理程序异常处理程序存在于程序映像中异常处理完再返回到之前被中断的程序ARM Cortex-M0的异常中断(Interrupt)中断是来自外设的请求事件通常需要一个中断控制器管理多个中断来源中断(Interrupt)Cortex-M0 集成了NVIC (Nested Vectored Interrupt Controller)中断(Interrupt)——NVIC中断(Interrupt)(Interrupt Latency) 中断延迟是指从硬件中断发生到开始执行中断处理程序第一条指令之间的这段时间。也就是:计算机接收到中断信号到操作系统作出响应,并完成换到转入中断服务程序的时间。通俗地表述为:(外部)硬件(设备)发生中断,到系统执行中断服务子程序(ISR)的第一条指令的时间。中断延迟=关中断的最长时间+开始执行中断服务程序第1条指令的时间ARM Cortex-M0的异常处理流程异常向量表处理器在响应异常处理请求时,需要首先确定异常处理的程序的起始地址,这些地址信息集合叫做异常向量表。ARM Cortex-M0的异常处理流程异常进入状态保存:寄存器入栈R0-R3,R12、
您可能关注的文档
- 土木工程课程设计结构计算书全解.doc
- 国学与企业文化(辛杰).ppt
- 国学之成语典故.pptx
- 国学智慧2016.docx
- 国有土地房屋征收与补偿格式文书.doc
- 哈尔滨—创建文明城市中学主题班会.ppt
- 土钉墙施工方案全解.doc
- 土顶施工方案全解.doc
- 哈尔滨工业大学-流体力学课件.ppt
- 土鸡蛋渠道设计全解.ppt
- 2025至2030中国移动治疗台行业发展研究与产业战略规划分析评估报告.docx
- 2025至2030链激酶行业细分市场及应用领域与趋势展望研究报告.docx
- 2025至2030爆炸物探测扫描仪行业市场占有率及有效策略与实施路径评估报告.docx
- 2025至2030四川省智能制造行业细分市场及应用领域与趋势展望研究报告.docx
- 2026届高三二轮复习试题政治大单元突破练1生产资料所有制与分配制度含解析.docx
- 2026届高三二轮复习试题政治大单元突破练16哲学基本思想与辩证唯物论含解析.docx
- 2026届高三二轮复习试题政治大单元突破练2社会主义市场经济体制含解析.docx
- 浙江省衢州市五校联盟2025-2026学年高二上学期期中联考技术试题-高中信息技术含解析.docx
- 浙江省金丽衢十二校2026届高三上学期11月联考政治试题含解析.docx
- 2026届高三二轮复习试题政治大单元突破练7领导力量:中国共产党的领导含解析.docx
原创力文档


文档评论(0)