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 sudo 配置
1.配置sudo权限 sudo配置信息保存在 /etc/sudoers 文件中,可以使用vi修改.但使用vi修改需要给root用户设置权限,可以使用 visudo 直接修改. visudo 复制这行将 ...
- echarts一些笔记
console.log(); 浏览器显示 $.ajax({ url : "ajax/echartWelcome.action", type : "post", ...
- [扩展推荐] Laravel 中利用 GeoIP 获取用户地理位置信息
我最近需要一个用户地域检测来设置用户的默认区域和货币.由 Daniel Stainback 创建的 torann/geoip 很好地满足为Laravel 5 项目提供 GeoIP 服务的要求. 这个 ...
- C实现线程池
简介:这里使用linux下的互斥锁和条件变量实现了一个线程池.代码由一个未知作者完成,第二任作者补充优化. 本人仅仅是做了一些注释工作. 代码如下: /*! .h */ #include <st ...
- vue.js学习 自定义过滤器使用(2)
gitHub地址: https://github.com/lily1010/vue_learn/tree/master/lesson05 一 自定义过滤器(注册在Vue全局) 注意事项: (1)全局方 ...
- C#socket编程序(二)
在上一篇中,我列了一些常用的方法,可以说这些方法是一些辅助性的方法,对于分析网络中的主机属性非常有用.在这篇中,我将会介绍一下面向连接(TCP)socket编程,其中辅以实例,代码可供下载. 对于TC ...
- HDU - 4458 计算几何判断点是否在多边形内
思路:将飞机看成不动的,然后枚举时间看点是否在多边形内部. #include<bits/stdc++.h> #define LL long long #define fi first #d ...
- Cordova 打包签名
1.第一步 在项目根目录下运行命令cordova build --release android,会在testApp\platforms\android\build\outputs\apk目录下生成一 ...
- webview内部跳转判断
重写webview内的方法 webView.setWebViewClient(new WebViewClient() { @Override // 在点击请求的是链接是才会调用,重写此方法返回true ...
- JAVAEE——宜立方商城13:订单系统实现、订单生成、Mycat数据库分片
1. 学习计划 1.订单系统实现 2.订单生成 3.Mycat数据库分片 2. 订单系统 2.1. 功能分析 1.在购物车页面点击“去结算”按钮,跳转到订单确认页面 a) 必须要求用户登录 b) 使用 ...