MRS / MSR指令

时间: 2024-01-04 08:20:38 浏览: 231
MRS和MSR是ARM处理器中的指令,用于在状态寄存器和通用寄存器之间传输数据。 MRS指令用于将状态寄存器的值传输到通用寄存器中。它的语法如下: ``` MRS Rd, Psr ``` 其中,Rd是目标通用寄存器,Psr是要传输的状态寄存器。例如,MRS指令可以将CPSR(当前程序状态寄存器)的值传输到R0寄存器中。 MSR指令用于将通用寄存器的值传输到状态寄存器中。它的语法如下: ``` MSR Psr, Operand2 ``` 其中,Psr是目标状态寄存器,Operand2是要传输的操作数。例如,MSR指令可以将R0寄存器的值传输到CPSR中。 需要注意的是,MRS和MSR指令只能在特权模式下执行,不能在用户模式下执行。此外,MRS指令不能用于访问SPSR(保存的程序状态寄存器)。
相关问题

实验内容 (1) 使用 MRS/MSR 指令切换工作模式,并初始化各种模式下堆栈指针; (2) 观察 ARM 处理器在各种模式下寄存器的区别。

1. 使用 MRS/MSR 指令切换工作模式,并初始化各种模式下堆栈指针: ARM 处理器有 7 种工作模式:User Mode、FIQ Mode、IRQ Mode、Supervisor Mode、Abort Mode、Undefined Mode 和 System Mode。在不同的工作模式下,处理器所能使用的寄存器和堆栈指针也不同。因此,切换工作模式时需要使用 MRS/MSR 指令来保存和恢复寄存器和堆栈指针。 下面是在不同工作模式下切换并初始化堆栈指针的示例代码: ``` main: MRS R0, CPSR ;读取当前程序状态寄存器(CPSR) BIC R0, R0, #0x1F ;将最低 5 位清零,以便设置新的工作模式 ORR R0, R0, #0x10 ;设置为 Supervisor Mode MSR CPSR_c, R0 ;切换工作模式 MOV SP, #0x8000 ;初始化 Supervisor Mode 下的堆栈指针 SRS #0x13 ;进入中断处理程序,自动切换到 IRQ Mode irq_handler: MOV SP, #0x9000 ;初始化 IRQ Mode 下的堆栈指针 …… RFE ;从中断处理程序返回,自动切换到 Supervisor Mode MOV SP, #0x8000 ;恢复 Supervisor Mode 下的堆栈指针 MRS R0, CPSR ;读取当前程序状态寄存器 BIC R0, R0, #0x1F ;将最低 5 位清零,以便设置新的工作模式 ORR R0, R0, #0x1F ;设置为 System Mode MSR CPSR_c, R0 ;切换工作模式 MOV SP, #0x10000 ;初始化 System Mode 下的堆栈指针 …… ``` 2. 观察 ARM 处理器在各种模式下寄存器的区别: 在不同的工作模式下,ARM 处理器所能使用的寄存器和堆栈指针也不同。下面是各种工作模式下 ARM 处理器的寄存器和堆栈指针的区别: - User Mode:可以使用所有的寄存器和堆栈指针。 - FIQ Mode:可以使用所有的寄存器和堆栈指针,但需要额外的 7 个 FIQ 寄存器来保存 FIQ 中断处理程序的状态和数据。 - IRQ Mode:可以使用所有的寄存器和堆栈指针,但需要额外的 2 个 IRQ 寄存器来保存 IRQ 中断处理程序的状态和数据。 - Supervisor Mode:可以使用所有的寄存器和堆栈指针,但需要额外的 2 个 Supervisor 寄存器来保存 Supervisor 模式下的状态和数据。 - Abort Mode:可以使用所有的寄存器和堆栈指针,但需要额外的 2 个 Abort 寄存器来保存 Abort 模式下的状态和数据。 - Undefined Mode:可以使用所有的寄存器和堆栈指针,但只能使用部分的 ARM 指令和没有定义的指令。 - System Mode:可以使用所有的寄存器和堆栈指针,但不能使用所有的协处理器指令。 因此,在编写 ARM 汇编程序时,需要根据不同的工作模式来选择合适的寄存器和堆栈指针,并注意不同工作模式下的指令限制和特点。

ARM汇编指令MRS 和MSR代码

MRS指令用于将特定系统寄存器的值移动到通用寄存器中,而MSR指令用于将通用寄存器的值移动到特定系统寄存器中。 以下是MRS和MSR的示例代码: MRS R0, CPSR ;将CPSR寄存器的值移动到R0通用寄存器中 MSR CPSR_cxsf, #0x10 ;将CPSR寄存器的cxsf位设置为0x10

相关推荐

解释嵌入式代码USR_STACK_LEGTH EQU 64 SVC_STACK_LEGTH EQU 0 FIQ_STACK_LEGTH EQU 16 IRQ_STACK_LEGTH EQU 64 ABT_STACK_LEGTH EQU 0 UND_STACK_LEGTH EQU 0 AREA Example5,CODE,READONLY ; 声明代码段Example5 ENTRY ; 标识程序入口 CODE32 ; 声明32位ARM指令 START MOV R0,#0 MOV R1,#1 MOV R2,#2 MOV R3,#3 MOV R4,#4 MOV R5,#5 MOV R6,#6 MOV R7,#7 MOV R8,#8 MOV R9,#9 MOV R10,#10 MOV R11,#11 MOV R12,#12 BL InitStack ; 初始化各模式下的堆栈指针 ; 打开IRQ中断 (将CPSR寄存器的I位清零) MRS R0,CPSR ; R0 <= CPSR BIC R0,R0,#0x80 MSR CPSR_cxsf,R0 ; CPSR <= R0 ; 切换到用户模式 MSR CPSR_c, #0xd0 MRS R0,CPSR ; 切换到管理模式 MSR CPSR_c, #0xdf MRS R0,CPSR HALT B HALT ; 堆栈初始化 InitStack MOV R0, LR ; R0 <= LR,因为各种模式下R0是相同的 MSR CPSR_c, #0xd3 ;设置管理模式堆栈 LDR SP, StackSvc MSR CPSR_c, #0xd2 ;设置中断模式堆栈 LDR SP, StackIrq MSR CPSR_c, #0xd1 ;设置快速中断模式堆栈 LDR SP, StackFiq MSR CPSR_c, #0xd7 ;设置中止模式堆栈 LDR SP, StackAbt MSR CPSR_c, #0xdb ;设置未定义模式堆栈 LDR SP, StackUnd MSR CPSR_c, #0xdf ;设置系统模式堆栈 LDR SP, StackUsr MOV PC, R0 StackUsr DCD UsrStackSpace + (USR_STACK_LEGTH - 1)*4 StackSvc DCD SvcStackSpace + (SVC_STACK_LEGTH - 1)*4 StackIrq DCD IrqStackSpace + (IRQ_STACK_LEGTH - 1)*4 StackFiq DCD FiqStackSpace + (FIQ_STACK_LEGTH - 1)*4 StackAbt DCD AbtStackSpace + (ABT_STACK_LEGTH - 1)*4 StackUnd DCD UndtStackSpace + (UND_STACK_LEGTH - 1)*4 ; 分配堆栈空间 AREA MyStacks, DATA, NOINIT, ALIGN=2 UsrStackSpace SPACE USR_STACK_LEGTH * 4 ; 用户(sys)模式堆栈SvcStackSpace SPACE SVC_STACK_LEGTH * 4 ; 管理模式堆栈空间 IrqStackSpace SPACE IRQ_STACK_LEGTH * 4 ; 中断模式堆栈空间 FiqStackSpace SPACE FIQ_STACK_LEGTH * 4 ; 快速中断模式堆栈空间 AbtStackSpace SPACE ABT_STACK_LEGTH * 4 ; 中止义模式堆栈空间 UndtStackSpace SPACE UND_STACK_LEGTH * 4 ; 未定义模式堆栈 END

最新推荐

recommend-type

常用ARM指令集及汇编.pdf

MRS 32 MSR 33 ARM 伪指令34 ADR 35 ADRL35 LDR36 NOP37 Thumb 指令集39 Thumb 指令集与 ARM 指令集的区别 39 Thumb 存储器访问指令 40 LDR 和 STR 41 PUSH 和 POP 43 LDMIA 和 STMIA 43 Thumb...
recommend-type

ARM的V4、V5版本的区别

ARM作为独立的公司,在1990年设计的第一个微处理器采用的是版本3的ARM6。它作为IP核、独立的处理器、具有片上高速缓存、MMU和写...增加了MRS/MSR指令,以访问新增的CPSR/SPSR寄存器;增加了从异常处理返回的指令功能。
recommend-type

FreeRTOS任务切换流程说明

mrs r0, psp /* PSP 内容存入 R0 */ isb /* 指令同步隔离,清流水线 */ ldr r3, =pxCurrentTCB /* 当前激活的任务 TCB 指针存入 R2 */ ldr r2, [r3] stmdb r0!, {r4-r11} /* 保存剩余的寄存器,异常处理程序执行...
recommend-type

基于stm32+FreeRTOS+ESP8266的实时天气系统

【作品名称】:基于stm32+FreeRTOS+ESP8266的实时天气系统 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【项目介绍】:项目简介 基于stm32F407+FreeRTOS+ESP8266的实时气象站系统,通过物联网技术实时读取天气情况,温度以及自带了一个计时功能。 所需设备 stm32F407,淘晶驰串口屏,ESP8266; 串口屏连接串口3,ESP8266连接串口2,串口1用于打印状态。 实现过程 通过对ESP8266发送AT指令,从服务器读取天气的json数据,然后通过cJSON解码数据,最后FreeRTOS对任务进行管理(FreeRTOS和cJSON有冲突,需要将cJSON申请内存空间的函数替换成FreeRTOS申请内存的函数,每次解码后,一定要释放内存,否则解码会卡死,而且需要把Heap_size设置稍微大一点,推荐设置为4096)
recommend-type

基于嵌入式ARMLinux的播放器的设计与实现 word格式.doc

本文主要探讨了基于嵌入式ARM-Linux的播放器的设计与实现。在当前PC时代,随着嵌入式技术的快速发展,对高效、便携的多媒体设备的需求日益增长。作者首先深入剖析了ARM体系结构,特别是针对ARM9微处理器的特性,探讨了如何构建适用于嵌入式系统的嵌入式Linux操作系统。这个过程包括设置交叉编译环境,优化引导装载程序,成功移植了嵌入式Linux内核,并创建了适合S3C2410开发板的根文件系统。 在考虑到嵌入式系统硬件资源有限的特点,通常的PC机图形用户界面(GUI)无法直接应用。因此,作者选择了轻量级的Minigui作为研究对象,对其实体架构进行了研究,并将其移植到S3C2410开发板上,实现了嵌入式图形用户界面,使得系统具有简洁而易用的操作界面,提升了用户体验。 文章的核心部分是将通用媒体播放器Mplayer移植到S3C2410开发板上。针对嵌入式环境中的音频输出问题,作者针对性地解决了Mplayer播放音频时可能出现的不稳定性,实现了音乐和视频的无缝播放,打造了一个完整的嵌入式多媒体播放解决方案。 论文最后部分对整个项目进行了总结,强调了在嵌入式ARM-Linux平台上设计播放器所取得的成果,同时也指出了一些待改进和完善的方面,如系统性能优化、兼容性提升以及可能的扩展功能等。关键词包括嵌入式ARM-Linux、S3C2410芯片、Mplayer多媒体播放器、图形用户界面(GUI)以及Minigui等,这些都反映出本文研究的重点和领域。 通过这篇论文,读者不仅能了解到嵌入式系统与Linux平台结合的具体实践,还能学到如何在资源受限的环境中设计和优化多媒体播放器,为嵌入式技术在多媒体应用领域的进一步发展提供了有价值的经验和参考。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

Python字符串为空判断的动手实践:通过示例掌握技巧

![Python字符串为空判断的动手实践:通过示例掌握技巧](https://img-blog.csdnimg.cn/72f88d4fc1164d6c8b9c29d8ab5ed75c.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBASGFyYm9yIExhdQ==,size_20,color_FFFFFF,t_70,g_se,x_16) # 1. Python字符串为空判断的基础理论 字符串为空判断是Python编程中一项基本且重要的任务。它涉及检查字符串是否为空(不包含任何字符),这在
recommend-type

box-sizing: border-box;作用是?

`box-sizing: border-box;` 是 CSS 中的一个样式属性,它改变了元素的盒模型行为。默认情况下,浏览器会计算元素内容区域(content)、内边距(padding)和边框(border)的总尺寸,也就是所谓的"标准盒模型"。而当设置为 `box-sizing: border-box;` 后,元素的总宽度和高度会包括内容、内边距和边框的总空间,这样就使得开发者更容易控制元素的实际布局大小。 具体来说,这意味着: 1. 内容区域的宽度和高度不会因为添加内边距或边框而自动扩展。 2. 边框和内边距会从元素的总尺寸中减去,而不是从内容区域开始计算。
recommend-type

经典:大学答辩通过_基于ARM微处理器的嵌入式指纹识别系统设计.pdf

本文主要探讨的是"经典:大学答辩通过_基于ARM微处理器的嵌入式指纹识别系统设计.pdf",该研究专注于嵌入式指纹识别技术在实际应用中的设计和实现。嵌入式指纹识别系统因其独特的优势——无需外部设备支持,便能独立完成指纹识别任务,正逐渐成为现代安全领域的重要组成部分。 在技术背景部分,文章指出指纹的独特性(图案、断点和交叉点的独一无二性)使其在生物特征认证中具有很高的可靠性。指纹识别技术发展迅速,不仅应用于小型设备如手机或门禁系统,也扩展到大型数据库系统,如连接个人电脑的桌面应用。然而,桌面应用受限于必须连接到计算机的条件,嵌入式系统的出现则提供了更为灵活和便捷的解决方案。 为了实现嵌入式指纹识别,研究者首先构建了一个专门的开发平台。硬件方面,详细讨论了电源电路、复位电路以及JTAG调试接口电路的设计和实现,这些都是确保系统稳定运行的基础。在软件层面,重点研究了如何在ARM芯片上移植嵌入式操作系统uC/OS-II,这是一种实时操作系统,能够有效地处理指纹识别系统的实时任务。此外,还涉及到了嵌入式TCP/IP协议栈的开发,这是实现系统间通信的关键,使得系统能够将采集的指纹数据传输到远程服务器进行比对。 关键词包括:指纹识别、嵌入式系统、实时操作系统uC/OS-II、TCP/IP协议栈。这些关键词表明了论文的核心内容和研究焦点,即围绕着如何在嵌入式环境中高效、准确地实现指纹识别功能,以及与外部网络的无缝连接。 这篇论文不仅深入解析了嵌入式指纹识别系统的硬件架构和软件策略,而且还展示了如何通过结合嵌入式技术和先进操作系统来提升系统的性能和安全性,为未来嵌入式指纹识别技术的实际应用提供了有价值的研究成果。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依