- 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微处理器支持程序状态寄存器访问指令,用于在程序状态寄存器和通用寄存器之间传送数据,程序状态寄存器访问指令包括以下两条: MRS 程序状态寄存器到通用寄存器的数据传送指令 MSR 通用寄存器到程序状态寄存器的数据传送指令 程序状态寄存器(PSR)处理指令 MRS/MSR MRS 状态寄存器的内容读取到通用寄存器 MSR 立即数或通用寄存器内容写到状态寄存器的指定区域 MSR {cond} PSR_fields, #immed_8r MSR {cond} PSR_fields, rm fields: c 控制域(PSR[7:0]) x 扩展域(PSR[15:8]) s 状态域(PSR[23:16]) f 标志域(PSR[31:24]) MRS指令 MRS指令的格式为: MRS{条件} 通用寄存器,程序状态寄存器(CPSR或SPSR) MRS指令用于将程序状态寄存器的内容传送到通用寄存器中。该指令一般用在以下几种情况: 当需要改变程序状态寄存器的内容时,可用MRS将程序状态寄存器的内容读入通用寄存器,修改后再写回程序状态寄存器。 当在异常处理或进程切换时,需要保存程序状态寄存器的值,可先用该指令读出程序状态寄存器的值,然后保存。 MRS R0,CPSR MRS R0,SPSR MSR指令 MSR指令的格式为: MSR{条件} 程序状态寄存器(CPSR或SPSR)_域,操作数 MSR指令用于将操作数的内容传送到程序状态寄存器的特定域中。其中,操作数可以为通用寄存器或立即数。域用于设置程序状态寄存器中需要操作的位,32位的程序状态寄存器可分为4个域: 位[31:24]为条件标志位域,用f表示; 位[23:16]为状态位域,用s表示; 位[15:8]为扩展位域,用x表示; 位[7:0]为控制位域,用c表示; 该指令通常用于恢复或改变程序状态寄存器的内容,在使用时,一般要在MSR指令中指明将要操作的域。 MSR CPSR,R0 MSR CPSR_c,R0 加载/存储指令及批量数据加载/存储指令 ARM微处理器支持加载/存储指令用于在寄存器和存储器之间传送数据,加载指令用于将存储器中的数据传送到寄存器,存储指令则完成相反的操作。常用的加载存储指令如下: LDR 字数据加载指令 LDRB 字节数据加载指令 LDRH 半字数据加载指令 STR 字数据存储指令 STRB 字节数据存储指令 STRH 半字数据存储指令 LDM 批量数据加载指令 STM 批量数据存储指令 加载/存储指令(LDR/STR/LDM/STM)的寻址方式 LDR/STR:采用寄存器间接寻址和基变址寻址的方式 零偏移; LDR r0, [r1] STR r0, [r1] 程序相对偏移; LDR r0, =0后索引偏移; LDR r0, [r13], #0x04 ;[r13]-r0, r13+=0x04 STR r1, [r13], #0x04 ;[r13]-r1, r13+=0x04 前索引偏移; OP{cond} Rd, [Rn, offset] {!} Offset 就是数据处理指令中的第二操作数; !为一个可选的后缀,即是否修改Rn Rn为R15时不能选择该后缀; LDR r0, [r1, #0x04] ;[r1+0x04]-r0 LDR r0, [r1, #0x04]! ;[r1+0x04]-r0, r1+=0x04 STR r0, [r1, r2, ASR #0x04]! ;r0-[r1+r2/16], r1+=r2/16 LDM/STM可以传送R0-R15的任意组合 OP {cond} mode Rn{!}, reglist{^} mode: IA 每次传送后地址加1 FD 满递减堆栈 IB 每次传送前地址加1 ED 空递减堆栈 DA 每次传送后地址减1 FA 满递增堆栈 DB 每次传送前地址减1 EA 空递增堆栈 LDR指令 LDR指令的格式为: LDR{条件} 目的寄存器,存储器地址 LDR指令用于从存储器中将一个32位的字数据传送到目的寄存器中。该指令通常用于从存储器中读取32位的字数据到通用寄存器,然后对数据进行处理。当程序计数器PC作为目的寄存器时,指令从存储器中读取的字数据被当作目的地址,从而可以实现程序流程的跳转。该指令在程序设计中比较常用,且寻址方式灵活多样,请读者认真掌握。 LDR R0,[R1] LDR R0,[R1,R2] LDR R0,[R1,#8] LDR R0,[R1,R2] !
您可能关注的文档
最近下载
- 2025版《煤矿安全规程》宣贯培训课件.pptx VIP
- 2025年中国石油数智研究院秋季高校毕业生招聘60人笔试上岸历年真考点题库附带答案详解.doc
- 变电所改造工程施工方案(3篇).docx VIP
- 欧洲标准化委员化BS EN 10283 - 2010.pdf VIP
- 2025年中国石油数智研究院招聘笔试备考题库(带答案详解).pdf
- 期末模拟质量检测卷-2024-2025学年统编版语文三年级上册.docx VIP
- 山东省建筑施工企业安全生产管理人员安全生产知识考试题库(含答案).pdf VIP
- 城市规划设计计费(2004)中规协秘字第022号.pdf VIP
- 数据库原理及应用教程(MySQL版)全套教学课件.pptx VIP
- 关爱困境儿童让爱守护成长PPT模板.pptx VIP
文档评论(0)