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讲解写出来,今天抽时间补上昨晚的例子讲解. 这里我先把昨天的两份代码贴过来,重新看下: ...
随机推荐
- 输出图像到文件 imwrite()[OpenCV 笔记7]
bool imwrite(const string& filename, InputArray img, const vector<int>& params=vector& ...
- android软件开发之webView.addJavascriptInterface循环渐进【一】
本篇文章由:http://www.sollyu.com/android-software-development-webview-addjavascriptinterface-cycle-of-gra ...
- AJAX 一些常用方法
abort() 停止当前请求getAllResponseHeaders() 返回包含HTTP请求的所有响应头信息,其中响应头包括Content-Length,Date,URI等内容.getRespon ...
- Unix环境高级编程学习笔记——fcntl
写这篇文正主要是为了介绍下fcntl,并将我自己在学习过程中的一些理解写下来,不一定那么官方,也有错误,希望指正,共同进步- fcntl: 一个修改一打开文件的性质的函数.基本的格式是 int fcn ...
- JS对于字符串的切割截取
对于字符串的切割截取平时所用可能不是特别多,而且分的比较细,所以自备自查.有备无患. 由于之前所有均在一个demo测试,若是哪里打错了,敬请谅解.一些其余属性找时间继续添加. 1.函数:split() ...
- php会话控制cookie/session
设置cookie PHP设置Cookie最常用的方法就是使用setcookie函数,setcookie具有7个可选参数,我们常用到的为前5个: name( Cookie名)可以通过$_COOKIE[' ...
- 安装 SQL Server 2005 的硬件和软件要求(官方全面)
SQL Server 2005 安装要求 本主题介绍了安装 SQL Server 205 的硬件和软件要求,以及查看安装文档的说明. 硬件和软件要求(32 位和 64 位) 访问 SQL Server ...
- Python学习_数据处理split方法
用open方法导入文件“sketch.txt”后,用split()方法进行分割: >>> import os >>> os.chdir('C:/Python33/H ...
- Leetcode 解题 Add Two Numbers Python
原题: You are given two linked lists representing two non-negative numbers. The digits are stored in r ...
- 从 IT 的角度思考 BIM(一):面向对象
还记得那个笑话吗:要把大象放进冰箱,总共分几步?这不仅仅是一个笑话,还是一个值得我们好好分析的笑话. 如果要放进冰箱的是一个苹果,那么也就不可笑了,但换成大象,就引起了我们的兴趣和注意,为什么? 我们 ...