主页
1.1.
前言
1.2.
ARM概述
1.2.1.
调用规范
1.3.
ARM寄存器
1.3.1.
寄存器命名
1.3.2.
寄存器架构
1.3.3.
常用寄存器
1.3.3.1.
PC
1.3.3.2.
IP
1.3.3.3.
SP
1.3.3.4.
LR
1.3.3.5.
状态寄存器
1.3.3.5.1.
CPSR
1.3.4.
其他寄存器
1.3.5.
AArch64=ARM64
1.3.5.1.
特殊用途寄存器
1.3.5.1.1.
NZCV
1.4.
ARM汇编指令
1.4.1.
指令列表
1.4.1.1.
按字母
1.4.1.2.
操作码
1.4.2.
常用汇编指令
1.4.2.1.
赋值
1.4.2.2.
内存操作
1.4.2.3.
比较
1.4.2.4.
分支跳转
1.4.2.5.
条件选择
1.4.2.6.
寻址
1.4.2.7.
算数运算
1.4.2.8.
逻辑运算
1.4.2.9.
SVC系统调用
1.4.2.10.
其他
1.5.
ARM常见用法和通用规则
1.5.1.
函数调用
1.5.2.
跳转指令
1.5.3.
条件执行
1.5.3.1.
cond条件码
1.5.4.
Pre-index和Post-index
1.5.5.
flexible second operand
1.6.
工具
1.6.1.
指令和二进制opcode互转
1.7.
附录
1.7.1.
X86汇编
1.7.2.
参考资料
本书使用 HonKit 发布
SP
SP
R13
=
SP
=
Stack Pointer
=
栈指针
=
堆栈指针
每一种异常模式都有其自己独立的r13,它通常指向异常模式所专用的堆栈,也就是说五种异常模式、非异常模式(用户模式和系统模式),都有各自独立的堆栈,用不同的堆栈指针来索引。这样当ARM进入异常模式的时候,程序就可以把一般通用寄存器压入堆栈,返回时再出栈,保证了各种模式下程序的状态的完整性
results matching "
"
No results matching "
"