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) 处理未定义指令
相关推荐
时光の尘10 小时前
【嵌入式大厂面经】·IIC常见考点(持续更新中···)
arm开发·单片机·嵌入式硬件·mcu·物联网·iot
爱喝纯牛奶的柠檬11 小时前
【已验证】STM32 LoRa 环境监测与远程控制系统
arm开发·stm32·单片机·嵌入式硬件
WangLanguager1 天前
Unix架构详细介绍
arm开发·架构·unix
難釋懷1 天前
Redis网络模型-用户空间和内核态空间
网络·arm开发·redis
yuanyuan2o22 天前
从最小项目开始的 CMake 教程
c语言·开发语言·arm开发·c++·makefile·make·cmake
灵哎惹,凌沃敏2 天前
CM3/CM4内核总线知识总结
c语言·arm开发·单片机
万法若空6 天前
Cortex-A7的运行模式
linux·arm开发
ZHANG13HAO6 天前
海思 Hi3516+ML307 双模 4G 在线方案:KOL 视频 AI 不掉线、长连接稳在线
arm开发
万法若空7 天前
ARMv7-a协处理器及指令详解
arm开发
万法若空7 天前
ARM汇编程序设计基础
arm开发