DIY编程器网

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 117|回复: 0
打印 上一主题 下一主题

ARM状态寄存器访问指令

[复制链接]
跳转到指定楼层
楼主
发表于 2012-1-16 18:42:21 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

                      ARM中有两条指令用于在状态寄存器和通用寄存器之间传送数据。
  状态寄存器中有些位是当前没有使用的,但在ARM将来版本中有可能使用这些位,因此用户程序不要使用这些位。
  程序不能通过直接修改CPSR中T的控制位直接将程序状态切换到Thumb状态,必须通过BX等指令完成程序状态的切换。
  通常修改状态寄存器是通过“读取-修改-写回”的操作序列来实现。
  状态寄存器访问指令包括以下两条。
  (1)MRS 状态寄存器到通用寄存器的传送指令
  MRS(条件)? ' CPSR
  MRS指令用于将状态寄存器的内容传送到通用寄存器中。
  MRS指令主要用于以下3种场合。
  ·通常通过“读取-修改-写回“操作序列修改状态寄存器的内容。MRS指令用于将状态寄存器的内容读到通用寄存器中。
  ·当异常中断允许嵌套时,需要在进入异常中断之后、嵌套中断发生之前保存当前处理器模式对应的SPSR J8时需要先通过MRS指令读出SPSR的值,再用其他指令将SPSR保存起来。
  ·在进程切换时也需要保存当前状态寄存器值。
  (2)MSR 通用寄存器到状态寄存器的传送指令
  MSR指令用于将通用寄存器的内容或一个立即数传送到状态寄存器中。
  MSR指令通常用于恢复状态寄存器的内容或者改变状态寄存器的内容。
  当退出异常中断处理程序时,如果事先保存了状态寄存器的内容(如在嵌套的异常中断处理中),则通常通过MSR指令实现将保存的状态寄存器内容恢复到状态寄存器中。
  当需要修改状态寄存器的内容时,通过“读取-修改-写回”指令序列完成。写回操作也是通过MSR指令完成的。
  考虑到指令执行的效率,通常在MSR指令中指定指令将要修改的位域。

  欢迎转载,信息来源维库电子市场网(www.dzsc.com)
            
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|文字版|手机版|DIY编程器网 ( 桂ICP备14005565号-1 )

GMT+8, 2025-7-27 07:32 , 耗时 0.085764 秒, 18 个查询请求 , Gzip 开启.

各位嘉宾言论仅代表个人观点,非属DIY编程器网立场。

桂公网安备 45031202000115号

DIY编程器群(超员):41210778 DIY编程器

DIY编程器群1(满员):3044634 DIY编程器1

diy编程器群2:551025008 diy编程器群2

QQ:28000622;Email:libyoufer@sina.com

本站由桂林市临桂区技兴电子商务经营部独家赞助。旨在技术交流,请自觉遵守国家法律法规,一旦发现将做封号删号处理。

快速回复 返回顶部 返回列表