刘帅嵌入式系统-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指令的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/422342

相关文章

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

linux重启命令有哪些? 7个实用的Linux系统重启命令汇总

《linux重启命令有哪些?7个实用的Linux系统重启命令汇总》Linux系统提供了多种重启命令,常用的包括shutdown-r、reboot、init6等,不同命令适用于不同场景,本文将详细... 在管理和维护 linux 服务器时,完成系统更新、故障排查或日常维护后,重启系统往往是必不可少的步骤。本文

Mac系统下卸载JAVA和JDK的步骤

《Mac系统下卸载JAVA和JDK的步骤》JDK是Java语言的软件开发工具包,它提供了开发和运行Java应用程序所需的工具、库和资源,:本文主要介绍Mac系统下卸载JAVA和JDK的相关资料,需... 目录1. 卸载系统自带的 Java 版本检查当前 Java 版本通过命令卸载系统 Java2. 卸载自定

Python包管理工具核心指令uvx举例详细解析

《Python包管理工具核心指令uvx举例详细解析》:本文主要介绍Python包管理工具核心指令uvx的相关资料,uvx是uv工具链中用于临时运行Python命令行工具的高效执行器,依托Rust实... 目录一、uvx 的定位与核心功能二、uvx 的典型应用场景三、uvx 与传统工具对比四、uvx 的技术实

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

Linux系统中的firewall-offline-cmd详解(收藏版)

《Linux系统中的firewall-offline-cmd详解(收藏版)》firewall-offline-cmd是firewalld的一个命令行工具,专门设计用于在没有运行firewalld服务的... 目录主要用途基本语法选项1. 状态管理2. 区域管理3. 服务管理4. 端口管理5. ICMP 阻断

Windows 系统下 Nginx 的配置步骤详解

《Windows系统下Nginx的配置步骤详解》Nginx是一款功能强大的软件,在互联网领域有广泛应用,简单来说,它就像一个聪明的交通指挥员,能让网站运行得更高效、更稳定,:本文主要介绍W... 目录一、为什么要用 Nginx二、Windows 系统下 Nginx 的配置步骤1. 下载 Nginx2. 解压

如何确定哪些软件是Mac系统自带的? Mac系统内置应用查看技巧

《如何确定哪些软件是Mac系统自带的?Mac系统内置应用查看技巧》如何确定哪些软件是Mac系统自带的?mac系统中有很多自带的应用,想要看看哪些是系统自带,该怎么查看呢?下面我们就来看看Mac系统内... 在MAC电脑上,可以使用以下方法来确定哪些软件是系统自带的:1.应用程序文件夹打开应用程序文件夹

windows系统上如何进行maven安装和配置方式

《windows系统上如何进行maven安装和配置方式》:本文主要介绍windows系统上如何进行maven安装和配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录1. Maven 简介2. maven的下载与安装2.1 下载 Maven2.2 Maven安装2.