相关文章推荐
深沉的野马  ·  斗罗:师尊无敌,开局收徒朱竹清最新章节在线阅 ...·  3 周前    · 
纯真的围巾  ·  詹杜库先后被击败,爱德华兹宣告登基,森林狼连 ...·  4 月前    · 
精明的手套  ·  惠誉下调玻利维亚信用评级至CCC-·  5 月前    · 
近视的香菜  ·  驻英国大使刘晓明夫人胡平华在英托尔盖特小学孔 ...·  1 年前    · 
光明磊落的登山鞋  ·  Python3 File ...·  1 年前    · 
Code  ›  汇编指令-MRS(读)和MSR(写)指令操作CPSR寄存器和SPSR寄存器使用(1)开发者社区
汇编指令 指令寄存器 数据寄存器 状态寄存器
https://cloud.tencent.com/developer/article/1012120
不要命的帽子
2 年前
作者头像
诺谦
0 篇文章

汇编指令-MRS(读)和MSR(写)指令操作CPSR寄存器和SPSR寄存器使用(1)

前往专栏
腾讯云
开发者社区
文档 意见反馈 控制台
首页
学习
活动
专区
工具
TVP
文章/答案/技术大牛
发布
首页
学习
活动
专区
工具
TVP
返回腾讯云官网
社区首页 > 专栏 > Linux驱动 > 正文

汇编指令-MRS(读)和MSR(写)指令操作CPSR寄存器和SPSR寄存器使用(1)

发布 于 2018-01-03 16:18:11
1.5K 0
举报

1.MSR和MRS指令介绍

MRS 指令:  对状态寄存器CPSR和SPSR进行 读操作 。通过读CPSR可以获得当前处理器的工作状态。读SPSR寄存器可以获得进入异常前的处理器状态(因为只有异常模式下有SPSR寄存器)。

MSR指令:    对状态寄存器CPSR和SPSR进行 写操作 。与MRS配合使用,可以实现对CPSR或SPSR寄存器的读-修改-写操作,可以切换处理器模式、或者允许/禁止IRQ/FIQ中断等。

2.CPSR 程序状态寄存器(current program status register)

如图所示,ARM每种工作模式除R0~R15共16个寄存器外,还有第17个寄存器CPSR,叫做 当前程序状态寄存器

CPSR寄存器格式:

在CPSR寄存器中主要用到了控制位,每个标志位如下图所示:

3.使用MSR指令写入数据

例:        msr cpsr_c, #0xd2       @0xd2=1100 0010            禁止中断使能,进入中断模式

msr cpsr_c, #0x53        @0x53=0101 0011             开IRQ中断,禁止FIQ中断,进入ARM状态,设为管理(svc32)模式

其中cpsr_c是因为CPSR有4个8位区域:

C 控制域屏蔽字节([7:0])

X 扩展域屏蔽字节([15:8])

S 状态域屏蔽字节([23:16])

F 标志域屏蔽字节([31:24])

所以cpsr_c表示的是CPSR控制位、

4.使用MRS和MSR来设置2440位管理模式,实例:

mrs r0,cpsr                          读状态寄存器cpsr的数据到r0中

bic  r0,r0,#0x1f                    对r0低5位进行清0,清除模式位 orr r0,r0,#0xd3                    低8位或(110 10011), 设为管理(svc32)模式,禁止IRQ和FIQ中断 msr cpsr,r0                          写入状态寄存器cpsr,更新。

5.SPSR程序保存状态寄存器(saved program status register)

SPSR用于保存CPSR的状态,以便异常返回后恢复异常发生时的工作状态。当特定的异常中断发生时,这个寄存器用于存放当前程序状态寄存器的内容。在异常中断退出时,可以用SPSR来恢复CPSR。

(注意:用户 user 模式和系统 system 模式不是异常中断模式,所以他没有SPSR。当用户在用户模式或系统模式访问SPSR,将产生不可预知的后果。)

在异常模式返回时,如果指令带有S后缀(除了比较指令以外),同时又以PC为目标寄存器进行操作,则操作的同时从SPSR恢复CPSR。以下都是可以恢复CPSR寄存器

例如:

movs pc, #0xff                                   // cpsr = spsr; pc = 0xff

adds pc, r1, #0xffffff00                       //cpsr = spsr; pc = r1 + 0xffffff00

ands pc, r1, r2                                    // cpsr = spsr; pc = r1 & r2;

ldmia   sp!,    { r0-r12,pc }^                    //  中断返回, ^表示将spsr的值复制到cpsr

点击展开阅读全文
文章分享自:
作者个人站点/博客
本文参与 腾讯云自媒体分享计划 ,欢迎热爱写作的你一起参与!

原始发表:2017-07-01 , 如有侵权请联系 cloudcommunity@tencent.com 删除

汇编语言
登录 后参与评论
关于作者
0
文章
0
累计阅读量
0
获赞
前往专栏
关注 - 腾讯云 开发者 公众号
将获得
10元无门槛代金券
洞察腾讯核心技术
剖析业界实践案例
扫码关注腾讯云开发者
NEW
切换旧版
领券
  • 社区

    • 专栏文章
    • 阅读清单
    • 互动问答
    • 技术沙龙
    • 技术视频
    • 团队主页
    • 腾讯云TI平台
  • 活动

    • 自媒体分享计划
    • 邀请作者入驻
    • 自荐上首页
    • 技术竞赛
  • 资源

    • 技术周刊
    • 社区标签
    • 开发者手册
    • 开发者实验室
  • 关于

    • 社区规范
    • 免责声明
    • 联系我们
    • 友情链接

腾讯云开发者

扫码关注腾讯云开发者

扫码关注腾讯云开发者

领取腾讯云代金券

热门产品

  • 域名注册
  • 云服务器
  • 区块链服务
  • 消息队列
  • 网络加速
  • 云数据库
  • 域名解析
  • 云存储
  • 视频直播

热门推荐

  • 人脸识别
  • 腾讯会议
  • 企业云
  • CDN加速
  • 视频通话
  • 图像分析
  • MySQL 数据库
  • SSL 证书
  • 语音识别

更多推荐

  • 数据安全
  • 负载均衡
  • 短信
  • 文字识别
  • 云点播
  • 商标注册
  • 小程序开发
  • 网站监控
  • 数据迁移

Copyright © 2013 - 2023 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有

深圳市腾讯计算机系统有限公司 ICP备案/许可证号: 粤B2-20090059 深公网安备号 44030502008569

腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287

问题归档 专栏文章 快讯文章归档 关键词归档 开发者手册归档 开发者手册 Section 归档
 
推荐文章
深沉的野马  ·  斗罗:师尊无敌,开局收徒朱竹清最新章节在线阅读-创世中文网官网
3 周前
纯真的围巾  ·  詹杜库先后被击败,爱德华兹宣告登基,森林狼连续两年再进西决!_腾讯新闻
4 月前
精明的手套  ·  惠誉下调玻利维亚信用评级至CCC-
5 月前
近视的香菜  ·  驻英国大使刘晓明夫人胡平华在英托尔盖特小学孔子课堂揭牌仪式上的致辞 — 中华人民共和国外交部
1 年前
光明磊落的登山鞋  ·  Python3 File readlines() 方法 | 菜鸟教程
1 年前
今天看啥   ·   Py中国   ·   codingpro   ·   小百科   ·   link之家   ·   卧龙AI搜索
删除内容请联系邮箱 2879853325@qq.com
Code - 代码工具平台
© 2024 ~ 沪ICP备11025650号