title: LDM与STM指令详解

date: 2019/2/26 17:58:00

toc: true

LDM与STM指令详解

指令形式如下,这里的存储方向是针对寄存器的

Load Multiple (LDM) and Store Multiple (STM)
LDM{<cond>}<addressing_mode> Rn{!}, <registers>{^}
STM{<cond>}<addressing_mode> Rn{!}, <registers>{^}

LDM,加载寄存器列表

LDMIA R2, {R0-R3} ; Reload R0-R3 from temporary storage

STM,存储寄存器列表

STMIA R13, (R0-R3) ; Put R0-R3 into temporary storage
看下STR
STR R0, [R7, #0x7C] ; Store word from R0 to address R7 + 124
摘自汇编器指南
^ 为一个可选后缀,仅可用于 ARM 状态。 不可在用户模式或系统模
式下使用该后缀。 该后缀具有下列功能:
• 如果指令为 LDM (具有任何寻址模式)且 reglist 包含 pc
(r15),则除了正常的多寄存器传送外,还会将 SPSR 复制到
CPSR 中。 这是为了从异常处理程序返回。 请仅在异常模式下
使用此后缀。
• 否则,数据将被送入或送出用户模式寄存器,而不是当前模
式寄存器。

!

! 表示更新表示目标地址的寄存器在操作后是否更新这个表示地址的寄存器的值,如果没有则

  • LDM中,Rn不变
  • STM中,Rn不变

LDM ^

LDM{<cond>}<addressing_mode> <Rn>, <registers_without_pc>^

For an LDM instruction that does not load the PC, this indicates that User mode registers are to be loaded.

LDM{<cond>}<addressing_mode> <Rn>{!}, <registers_and_pc>^

For an LDM instruction that loads the PC, this indicates that the SPSR of the current mode iscopied to the CPSR.

  • 如果操作的寄存器有pc,则表示恢复spsr到cpsr,并跳转到pc,一般切换模式返回都需要这样,这个应该在异常模式下使用
  • 否则,表示存储的是用户模式的寄存器,比如我现在在异常模式,用这个方式的话**设置的是用户状态的寄存器sp**

STM ^

STM{<cond>}<addressing_mode> <Rn>, <registers>^

For an STM instruction, indicates that User mode registers are to be stored.

表示操作的是用户模式的寄存器,比如我现在在异常模式,用这个方式的话读取的的是用户状态的寄存器sp,也就是说将用户模式的sp存到某个地方

如果不用这个指令,想获取到用户的寄存器,我们需要切换到系统模式,因为系统模式和用户模式的sp是公用的

MOVS

这里插入讲一下指令后跟个S,表示更新cpsr,MOVS PC,R14

This restores the PC (from R14_und) and CPSR (from SPSR_und) and returns to the instruction following

the Undefined instruction.

参考

关于指令,找不到的话看 ARM Architecture Reference Manual.pdf,直接google一下就有pdf

或者点击这里

中文的pdf RealView_ARM_汇编指南.pdf

LDM与STM指令详解的更多相关文章

  1. [转]JVM指令详解(上)

    作者:禅楼望月(http://www.cnblogs.com/yaoyinglong) 本文主要记录一些JVM指令,便于记忆与查阅. 一.未归类系列A 此系列暂未归类. 指令码    助记符      ...

  2. C#中的预处理器指令详解

    这篇文章主要介绍了C#中的预处理器指令详解,本文讲解了#define 和 #undef.#if.#elif.#else和#endif.#warning和#error.#region和#endregio ...

  3. rsync指令详解

    rsync指令详解(更详细的看官方文档http://rsync.samba.org/ftp/rsync/rsync.html) [root@Centos epel]# rsync --help rsy ...

  4. #pragma 预处理指令详解

    源地址:http://blog.csdn.net/jx_kingwei/article/details/367312 #pragma  预处理指令详解              在所有的预处理指令中, ...

  5. 迈向angularjs2系列(2):angular2指令详解

    一:angular2 helloworld! 为了简单快速的运行一个ng2的app,那么通过script引入预先编译好的angular2版本和页面的基本框架. index.html: <!DOC ...

  6. C#中的预处理指令详解

    这篇文章主要介绍了C#中的预处理指令详解,本文讲解了#define 和 #undef.#if.#elif.#else和#endif.#warning和#error.#region和#endregion ...

  7. pragma comment的使用 pragma预处理指令详解

    pragma comment的使用 pragma预处理指令详解   #pragma comment( comment-type [,"commentstring"] ) 该宏放置一 ...

  8. Docker技术入门与实战 第二版-学习笔记-3-Dockerfile 指令详解

    前面已经讲解了FROM.RUN指令,还提及了COPY.ADD,接下来学习其他的指令 5.Dockerfile 指令详解 1> COPY 复制文件 格式: COPY  <源路径> .. ...

  9. nginx.conf中关于nginx-rtmp-module配置指令详解

    译序:截至 Jul 8th,2013 官方公布的最新 Nginx RTMP 模块 nginx-rtmp-module 指令详解.指令Corertmp语法:rtmp { ... }上下文:根描述:保存所 ...

随机推荐

  1. Android 设计模式之MVC模式

    说到Android设计模式的MVC模式,估计很多人都是比较熟悉了,这里深入了解一下MVC到底是怎么回事,以ListView为例子讲解. 一.深入理解MVC概念 MVC即Model-View-Contr ...

  2. MyBatis Generator 生成器把其他数据库的同名表生成下来的问题

    [问题] 使用MyBatis Generator生成器时,发现Mapper文件中出现字段与连接数据库不符,经过查找发现该表是其他数据库的同名表的字段. [解决问题] 在构造文件中,这里是generat ...

  3. java:编程比赛中有用的方法整理(一)数组

    我曾经参加过几次编程比赛,但是当时用的是c语言,现在学习了java,打算专攻java组,故以此整理. 数组无论在哪里都必不可少. 一.数组的拷贝: 使用Arrays类的copyOf方法: 1.将一个数 ...

  4. Java:配置环境(Mac)——Eclipse;修改JDK版本后,Eclipse打不开

    1.官网下载 选择一个速度快的镜像 推荐东软这个 2.双击下载的安装包,下一步 其中有一步是选择Eclipse版本,SE选第一个,EE第二个.仔细审题吧. 3.配置JDK 应用.关闭 4.测试:写个H ...

  5. SQLServer更改用户定义的数据库角色

    更改用户定义的数据库角色注意事项 需具有以下一项或多项权限或成员身份才能运行此命令: 对角色具有 ALTER 权限 对数据库具有 ALTER ANY ROLE 权限 具有 db_securityadm ...

  6. jpa 解决org.hibernate.lazyinitializationexception could not initialize proxy - no session

    org.hibernate.LazyInitializationException: could not initialize proxy [org.alan.entity.SysUser#1] - ...

  7. mysql8.0绿色版安装及mysqldump备份

    1.下载mysql绿色版压缩包https://dev.mysql.com/downloads/mysql/ 2.解压到安装目录后,在根目录创建data文件夹 3.把mysql下的bin目录添加到环境变 ...

  8. composer包(发布到github上)同步到Packagist

    在上一篇文章里面,探讨了如何一步步建立composer包–创建你的一个composer包 创建完成后,我们需要做的就是讲自建的包发布到Packagist上.至于说什么是Packagist,这个就不用我 ...

  9. MySQL 是如何解决幻读的

    MySQL 是如何解决幻读的 一.什么是幻读 在一次事务里面,多次查询之后,结果集的个数不一致的情况叫做幻读. 而多出来或者少的哪一行被叫做 幻行 二.为什么要解决幻读 在高并发数据库系统中,需要保证 ...

  10. python 提取pdf文字

    安装pdfminer 库 windows 下安装pdfminer3k pip install pdfminer3k Liunx 下安装pdfminer pip install pdfminer 代码 ...