ARM开发day1

什么是立即数?如何判断某数是非法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中条件标志位,分别在什么情况下被置位

  1. N: 符号标志位:上条指令执行结果最高位bit31为1,则 N = 1, 当结果作为有符号解释时为负值;
  2. Z: 零值标志位:上条指令执行结果为0(即bit0 - bit31 均为0),则 Z = 1;
  3. C: 进位标志位:进行无符号解读,如果在加法过程中进位(最高位向更高位进位)或者减法时没有借位,则为 C = 1,否则 C = 0
  4. V: 溢出标志位:进行有符号解读,是否发生溢出 -2^31 - 2^31-1(两个正数加得负数,两个负数加得正数)

arm汇编调用c语言函数以及c语言函数调用汇编编写的函数,函数参数和返回值如何处理?

ARM中将函数的参数和返回值在函数跳转时和地址一起存储在栈中,在返回该函数时取出,注意:函数的参数和返回值在存储时应按照固定的顺序存储,否则会造成参数混乱。

相关推荐
底层开发智库8 小时前
无需硬件开发板,从零构建并运行ARM aemfvp-a-rme软件栈
arm开发·arm
HMS工业网络16 小时前
主从结合,安全互联:Anybus工业通信解决方案全栈升级
arm开发
XINVRY-FPGA17 小时前
XC7Z010-2CLG400I Xilinx Zynq-7000 FPGA
arm开发·嵌入式硬件·算法·fpga开发·硬件工程·dsp开发·fpga
Emtronix英创1 天前
RK3568 CAN驱动测试及使用说明
linux·arm开发·rk3568·全国产主板
时空自由民.3 天前
Arm Coretex-M核MCU做IAP/OTA升级时候为什么要做中断向量表地址偏移?
arm开发·单片机·嵌入式硬件
黑猫学长呀3 天前
存储宝典第1篇:Nand SCA是什么
arm开发·arm·nand·存储芯片·nandflash·onfi
Freak嵌入式3 天前
WIZnet-EVB-Pico2开始,用MicroPython玩转以太网开发
arm开发·人工智能·python·嵌入式硬件·机器人·嵌入式·micropython
振南的单片机世界3 天前
推挽输出:上管推、下管拉,驱动强但不“合群”
arm开发·stm32·单片机·嵌入式硬件
沃普天科技5 天前
USB显示器多屏异显多屏拼接IF8032 IT690 VL171 8801 RTD2556
arm开发·驱动开发·算法·计算机外设·音视频·硬件工程·pcb工艺
凉、介5 天前
ARM GICv3 学习笔记(一)
arm开发·笔记·学习·嵌入式