嵌入式学习day45-硬件—汇编

1、ARM 内核工作模式有哪些,分别是在什么情况下被切换?

ARM 内核有 7 种基本工作模式:

  1. User 模式:正常的用户程序运行模式。

  2. FIQ 模式:快速中断模式(Fast Interrupt),响应高速数据传输或通道处理。

  3. IRQ 模式:普通中断模式(Interrupt Request)。

  4. Supervisor 模式:管理模式,通常在复位(Reset)或执行系统调用(SVC 指令)时进入。

  5. Abort 模式:存储器访问出错(如地址无效)时进入。

  6. Undefined 模式:遇到未定义指令时进入。

  7. System 模式:特权级模式,和 User 模式寄存器相同,但拥有管理权限。

模式切换通常发生在 异常/中断/系统调用 时,由硬件自动完成。

2、异常向量表是什么?

  • 异常向量表(Exception Vector Table)是存放 异常入口地址 的一段内存区域。

  • 当发生 复位、中断或异常 时,CPU 会根据异常类型跳转到对应的入口地址执行。

  • ARM 默认异常向量表基地址为 0x00000000(有些芯片可重映射到 0xFFFF0000)。

3、什么是立即数?如何判断某数是非法是12位立即数?

  • 立即数(Immediate Number):直接写在指令里的常数,而不是存放在寄存器或内存中的数据。

  • 在 ARM 指令集中,立即数通常是 12 位编码,由 8 位有效数(imm8)和 4 位旋转值(rot)组成。把某个数展开成2进制,该数必须存在一种循环右移(偶数位),使得移位后高24位全0,低8位即为有效imm8;

4、b,bl,bx指令的区别是什么?

  • B label

    • 无条件跳转到 label 地址。

    • PC ← label

  • BL label

    • 带返回地址的跳转(函数调用)。

    • LR ← 下一条指令地址PC ← label

  • BX reg

    • 跳转到寄存器 reg 的地址,同时可切换 ARM/Thumb 状态(根据地址最低位)。

    • 常用于函数返回或混合 ARM/Thumb 程序跳转。

5、ARM内核采用的栈是哪种栈?

ARM 支持 全递减栈/满减栈(Full Descending Stack, FD)

  • 栈向低地址增长(SP 递减)。

  • Push:先减 SP,再存数据。

  • Pop:先取数据,再加 SP。

相关推荐
西瓜堆4 小时前
提示词工程学习笔记: 工程技术行业提示词推荐
笔记·学习
charlie1145141917 小时前
嵌入式的现代C++教程——constexpr与设计技巧
开发语言·c++·笔记·单片机·学习·算法·嵌入式
好奇龙猫7 小时前
【AI学习-comfyUI学习-三十二节-FLXU原生态反推+controlnet depth(UNion)工作流-各个部分学习】
人工智能·学习
好奇龙猫7 小时前
【大学院-筆記試験練習:数据库(データベース問題訓練) と 软件工程(ソフトウェア)(7)】
学习
j_jiajia8 小时前
(一)人工智能算法之监督学习——KNN
人工智能·学习·算法
2301_783360138 小时前
关于RNAseq——从fastq到gene_counts全流程
笔记·学习
_李小白9 小时前
【AlohaMini学习笔记】第三天:AlohaMini相关技术
笔记·学习
我命由我123459 小时前
Photoshop - Photoshop 工具栏(57)模糊工具
学习·ui·职场和发展·求职招聘·职场发展·学习方法·photoshop
yatingliu20199 小时前
将深度学习环境迁移至老旧系统| 个人学习笔记
笔记·深度学习·学习
week_泽9 小时前
第1课:AI Agent是什么 - 学习笔记_1
人工智能·笔记·学习