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) 处理未定义指令
相关推荐
WHS-_-20222 天前
When RDMA Meets Wireless
arm开发
szxinmai主板定制专家2 天前
基于 ARM+FPGA 数据机床实时工业控制设计--以雕刻机为例
arm开发·人工智能·嵌入式硬件·fpga开发
wandertp2 天前
对信号处理及滤波器的理解---基于robomaster机器人嵌入式控制系统
arm开发·stm32·算法·信号处理
XMAIPC_Robot2 天前
基于RK3588 ARM+FPGA电火花数控机床控制系统设计,兼顾ethercat软硬件实时
linux·arm开发·人工智能·嵌入式硬件·fpga开发
底层开发智库2 天前
C1-Ultra FVP调试并运行Linux kernel全程记录,硬核演示如何解决启动问题
linux·arm开发·内核·嵌入式·arm
XMAIPC_Robot2 天前
基于 ARM+FPGA 数据机床控制系统设计--以雕刻机为例
arm开发·fpga开发
一抹晴空2 天前
Keil MDK AC6 compiler编译报错,与AC5区别
c语言·arm开发·单片机
运维成长记2 天前
关于“有x86镜像,没有Dockerfile” 怎么制作arm架构的镜像
arm开发·架构
熠速3 天前
PolarBox高性能实时仿真系统
arm开发·fpga开发·嵌入式实时数据库·硬件在环半实物仿真
天下·第二4 天前
如何在【x86】服务器上打包构建【arm】镜像
服务器·arm开发·eureka