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

相关推荐
CinzWS8 小时前
A53 FPGA原型验证:从RTL到可运行系统的挑战
arm开发·嵌入式·芯片验证·原型验证·a53
AI服务老曹9 小时前
深度解析:支持 GB28181/RTSP 及异构计算(X86/ARM+GPU/NPU)的 AI 视频管理平台架构方案(附源码交付与 Docker 部署)
arm开发·人工智能·音视频
2302_813806229 小时前
基础环境篇 – 交叉编译环境搭建与NFS服务配置
arm开发
极创信息9 小时前
信创领域五种主流CPU架构(X86 / ARM / RISC-V / MIPS / LoongArch)
java·arm开发·数据库·spring boot·mysql·软件工程·risc-v
AI服务老曹10 小时前
节省95%开发成本:支持X86/ARM与GPU/NPU异构部署的AI视频云网关架构深度解析
arm开发·人工智能·音视频
徐某人..1 天前
基于i.MX6ULL平台的智能网关系统开发
arm开发·c++·单片机·qt·物联网·学习·arm
2035去旅行1 天前
嵌入式开发,如何选择C标准库
linux·arm开发
进击的小头1 天前
20_第20篇:嵌入式外设驱动开发基础:寄存器级开发与库函数开发对比实战
arm开发·驱动开发·单片机
AI服务老曹1 天前
架构实战:如何构建支持X86/ARM及异构GPU/NPU的跨平台企业级AI视频管理系统?
arm开发·人工智能·架构
ai产品老杨1 天前
【架构深研】如何构建兼容X86/ARM与异构算力的AI视频中台?基于GB28181与边缘计算的源码交付实践
arm开发·人工智能·架构