ARM 微处理器7 种处理器模式

ARM 微处理器(以经典的 ARMv4/v5/v6 架构为例,如 ARM7、ARM9)支持 7 种处理器模式。这些模式是为了应对不同类型的异常和任务,提供不同级别的访问权限和独立的寄存器组。

以下是这 7 种模式的详细说明:

模式 简称 进入方式 特点与用途
用户模式 usr 系统上电后默认进入的模式,或通过异常返回进入。 普通程序执行模式。属于非特权模式,不能直接访问某些系统资源(如进行软件配置),也不能随意切换模式。
系统模式 sys 从特权模式(如管理、快中断等)中修改 CPSR 进入。 与用户模式共用寄存器组,但是特权模式。用于运行操作系统等需要访问系统资源的任务。
快速中断模式 fiq 当处理器接收到 FIQ 信号时自动进入。 专为需要极快响应的中断设计。拥有自己独立的 R8~R12 寄存器,从而避免了压栈操作,中断响应速度最快。常用于高速数据传输。
外部中断模式 irq 当处理器接收到 IRQ 信号时自动进入。 用于处理普通的外设中断。优先级低于 FIQ。绝大多数的设备中断都在此模式下处理。
管理模式 svc 执行 SWI(软件中断)指令,或系统复位时进入。 受保护的操作系统模式。通常用于操作系统内核,处理系统调用和复位。
中止模式 abt 当指令预取或数据访问失败(存储器异常)时自动进入。 用于处理内存访问异常,如缺页、非法访问等。分为指令预取中止和数据访问中止。
未定义模式 und 当处理器执行到一条未定义指令时自动进入。 用于软件模拟硬件协处理器,或处理未定义指令异常。

关键补充说明:

  • 特权模式与非特权模式

    • 特权模式(除用户模式外的 6 种):可以访问所有系统资源,并能自由地切换处理器模式。
    • 非特权模式(用户模式):不能访问某些受保护的资源,以保证操作系统的安全稳定。
  • 寄存器使用

    • 每个模式都拥有独立的 R13(SP,栈指针)R14(LR,链接寄存器),这保证了在进入异常或中断后,能拥有自己独立的堆栈空间,而不会破坏用户模式的栈。
    • FIQ 模式最为特殊,它拥有独立的 R8~R12,这样在中断处理中无需保存和恢复这些寄存器,从而实现了最快的上下文切换。
  • 模式切换

    • 被动切换:异常或中断发生时,处理器会自动进入对应的模式。
    • 主动切换:在特权模式下,可以通过直接修改当前程序状态寄存器(CPSR)的模式位来主动切换模式。

小结

模式名 是否为特权模式 主要功能
用户模式(usr) 运行应用程序
系统模式(sys) 运行操作系统任务
快速中断模式(fiq) 处理快速中断
外部中断模式(irq) 处理普通中断
管理模式(svc) 处理复位、软中断
中止模式(abt) 处理内存访问异常
未定义模式(und) 处理未定义指令
相关推荐
ai产品老杨3 小时前
异构计算与边缘协同:基于 X86/ARM 的企业级 AI 视频中台架构解析
arm开发·人工智能·音视频
果果燕10 小时前
ARM嵌入式学习(三)---汇编应用:LED点亮
arm开发·单片机·嵌入式硬件
凌盛羽11 小时前
在MDK-ARM编译后用python解析map文件在编译窗口输出Flash和RAM使用及剩余情况
arm开发·python·stm32·单片机·mysql·链表·esp32
炎爆的土豆翔12 小时前
NEON 入门:把它理解成 ARM 平台上的 SSE / AVX
arm开发
老师用之于民14 小时前
【DAY35】ARM开发:UART 异步串行通信原理、通信标准及模块配置详解
c语言·汇编·arm开发·vscode
ai产品老杨1 天前
异构计算时代的安防底座:基于 Docker 的 X86/ARM 双架构 AI 视频管理平台深度解析
arm开发·docker·架构
誰能久伴不乏1 天前
击碎纯逻辑的幻想:嵌入式按键底层的“物理学骗局”
arm开发
xu_wenming1 天前
在 TinyML 场景下,如何将模型从 FP32 量化为 INT8?
arm开发·算法·iot
蜕变的小白1 天前
ARM 知识点总结
arm开发