ARM学习笔记4——加载存储指令
一、字数据传送指令
作用:用于把单一的数据传入或者传出一个寄存器。

1、LDR指令
1.1、作用
根据<addr_mode>所确定的地址模式从内存中将一个32位的字段读取到目标寄存器<Rd>,如果指令中的寻址方式确定的地址不是字对齐的,则读出的数值要进行循环右移。
1.2、语法格式
LDR{<condition>} <Rd>,<addr_mode>
1.3、参数说明
<Rd>确定使用哪个通用寄存器作为目标寄存器
<addr_mode>确定了指令编码中的I、P、U、W、Rn和<addr_mode>位
2、STR指令
2.1、作用
将一个32位的字数据写入到指令中指定的内存单元
2.2、语法格式
STR{<condition>} <Rd>,<addr_mode>
二、字节数据传送指令(LDRB/STRB)
1、LDRB指令
1.1、作用
根据<addr_mode>所确定的地址模式将一个8位字节读取到指令中的目标寄存器<Rd>
1.2、语法格式 LDR{<condition>}B <Rd>,<addr_mode>
2、STRB指令
2.1、作用
从寄存器中取出指定的8位字节放入指令中指定的内存单元的低8位,并将其高位补0
2.2、语法格式 STR{<condition>}B <Rd>,<addr_mode>
三、半字数据传送指令(LDRH/STRH)
1、LDRH
1.1、作用
从内存中将一个16位的半字读取到目标寄存器
1.2、语法格式
LDR{<condition>}H <Rd>,<addr_mode>
2、STRH
2.1、作用
从寄存器中取出知道你个的16位半字放入指令中指定的内存单元的低16位,并将其高位补0
2.2、语法格式
STR{<condition>}H <Rd>,<addr_mode>
四、用户模式字数据传送指令
1、LDRT
1.1、作用
在用户模式下,根据<addr_mode>所确定的地址模式从内存中将一个32位的字读取到目标寄存器<Rd>
1.2、语法格式
LDR{<condition>}T <Rd>,<post_indexed_addressing_mode>
1.3、参数说明
<post_indexed_address_mode>:使用后索引地址模式寻址
2、STRT
2.1、作用
将一个32位的字数据写入到指令中指定的内存单元
2.2、语法格式
STR{<condition>}T <Rd>,<post_indexed_addressing_mode>
五、用户模式字节数据传送指令
1、LDRBT指令
1.1、作用
根据<post_indexed_addressing_mode>地址模式将一个8位字节读取到指令中的目标寄存器<Rd>
1.2、语法格式
LDR{<condition>}BT <Rd>,<post_indexed_addressing_mode>
2、STRBT指令
2.1、作用
将一个8位的字节数据写入到指令中指定的内存单元
2.2、语法格式
STR{<condition>}BT <Rd>,<addr_mode>,<post_indexed_addressing_mode>
六、有符号的字节/半字数据传送指令
1、LDRSB指令
1.1、作用
根据<addr_mode>所确定的地址模式将一个8位字节读取到指令中的目标寄存器<Rd>
1.2、语法格式
LDR{<condition>}SB <Rd>,<addr_mode>
2、LDRSH指令
2.1、作用
根据<addr_mode>所确定的地址模式将一个16位半字读取到指令中的目标寄存器<Rd>
2.2、语法格式
LDR{<condition>}SH <Rd>,<addr_mode>
ARM学习笔记4——加载存储指令的更多相关文章
- 学习笔记TF015:加载图像、图像格式、图像操作、颜色
TensorFlow支持JPG.PNG图像格式,RGB.RGBA颜色空间.图像用与图像尺寸相同(height*width*chnanel)张量表示.通道表示为包含每个通道颜色数量标量秩1张量.图像所有 ...
- [WPF学习笔记]动态加载XAML
好久没写Blogs了,现在在看[WPF编程宝典],决定开始重新写博客,和大家一起分享技术. 在编程时我们常希望界面是动态的,可以随时变换而不需要重新编译自己的代码. 以下是动态加载XAML的一个事例代 ...
- 自己写CPU第九阶段(3)——加载存储指令说明2(swl、swr)
我们会继续上传新书<q=%E8%87%AA%E5%B7%B1%E5%8A%A8%E6%89%8B%E5%86%99CPU&ie=utf-8&src=se_lighten_quot ...
- Away3D 学习笔记(一): 加载3DS格式的模型文件
加载外部的3DS文件分为两种: 1: 模型与贴图独立于程序的,也就是从外部的文件夹中读取 private function load3DSFile():Loader3D { loader = new ...
- flutter源码学习笔记-图片加载流程
本文基于1.12.13+hotfix.8版本源码分析. 0.大纲 Image ImageProvider 图片数据加载 ImageStream.ImageStreamCompleter 缓存池 Pai ...
- Unity3D学习笔记9——加载纹理
目录 1. 概述 2. 详论 2.1. Resources方式 2.2. API方式 2.3. Web方式 1. 概述 理论上,Unity中加载纹理并没有什么难度,只需要将图片放置在Assets文件夹 ...
- ARM学习笔记2——分支跳转指令
一.Arm指令条件码和条件助记符 二.跳转指令B 1.作用 跳转指令B使程序跳转到指定的地址执行程序(跳转范围是PC-32MB到PC+32MB) 2.指令格式(注:B后面如果有条件,条件就是紧跟在B后 ...
- ARM学习笔记6——程序状态寄存器访问指令
这两条指令结合,可用于对CPSR或SPSR进行读/写操作. 当需要保存或修改当前模式下CPSR或SPSR的内容时,首先必须将这些内容传递到通用寄存器中 1.MRS指令(Move to Register ...
- 深入java虚拟机学习 -- 类的加载机制(续)
昨晚写 深入java虚拟机学习 -- 类的加载机制 都到1点半了,由于第二天还要工作,没有将上篇文章中的demo讲解写出来,今天抽时间补上昨晚的例子讲解. 这里我先把昨天的两份代码贴过来,重新看下: ...
随机推荐
- JS模版引擎[20行代码实现模版引擎读后感]
曾经阅读过<只有20行JAVASCRIPT代码, 手把手教你写一个页面模版引擎>这篇文章, 对其中实现模版的想法实在膜拜, 于是有了这篇读后感, 谈谈自己对模版引擎的理解, 以及用自己的语 ...
- 初步认识 Web Service
Web Service初步认识 Web Service:不是框架,不是一种技术,而是一种跨平台,跨语言的规范. 作用:异构平台之间的交互,解决了不同平台,不同语言所编写的应用之间的相互调用.(远 ...
- Java学习笔记(基本数据类型和变量命名规则)
java基本数据类型 变量 1.变量就是可变的量. 2.常量就是不可变的量. 3.字面量:Java的变量和常量中存放的具体的数据成为字面量. 变量 命名规则: (1)首字母是英文字母.$或下划线,由字 ...
- (hdu)1022 Train Problem I 火车进站问题
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=1022 Problem Description As the new term comes, ...
- leetcode344——Reverse String(C++)
Write a function that takes a string as input and returns the string reversed. Example:Given s = &qu ...
- 第5章标准I/O库总结
1 fwide函数试图设置流的定向(流的定向决定了读写单字节还是多字节字符) int fwide(FILE *fp,int mode) 宽定向返回正值,字节定向返回负值,为定向返回0 已定向流不会改变 ...
- spark-shell - 将结果保存成一个文件
sqlContext.sql(""" SELECT user_no,cust_id,oper_code FROM cui.operation_data_an ...
- android 开源框架推荐
同事整理的 android 开源框架,个个都堪称经典.32 个赞! 1.volley 项目地址 https://github.com/smanikandan14/Volley-demo (1) JS ...
- 在hyper安装openwrt
写了长长长一篇文章,结果把标签关了,这篇文章就不见了,草稿箱也没有!!! 只好直接copy原来作者的文章了 下载地址 openwrt image tulip driver 引用 Want to add ...
- 更新ACCESS数据库出现“字段太小而不能接受所要添加的数据的数量。试着插入或粘贴较少的数据。”的解决方法
今天进行数据调试时出现“字段太小而不能接受所要添加的数据的数量.试着插入或粘贴较少的数据.”,跟踪发现是在更新数据库的数据时出现的. 打开数据库表格发现出错的数据字段类型被定义为“文本”,也就是数据最 ...