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汇编语言程序里,有一些特殊指令助记符,这些助 ...
随机推荐
- linux(vi)常用命令
常用操作 系统命令 查看主机名 hostname 修改主机名(重启后无效) hostname yang 修改主机名(重启后永久生效) vi /ect/sysconfig/network 修改IP(重启 ...
- sql中多层循环示例(有游标)
在需求处理中,我们会遇到需要通过SQL多层循环来处理的问题.如:A表中有8条数据,B表中有10条数据,需要实现A表中的每1条数据对应B表中的10条数据,最后就有了80条数据,从而实现一对多的关系.那如 ...
- Linux基础入门学习笔记之四
环境变量与文件查找 环境变量 变量 所谓shell变量,就是计算机中用于记录一个值(不一定是数值,也可以是字符或字符串)的符号,而这些符号将用于不同的运算处理中.通常变量与值是一对一的关系,可以通过表 ...
- SQL update select语句
SQL update select语句 最常用的update语法是:UPDATE <table_name>SET <column_name1> = <value>, ...
- CentOS 7不能联网解决办法
在使用 Ubuntu 一段时间之后想体验一下 CentOS,就去下载了 CentOS 7 安装到了虚拟机里面,结果发现不能联网,一直提示Cannot find a valid baseurl for ...
- BCD码
BCD码(Binary-Coded Decimal)亦称二进码十进数或二-十进制代码,是用4位二进制数来表示1位十进制数中的0~9这10个数码,用一种使用二进制编码十进制的数字编码形式.BCD码这种 ...
- asp.net 微信公众号源码
需要源码,请加QQ:858-048-581 功能菜单 该源码功能十分的全面,具体介绍如下:1.菜单回复:微信自定义回复.关注时回复.默认回复.文本回复.图文回复.语音回复. 请求回复记录.LBS位置回 ...
- #JS Ajax的error函数
使用jquery的ajax方法向服务器发送请求的时候,常常需要使用到error函数进行错误信息的处理, 一般error函数返回的参数有三个: function(jqXHR jqXHR, String ...
- ZooKeeper实践:(2)配置管理
一. 前言 配置是每个程序不可或缺的一部分,配置有多重方式:xml.ini.property.database等等,从最初的单机环境到现在的分布式环境. 1. 以文件的格式存储配置,修改任何都 ...
- Python爬虫个人记录(三)爬取妹子图
这此教程可能会比较简洁,具体细节可参考我的第一篇教程: Python爬虫个人记录(一)豆瓣250 Python爬虫个人记录(二)fishc爬虫 一.目的分析 获取煎蛋妹子图并下载 http://jan ...