ARM ® and Thumb ®-2 指令系统
指令表关键词 | |||||
Rm {, <opsh>} | 寄存器移位方式,将寄存器的移位结果作为操作数而Rm值保持不变 | ||||
<Operand2> | 灵活的使用第二个操作数。移位和循环最合适作为第二操作数的一部分使用 | <reglist> | 由大括号括起来的一些用逗号分割的寄存器列表。如:{ and }. | ||
<fields> | 查看程序状态寄存器域目录. | <reglist-PC> | 加载或存储的寄存器列表,但不含程序计数器寄存器。 | ||
<PSR> | 包含CPSR (当前程序状态寄存器) 或SPSR (程序状态保存寄存器) | <reglist+PC> | 须有程序计数器寄存器列表。将SPSR拷贝到CPSR中,用于从异常处理返回。 | ||
C*, V* | 标志值在V4及之前的架构中是不确定的, 在V5及之后则是不变的. | +/- | 正或负. (+ 有可能被忽略.) | ||
<Rs|sh> | 可能是Rs或一个可移位的立即数. 值由寄存器中可用的各种移位方式进行 | § | ARM体系结构版本 | ||
任意位循环移动得到 | <iflags> | 中断标志. 一个或多个异常,中断,快速中断. | |||
x,y | B 指寄存器低位 [15:0], 而 T 指高位[31:16]. (Bottom,Top) | <p_mode> | 识别处理机模式 | ||
<imm8m> | ARM: 32位常数,由一个8位数循环右移偶数位得到。 | SPm | 由<p_mode>区分的处理机模式的堆栈指针 | ||
Thumb: 32位常数,由一个8位数左移一位或多位数得到。 | <lsb> | 位域的最低有效位 | |||
型如以下形式之一: 0xXYXYXYXY, 0x00XY00XY or 0xXY00XY00 | <width> | 位域的宽度. <width> + <lsb> 须<=32 | |||
<prefix> | 相似指令的前缀 | {X} | RsX 是在x置位时Rs循环移动16位. 否则, RsX=Rs. | ||
{IA|IB|DA|DB} | 分别指:传送后地址增加, 传送前地址增加, 传送后地址减少, 传送前地址减少4个字节。 | {!} | 若 ! 存在 (预先变址),则数据传送后更新基址寄存器(Rn)。 | ||
IB和 DA在Thumb状态下是不可用的. 如未指定,默认使用IA. | {S} | 若S存在更新标志位 | |||
<size> | B , SB, H, or SH, 分别指:字节, 带符号位的字节, 半字, 带符号位的半字。 | {T} | 若T存在给用户模式特权 | ||
SB 和 SH在STR 指令中不可用。 | {R} | 若R存在恢复最近的结果,否则丢弃结果。 |
ARM ® and Thumb ®-2 指令系统的更多相关文章
- ARM 的Thumb状态测试
作为一个使用ARM的学习者,有必要全面了解你的处理器内核.尽管有些内容可能在实际应用中用不到,但是“了解”还是很必要的.Thumb状态,是ARM的一个特色,但是你知道Thumb状态与ARM状态最大的区 ...
- 对于Android NDK编译器ARM和Thumb模式的理解
编译NDK项目时,编译器无法识别arm汇编,设置LOCAL_ARM_MODE := arm后问题解决, NDK文档上对LOCAL_ARM_MODE的说明如下: LOCAL_ARM_MODE By de ...
- ARM处理器的寄存器,ARM与Thumb状态,7中运行模式
** ARM处理器的寄存器,ARM与Thumb状态,7中运行模式 分类: 嵌入式 ARM处理器工作模式一共有 7 种 : USR 模式 正常用户模式,程序正常执行模式 FIQ模式(Fast ...
- ARM处理器的寄存器,ARM与Thumb状态,7中运行模式 【转】
转自:http://blog.chinaunix.net/uid-28458801-id-3494646.html ARM处理器工作模式一共有 7 种 : USR 模式 正常用户模式,程序正常 ...
- ARM指令系统
转载自:http://cxb4224.blog.163.com/blog/static/191224151201110220325976/ ARM处理器的工作状态和工作模式 工作状态 ARM处理器一般 ...
- ARM状态和THUMB状态
ARM处理器的工作状态 在ARM的体系结构中,可以工作在三种不同的状态,一是ARM状态,二是Thumb状态及Thumb-2状态,三是调试状态. <嵌入式系统开发与应用教程(第2版)>上介绍 ...
- [转]ARM/Thumb/Thumb-2
ref:http://kmittal82.wordpress.com/2012/02/17/armthumbthumb-2/ A few months ago I gave a presentatio ...
- 13 ARM指令集与Thumb指令集
指令格式 ARM基本格式 <opcode>{<cond>}{S}{.W|.N}<Rd>,<Rn>{,<operand2>} opecode: ...
- ARM汇编程序中的伪指令
转自http://blog.chinaunix.net/uid-13701930-id-336459.html 4.1 ARM汇编器所支持的伪指令 在ARM汇编语言程序里,有一些特殊指令助记符,这些助 ...
随机推荐
- day05作业
一.1.switch 2.字符串 3.表达式1 4.break 5.continue 二.1.B 2.A 3.BD 4.D 5.B 6.B 7.A 8.D 9.D 10.B 三.1.√ 2.√ 3.× ...
- invalid byte sequence for encoding "UTF8": 0xe99d2c
服务器还原数据库数据出错,老规矩... 字符集编码的问题 http://blog.csdn.net/beiigang/article/details/39582583 over....
- DOS命令大全(二)
一般来说dos命令都是在dos程序中进行的,如果电脑中安装有dos程序可以从开机选项中选择进入,在windows 系统中我们还可以从开始运行中输入cmd命令进入操作系统中的dos命令,如下图: 严格的 ...
- AdvStringGrid 删除数据
unit Unit6; interface uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System ...
- linux用户操作
1.用户种类 Linux具有三种用户: 超级管理员root:具有最高权限,UID=0 GID=0伪用户(System Account):(UID=1~499)普通用户(login-Account): ...
- es6之yield
yield 关键字用来暂停和继续一个生成器函数.我们可以在需要的时候控制函数的运行. yield 关键字使生成器函数暂停执行,并返回跟在它后面的表达式的当前值.与return类似,但是可以使用next ...
- javascript重要类方法笔记
三.数据结构和map 1.大括号数据结构:{} 1.1 键值对形式,类似Map 1.2 var treeNode={}; treeNode ...
- centos7.3 chrome 安装
/etc/yum.repos.d/目录下新建文件google-chrome.repo,向其中添加如下内容: [google-chrome] name=google-chrome baseurl=htt ...
- 使用Let’s Encrypt创建nginx免费SSL证书
资料参考: https://www.freehao123.com/top-8-free-ssl-cert/ 八大免费SSL证书-给你的网站免费添加Https安全加密 https://www.fre ...
- jquery 查询IP归属地
<script src="http://c.csdnimg.cn/public/common/libs/jquery/jquery-1.9.1.min.js" type=&q ...