什么是立即数?如何判断某数是非法12位立即数?
立即数是直接嵌入在指令中的常数,不需要从内存或寄存器中读取。立即数由四位旋转位和八个数字位构成。
立即数:把某个数展开成2进制,该数必须存在一种循环右移(偶数位),使得移位后高24位全0,低位即为有效imm8
非法立即数:将32位数循环左移任意偶数次(0~30步),若无法得到一个8位范围内的数(即高24位全为0),则为非法12位立即数。
b,bl,bx指令的区别是什么?
b:不保存返回地址,直接跳转到目标地址
B<c> <label>
b fun <==> ldr pc, =fun
bl:跳转时将下一条指令的地址存储到lr中。
BL<c> <label>
bl fun
bx:不保存返回地址,仅跳转 + 切换指令集。
BX<c> <Rm>
bx lr <==> mov pc, lr
ARM内核采用的栈是哪种栈?
采用了满减栈
CPSR中条件标志位,分别在什么情况下被置位
- N: 符号标志位:上条指令执行结果最高位bit31为1,则 N = 1, 当结果作为有符号解释时为负值;
- Z: 零值标志位:上条指令执行结果为0(即bit0 - bit31 均为0),则 Z = 1;
- C: 进位标志位:进行无符号解读,如果在加法过程中进位(最高位向更高位进位)或者减法时没有借位,则为 C = 1,否则 C = 0
- V: 溢出标志位:进行有符号解读,是否发生溢出 -2^31 - 2^31-1(两个正数加得负数,两个负数加得正数)
arm汇编调用c语言函数以及c语言函数调用汇编编写的函数,函数参数和返回值如何处理?
ARM中将函数的参数和返回值在函数跳转时和地址一起存储在栈中,在返回该函数时取出,注意:函数的参数和返回值在存储时应按照固定的顺序存储,否则会造成参数混乱。