刘帅嵌入式系统-MSR指令

2023-11-24 17:50

本文主要是介绍刘帅嵌入式系统-MSR指令,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MSR指令用于将通用寄存器的内容或一个立即数传送到状态寄存器中。

指令的编码格式

指令的源操作数为通用寄存器时,指令编码格式如下:
在这里插入图片描述

指令的源操作数为立即数时,指令编码格式如下:

指令的语法格式

MSR{< cond >} CPSR_< fields >, #< immediate >

MSR{< cond >} CPSR_< fields >, < Rm >

MSR{< cond >} SPSR_< fields >, #< immediate >

MSR{< cond >} SPSR_< fields >, < Rm>

其中:

  • < fields >设置状态寄存器中需要操作的位。状态寄存器的32位可以分为4个8位的域:bits[31:24]为条件标志位域,用f表示;bit[23:16]为状态域,用s表示;bit[15:8]为扩展域,用x表示;bit[7:0]为控制位域,用c表示。
  • < immediate >为将要传送到状态寄存器中的立即数,该立即数的计算方法在之前已经介绍。
  • < Rm >寄存器包含将要传送到状态寄存器中的数据。

指令操作的伪代码

if ConditionPassed(cond) thenif opcode[25] == 1operand = 8_bit_immediate Rotate_Right (rotate_imm *2)else /* opcode[25] == 0 */operand = Rmif R == 0 thenif field_mask[0] == 1 and InAPrivilegedMode() thenCPSR[7:0] = operand[7:0]if field_mask[1] == 1 and InAPrivilegedMode() thenCPSR[15:8] = operand[15:8]if field_mask[2] == 1 and InAPrivilegedMode() thenCPSR[23:16] = operand[23:16]if field_mask[3] == 1CPSR[31:24] = operand[31:24]else /* R == 1 */if field_mask[0] == 1 and CurrentModeHasSPSR() thenCPSR[7:0] = operand[7:0]if field_mask[1] == 1 and CurrentModeHasSPSR() thenCPSR[15:8] = operand[15:8]if field_mask[2] == 1 and CurrentModeHasSPSR() thenCPSR[23:16] = operand[23:16]if field_mask[3] == 1 and CurrentModeHasSPSR() thenCPSR[31:24] = operand[31:24]

指令的使用

MSR指令通常用于恢复状态寄存器的内容或者改变状态寄存器的内容。

当退出异常中断处理程序时,如果事先保存了状态寄存器的内容(如在嵌套的异常中断处理中)通常通过MSR指令将事先保存的状态寄存器内容恢复到状态寄存器中。

当需要修改状态寄存器的内容时,通过"读出-修改-写回"指令序列完成。写回操作也是通过MSR指令完成的。

考虑到指令执行的效率,通常在MSR指令中指定指令将要修改的位域。例如,下面的指令序列将处理器模式切换到特权模式,这里只修改状态寄存器的控制位域,所以在指令中指定该位域。

MRS R0,CPSR     ;读取CPSR
BIC R0,R0,#0x1F ;修改,去除当前处理器模式
ORR R0,R0,#0x13 ;修改,设置特权模式
MSR CPSR_c, R0  ;写回,仅仅修改CPSR中的控制位域

但是,当进程切换到应用场合时,应指定SPSR_fsxc,这样,将来ARM扩展了当前未用的一些位后,程序还可以正常运行。

当欲修改的状态寄存器位域中包含未分配的位时,最好不要使用立即数方式的MSR指令。一个例外的情况是,可以使用立即数方式的MSR指令修改状态寄存器中的条件标志位位域。

这篇关于刘帅嵌入式系统-MSR指令的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/shuai532209720/article/details/90301894
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/422342

相关文章

ubuntu20.0.4系统中安装Anaconda的超详细图文教程

《ubuntu20.0.4系统中安装Anaconda的超详细图文教程》:本文主要介绍了在Ubuntu系统中如何下载和安装Anaconda,提供了两种方法,详细内容请阅读本文,希望能对你有所帮助... 本文介绍了在Ubuntu系统中如何下载和安装Anaconda。提供了两种方法,包括通过网页手动下载和使用wg

ubuntu系统使用官方操作命令升级Dify指南

《ubuntu系统使用官方操作命令升级Dify指南》Dify支持自动化执行、日志记录和结果管理,适用于数据处理、模型训练和部署等场景,今天我们就来看看ubuntu系统中使用官方操作命令升级Dify的方... Dify 是一个基于 docker 的工作流管理工具,旨在简化机器学习和数据科学领域的多步骤工作流。

使用Python和SQLAlchemy实现高效的邮件发送系统

《使用Python和SQLAlchemy实现高效的邮件发送系统》在现代Web应用中,邮件通知是不可或缺的功能之一,无论是订单确认、文件处理结果通知,还是系统告警,邮件都是最常用的通信方式之一,本文将详... 目录引言1. 需求分析2. 数据库设计2.1 User 表(存储用户信息)2.2 CustomerO

Linux系统调试之ltrace工具使用与调试过程

《Linux系统调试之ltrace工具使用与调试过程》:本文主要介绍Linux系统调试之ltrace工具使用与调试过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、ltrace 定义与作用二、ltrace 工作原理1. 劫持进程的 PLT/GOT 表2. 重定

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

嵌入式Linux之使用设备树驱动GPIO的实现方式

《嵌入式Linux之使用设备树驱动GPIO的实现方式》:本文主要介绍嵌入式Linux之使用设备树驱动GPIO的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、设备树配置1.1 添加 pinctrl 节点1.2 添加 LED 设备节点二、编写驱动程序2.1

嵌入式Linux驱动中的异步通知机制详解

《嵌入式Linux驱动中的异步通知机制详解》:本文主要介绍嵌入式Linux驱动中的异步通知机制,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、异步通知的核心概念1. 什么是异步通知2. 异步通知的关键组件二、异步通知的实现原理三、代码示例分析1. 设备结构

Windows系统宽带限制如何解除?

《Windows系统宽带限制如何解除?》有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文就跟大家一起来看看Windows系统解除网络限制的操作方法吧... 有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设

电脑找不到mfc90u.dll文件怎么办? 系统报错mfc90u.dll丢失修复的5种方案

《电脑找不到mfc90u.dll文件怎么办?系统报错mfc90u.dll丢失修复的5种方案》在我们日常使用电脑的过程中,可能会遇到一些软件或系统错误,其中之一就是mfc90u.dll丢失,那么,mf... 在大部分情况下出现我们运行或安装软件,游戏出现提示丢失某些DLL文件或OCX文件的原因可能是原始安装包