1、什么是立即数?如何判断某数是非法是12位立即数?
(1)立即数是直接嵌在指令中的常数,不需要从内存 / 寄存器读取,
(2)判断标准:把某个数展开成2进制,该数必须存在一种循环右移(偶数位),使得移位后高24位全0,低8位即为有效imm8
2、b,bl,bx指令的区别是什么?
b:单纯跳转,不保存返回地址
bl:跳转前,将下一条指令地址存入 LR (R14)
bx:跳转 + 切换指令集(ARM↔Thumb),不保存返回地址
3、ARM内核采用的栈是哪种栈?
ARM 内核本身不强制固定栈类型,但主流使用满递减栈(FD)
1.满递减栈 (FD)
- 缩写: FD
- 核心特点 :
SP始终指向栈中最后一个已压入的元素。
入栈操作时,先执行SP递减(SP--),再将数据存入新位置。
适用于栈空间已满时需先移动指针再存储的场景。
2.空递减栈 (ED)
- 缩写: ED
- 核心特点 :
SP指向栈中第一个可用的空位置。
入栈操作时,先将数据存入当前SP位置,再执行SP递减(SP--)。
适用于栈空间从高地址向低地址增长且初始为空的情况。
3.满递增栈 (FA)
- 缩写: FA
- 核心特点 :
SP指向栈中最后一个已压入的元素。
入栈操作时,先存入数据到当前SP的下一个位置,再执行SP递增(SP++)。
适用于栈空间从低地址向高地址增长且初始为满的场景。
4.空递增栈 (EA)
- 缩写: EA
- 核心特点 :
SP指向栈中第一个可用的空位置。
入栈操作时,先执行SP递增(SP++),再将数据存入新位置。
适用于栈空间从低地址向高地址增长且初始为空的情况。
5.关键区别总结
- 满栈 与空栈 :
满栈的SP指向有效数据,空栈的SP指向空闲位置。 - 递减栈 与递增栈 :
递减栈向低地址扩展(SP--),递增栈向高地址扩展(SP++)。
6.典型应用场景
- ARM架构: 通常使用满递减栈(FD)。
- x86架构: 常见空递增栈(EA)。
- 嵌入式系统: 根据硬件设计选择栈类型,如Cortex-M系列默认采用FD栈。
4、CPSR中条件标志位,分别在什么情况下被置位
|-----|-------------|------------------------|-------------------|
| 标志位 | 含义 | 置位(=1) | 清零(=0) |
| N | 运算结果为负 | 有符号数运算结果的最高位(bit31)为 1 | 最高位为 0 |
| Z | 运算结果为 0 | 运算结果所有位都是 0 | 运算结果非 0 |
| C | 无符号数进位 / 借位 | 加法:最高位产生进位 减法:无借位 | 加法:最高位无进位 减法:产生借位 |
| V | 有符号数溢出 | 有符号数运算结果超出 32 位范围 | 有符号数运算无溢出 |
5、arm汇编调用c语言函数以及c语言函数调用汇编编写的函数,函数参数和返回值如何处理?
(1)参数传递:
前 4 个参数依次存入R0、R1、R2、R3;
超过 4 个的参数,通过栈传递(按从左到右顺序压栈);
(2)返回值处理:
32 位返回值:存入R0;
64 位返回值:存入R0+R1;