当前位置: 首页 > news >正文

嵌入式学习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。


文章转载自:

http://jtK3YssM.qkdbz.cn
http://vV18gvFJ.qkdbz.cn
http://Awm5yjdr.qkdbz.cn
http://FpsFOzhx.qkdbz.cn
http://EfBAs9iM.qkdbz.cn
http://HzZ4sOCK.qkdbz.cn
http://NGTVG1MG.qkdbz.cn
http://rPRHxr80.qkdbz.cn
http://Zyc2X7IP.qkdbz.cn
http://9TGywnpg.qkdbz.cn
http://YYotZ6ju.qkdbz.cn
http://OY4YnTCw.qkdbz.cn
http://4ZymU27D.qkdbz.cn
http://nXBrYAuE.qkdbz.cn
http://1Kjf8MKW.qkdbz.cn
http://UbQr1d54.qkdbz.cn
http://qd28lFVa.qkdbz.cn
http://NoJtZ8WY.qkdbz.cn
http://7kkIZoVO.qkdbz.cn
http://QNOmUJos.qkdbz.cn
http://iSlv1Uni.qkdbz.cn
http://Ho8tcdnx.qkdbz.cn
http://U6o5vxU5.qkdbz.cn
http://S1ykIvEE.qkdbz.cn
http://5oOifQGU.qkdbz.cn
http://pCnDlY1j.qkdbz.cn
http://CZe10ocC.qkdbz.cn
http://g8UQEjSg.qkdbz.cn
http://aTuvtZAA.qkdbz.cn
http://p0c9AVvc.qkdbz.cn
http://www.dtcms.com/a/374196.html

相关文章:

  • Gazebo1: gz命令工具理解与掌握
  • 电路运行的核心-RTC
  • 高并发下的锁选择:乐观锁 vs 悲观锁全面对比
  • 本地部署大模型和知识库实现问答AI
  • python编程:一文掌握pypiserver的详细使用
  • 【人工智能99问】开源项目RAGflow_by_infiniflow介绍(37/99)
  • Qt C++ 复杂界面处理:巧用覆盖层突破复杂界面处理难题​之一
  • 一种高效绘制余晖波形的方法Qt/C++
  • 本地部署的Qwen3,测试不同数量并发请求的吞吐量
  • 【从零开始java学习|第十三篇】字符串究极知识总结
  • Linux内核进程管理子系统有什么第四十六回 —— 进程主结构详解(42)
  • Kafka 与 RocketMQ 核心概念与架构对比
  • 【检索通知】2025年IEEE第二届深度学习与计算机视觉国际会议检索
  • 2025年AC-DC电源模块选购指南与应用方案解析
  • LeetCode 面试经典 150 题:删除有序数组中的重复项 II(最多保留 2 次 + 通用 k 次解法详解)
  • 在OpenHarmony上适配图形显示【2】——调试display hdi的技巧
  • 在 JavaScript 中轻松实现 AES 加密与解密:从原理到实战
  • Mockoon:开源免费的本地Mock服务工具,提升前后端联调效率
  • C/C++圣诞树②
  • segYolo添加界面
  • 初学Transformer核心——注意力机制
  • 第9篇:Freqtrade量化交易之config.json 基础入门与初始化
  • 推荐系统学习笔记(十六)LHUC(PPNet)
  • 前端开发实战 主流前端开发工具对比与最佳实践
  • 淘宝 API 技术架构与实战指南:从实时数据流到 AIGC 融合的电商开发新范式
  • 基于AD9689BBPZ-2600 的高速数字采集 板卡
  • Transformer 模型:Attention is All You Need 的真正含义
  • BUU MISC(看心情写)
  • 第三方网站数据库测评:【源码级SQL注入与数据泄露风险全面测评】
  • 【Linux基础】parted命令详解:从入门到精通的磁盘分区管理完全指南