嵌入式第四十七篇——ARM汇编

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;

相关推荐
zhangrelay21 分钟前
机器人工程专业:Lubuntu 26.04 + ROS2 Lyrical Luth 入门、进阶、精通全指南
笔记·学习
Orange_sparkle32 分钟前
learn claude code学习记录-S06
学习
徒 花37 分钟前
HCIP学习09 重发布(路由引入)+ 路由策略
网络·学习·hcip
:mnong1 小时前
跟着学伴AI项目设计分析学习安卓APP研发
android·人工智能·学习
头疼的程序员1 小时前
计算机网络:自顶向下方法(第七版)第九章 学习分享(三)
学习·计算机网络
千谦阙听1 小时前
数据结构最终章:万字详解排序算法!(内部排序)
c语言·数据结构·学习·算法·排序算法
三无推导1 小时前
GitHub爆火项目ChinaTextbook——开源如何重新定义教育普惠的边界
学习·开源·github
kk在加油1 小时前
python学习笔记(基础语法与变量、容器)
笔记·python·学习
江苏世纪龙科技1 小时前
世纪龙-安全先行,技能进阶—新能源汽车故障诊断虚拟实训软件
学习
qingwufeiyang_5301 小时前
Mybatis学习笔记-1-快速入门
笔记·学习·mybatis