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. PM过程能力成熟度3级

    2级PM已经可以把项目管理起来了.如果这时候,企业只有一个PM,那这种程度的管理,只要逐渐深化,就可以一直维持下去. 然鹅,现实总是复杂很多... 公司会在PM建立2级的过程管理后,提高所有项目的可视 ...

  2. Django-2- 模板路径查找,模板变量,模板过滤器,静态文件引用

    模板路径查找 路径配置 2. templates模板查找有两种方式 2.1 - 在APP目录下创建templates文件夹,在文件夹下创建模板 2.2 - 在项目根目录下创建templates文件夹, ...

  3. 我的Windows日常——你的小电影藏好了吗?

    Hello!           everybody! 记得大三,第一次上我们某主任的课(我是计算机学部的),某主任上课的第一件事,点名,第二件事,忽悠我们. 具体忽悠步骤如下: 某:”同学们,这里有 ...

  4. 周一02.3运行python程序的两种方式

    一.运行python程序的两种方式 方法一:交互式:                     优点:输入一行代码立刻返回结果                      缺点:无法永久保存代码 方法二: ...

  5. ubunru18.04下面安装docker

    sudo apt-get updat // 更新apt包索引 sudo apt-get remove docker docker-engine docker-ce docker.io // 卸载旧版本 ...

  6. python学习——读取染色体长度(二、向前一步:通过染色体序列获得长度信息)

    # 读取fasta # 解析每条序列的长度 chr1_seq = 'ATATATATAT' chr2_seq = 'ATATATATATCGCGCGCGCG' chr3_seq = 'ATATATAT ...

  7. 老白关于rac性能调优的建议(10gRAC)

    RAC应用设计方面需要在底层做很有设计.虽然ORACLE的售前人员总是说RAC的扩展性是透明的,只要把应用分到不同的节点,就可以平滑的扩展系统能力了.而事实上,RAC的CACHE FUSION机制决定 ...

  8. git客户端的安装及使用

    1.git提交全部文件的基本步骤: 1)git status:查看修改内容 2)git add XX :添加XX文件到暂存区,如果修改内容比较多,可以使用git add -A .来一次性添加所有文件( ...

  9. django.db.utils.ProgrammingError: (1146, "Table 'db_gold.user_ip_info' doesn't exist") RuntimeError: Model class scanhosts.models.HostLoginInfo doesn't declare an explicit app_label and isn't in an a

    Error Msg 创建了一个apps的目录将所有app放入apps文件中, 将apps路径加入sys.path中:sys.insert(0, os.path.join(BASE_DIR, " ...

  10. Mysql中的explain和desc

    查询分析器 desc 和 explain 作用基本一样,explain速度快一点 explain 一条SQL语句出出现以下参数, 其中id,select_type,table 用于定位查询,表示本行参 ...