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

Cortex-A7 MPCore 架构

鉴于学习的硬件使用的是Cortex-A7架构,本章学习该架构的相关知识。了解了 Cortex-A7 架构以后有利于我们后面的学习,因为后面有很多例程涉及到 Cortex-A7 架构方面的知识,比如处理器模型、 Cortex-A7 寄存器组等等。

Cortex-A7 MPCore 简介

Cortex-A7 MPcore 处理器支持 1~4 核,通常是和 Cortex-A15 组成 big.LITTLE 架构的, Cortex-A15 作为大核负责高性能运算,比如玩游戏啥的, Cortex-A7 负责普通应用,因为 Cortex-A7 省电。 Cortex-A7 本身性能也不弱,不要看它叫做 Cortex-A7 但是它可是比 Cortex-A8 性能要强大,而且更省电。 ARM 官网对于 Cortex-A7 的说明如下:
“在 28nm 工艺下, Cortex-A7 可以运行在 1.2~1.6GHz,并且单核面积不大于 0.45mm2(含有浮点单元、 NEON 和 32KB 的 L1 缓存),在典型场景下功耗小于 100mW, 这使得它非常适合对功耗要求严格的移动设备,这意味着 Cortex-A7 在获得与 Cortex-A9 相似性能的情况下,其功耗更低”。
Cortex-A7 MPCore 支持在一个处理器上选配 1~4 个内核, Cortex-A7 MPCore 多核配置如图所示:

Cortex-A7 MPCore 的 L1 可选择 8KB、 16KB、 32KB、 64KB, L2 Cache 可以不配,也可以选择 128KB、 256KB、 512KB、 1024KB。 I.MX6UL 配置了 32KB 的 L1 指令 Cache 和 32KB的 L1 数据 Cache,以及 128KB 的 L2 Cache。 Cortex-A7MPCore 使用 ARMv7-A 架构,主要特性如下:

①、 SIMDv2 扩展整形和浮点向量操作。
②、提供了与 ARM VFPv4 体系结构兼容的高性能的单双精度浮点指令,支持全功能的 I
EEE754。
③、支持大物理扩展(LPAE),最高可以访问 40 位存储地址,也就是最高可以支持 1TB 的
内存。
④、支持硬件虚拟化。
⑥、支持 Generic Interrupt Controller(GIC)V2.0。
⑦、支持 NEON,可以加速多媒体和信号处理算法。

Cortex-A 处理器运行模型

以前的 ARM 处理器有 7 中运行模型: User、 FIQ、 IRQ、 Supervisor(SVC)、 Abort、 Undef和 System,其中 User 是非特权模式,其余 6 中都是特权模式。但新的 Cortex-A 架构加入了 TrustZone 安全扩展,所以就新加了一种运行模式: Monitor,新的处理器架构还支持虚拟化扩展,因此又加入了另一个运行模式: Hyp,所以 Cortex-A7 处理器有 9 种处理模式,如表所示:

除了 User(USR)用户模式以外,其它 8 种运行模式都是特权模式,这几个运行模式可以通过软件进行任意切换,也可以通过中断或者异常来进行切换。

大多数的程序都运行在用户模式,用户模式下是不能访问系统所有资源的,有些资源是受限的,要想访问这些受限的资源就必须进行模式切换。但是用户模式是不能直接进行切换的,用户模式下需要借助异常来完成模式切换,当要切换模式的时候,应用程序可以产生异常,在异常的处理过程中完成处理器模式切换。

当中断或者异常发生以后,处理器就会进入到相应的异常模式种,每一种模式都有一组寄
存器供异常处理程序使用,这样的目的是为了保证在进入异常模式以后,用户模式下的寄存器
不会被破坏。

相比起STM32,STM32 只有两种运行模式,特权模式和非特权模式,但是 Cortex-A 就有 9 种运行模式。

Cortex-A 寄存器组

本节我们要讲的是 Cortex-A 的内核寄存器组,注意不是芯片的外设寄存器
ARM 架构提供了 16 个 32 位的通用寄存器(R0~R15)供软件使用,前 15 个(R0~R14)可以用作通用的数据存储, R15 是程序计数器 PC,用来保存将要执行的指令。 ARM 还提供了一个当前程序状态寄存器 CPSR 和一个备份程序状态寄存器 SPSR, SPSR 寄存器就是 CPSR 寄存器的备份。这 18 个寄存器如图所示:

9 种运行模式,每一种运行模式都有一组与之对应的寄存器组。每一种模式可见的寄存器包括 15 个通用寄存器(R0~R14)、一两个程序状态寄存器和一个程序计数器 PC。在这些寄存器中,有些是所有模式所共用的同一个物理寄存器,有一些是各模式自己所独立拥有的,各个模式所拥有的寄存器如下表所示:

图中浅色字体的是与 User 模式所共有的寄存器蓝绿色背景的是各个模式所独有的寄存器。可以看出,在所有的模式中,低寄存器组(R0~R7)是共享同一组物理寄存器的,只是一些高寄存器组在不同的模式有自己独有的寄存器,比如 FIQ 模式下 R8~R14 是独立的物理寄存器。假如某个程序在 FIQ 模式下访问 R13 寄存器,那它实际访问的是寄存器 R13_fiq,如果程序处于 SVC 模式下访问 R13 寄存器,那它实际访问的是寄存器 R13_svc。总结一下, Cortex-A 内核寄存器组成如下:
①、 34 个通用寄存器,包括 R15 程序计数器(PC),这些寄存器都是 32 位的。
②、 8 个状态寄存器,包括 CPSR 和 SPSR。
③、 Hyp 模式下独有一个 ELR_Hyp 寄存器。

理解

1. 第一组:R0 ~ R7 【全模式共用】
  • 比喻酒店大堂的公共储物柜
  • 看图:User、Sys、FIQ、IRQ…… 这几列,R0 到 R7 下面的格子全部都是一样的
  • 解释:不管你当前是什么身份(User/SVC/IRQ 等),R0~R7 永远指向同一个物理柜子
  • 结果:如果你在 User 模式往 R0 放了个数据 100,那你切到 IRQ 模式看 R0,里面也是 100。大家共用,容易被覆盖。
2. 第二组:R8 ~ R12 【大部分共用,FIQ 独有】
  • 比喻普通楼层的淋浴间(大家一般共用一套,但 FIQ 是 VIP,有独立淋浴间)。
  • 看图
    • User、Sys、IRQ、ABT、SVC、UND、MON 这些列里,R8~R12 是同一套
    • 但是!FIQ 模式列下面写的是R8_fiq~R12_fiq,和别人不一样。
  • 解释
    • 除了 FIQ 模式,其他人用的是同一组高寄存器。
    • FIQ 模式有自己独有的一组R8~R12。
    • 这就意味着 FIQ 快速中断来了,不用花时间保存原来的数据,直接用自己的新房间,所以 FIQ 很快。
3. 第三组:R13 (SP) ~ R14 (LR) 【每个模式都独有】
  • 比喻每个模式的专属卧室 + 衣帽间
  • 看图
    • 看 R13 (SP) 这一列:User 是R13_usr,IRQ 是SP_irq,SVC 是SP_svc。每一列的后缀都不一样。
    • R14 (LR) 也是一样:IRQ 是LR_irq,SVC 是LR_svc
  • 解释
    • R13 (栈指针 SP):每个模式都有自己的(自己的地盘),不能乱共用。比如 SVC 模式的栈不能覆盖 IRQ 的栈。
    • R14 (链接寄存器 LR):每个模式发生异常时,返回地址存在自己的 LR 里,互不干扰
    • 你图里的那句话:“FIQ 访问 R13 是 R13_fiq,SVC 访问 R13 是 R13_svc”。
    • 翻译:你在不同身份(模式)下,喊同一个名字 R13,系统实际上会带你去不同的物理房间(R13_usr / R13_fiq)。
4. 第四组:R15 (PC) 【全模式共用】
  • 比喻酒店的总时钟 / 日历
  • 看图:所有模式列下面的 R15 都是一样的。
  • 解释:程序计数器 PC,全天下 CPU 只有一个,大家都在看它指向哪里,必须统一。
5. 第五组:CPSR / SPSR 【状态标志位】
  • CPSR当前房间的总开关(存当前是哪个模式、标志位)。
  • SPSR异常前的备份开关(比如 IRQ 来了,把原来的 CPSR 备份到 SPSR_irq 里,恢复时再拿回来)。

通用寄存器

R0~R15 就是通用寄存器,通用寄存器可以分为以下三类:
①、 未备份寄存器,即 R0~R7。
②、 备份寄存器,即 R8~R14。
③、程序计数器 PC,即 R15。

未备份寄存器

未备份寄存器指的是 R0~R7 这 8 个寄存器,因为在所有的处理器模式下这 8 个寄存器都是同一个物理寄存器,在不同的模式下,这 8 个寄存器中的数据就会被破坏。所以这 8 个寄存器并没有被用作特殊用途。

备份寄存器

备份寄存器中的 R8~R12 这 5 个寄存器有两种物理寄存器,在快速中断模式下(FIQ)它们对应着 Rx_irq(x=8~12)物理寄存器,其他模式下对应着 Rx(8~12)物理寄存器。 FIQ 是快速中断模式,看名字就是知道这个中断模式要求快速执行! FIQ 模式下中断处理程序可以使用 R8~R12寄存器,因为 FIQ 模式下的 R8~R12 是独立的,因此中断处理程序可以不用执行保存和恢复中断现场的指令,从而加速中断的执行过程。

备份寄存器 R13 一共有 8 个物理寄存器,其中一个是用户模式(User)系统模式(Sys)共用的,剩下的 7 个分别对应 7 种不同的模式。 R13 也叫做 SP,用来做为栈指针。基本上每种模式都有一个自己的 R13 物理寄存器,应用程序会初始化 R13,使其指向该模式专用的栈地址,这就是常说的初始化 SP 指针。

备份寄存器 R14 一共有 7 个物理寄存器,其中一个是用户模式(User)、系统模式(Sys)和超级监视模式(Hyp)所共有的,剩下的 6 个分别对应 6 种不同的模式。 R14 也称为连接寄存器(LR), LR 寄存器在 ARM 中主要用作如下两种用途:

①、每种处理器模式使用 R14(LR)来存放当前子程序的返回地址,如果使用 BL 或者 BLX来调用子函数的话, R14(LR)被设置成该子函数的返回地址,在子函数中,将 R14(LR)中的值赋给R15(PC)即可完成子函数返回,比如在子程序中可以使用如下代码:
MOV PC, LR @寄存器 LR 中的值赋值给 PC,实现跳转
或者可以在子函数的入口出将 LR 入栈:
PUSH {LR} @将 LR 寄存器压栈
在子函数的最后面出栈即可:

POP {PC}@将上面压栈的 LR 寄存器数据出栈给 PC 寄存器,严格意义上来讲应该是将
@LR-4 赋给 PC,因为 3 级流水线,这里只是演示代码。

②、当异常发生以后,该异常模式对应的 R14 寄存器被设置成该异常模式将要返回的地址,
R14 也可以当作普通寄存器使用。

程序计数器 R15

程序计数器 R15 也叫做 PC, R15 保存着当前执行的指令地址值加 8 个字节,这是因为 ARM 的流水线机制导致的。 ARM 处理器 3 级流水线:取指->译码->执行,这三级流水线循环执行,比如当前正在执行第一条指令的同时也对第二条指令进行译码,第三条指令也同时被取出存放在 R15(PC)中。我们喜欢以当前正在执行的指令作为参考点,也就是以第一条指令为参考点,那么 R15(PC)中存放的就是第三条指令,换句话说就是 R15(PC)总是指向当前正在执行的指令地址再加上 2 条指令的地址。对于 32 位的 ARM 处理器,每条指令是 4 个字节,所以:

R15 (PC)值 = 当前执行的程序位置 + 8 个字节。

程序状态寄存器

所有的处理器模式都共用一个 CPSR 物理寄存器,因此 CPSR 可以在任何模式下被访问。
CPSR 是当前程序状态寄存器,该寄存器包含了条件标志位、中断禁止位、当前处理器模式标志等一些状态位以及一些控制位。所有的处理器模式都共用一个 CPSR 必然会导致冲突,为此,除了 User 和 Sys 这两个模式以外,其他 7 个模式每个都配备了一个专用的物理状态寄存器,叫做 SPSR(备份程序状态寄存器),当特定的异常中断发生时, SPSR 寄存器用来保存当前程序状态寄存器(CPSR)的值,当异常退出以后可以用 SPSR 中保存的值来恢复 CPSR。

因为 User 和 Sys 这两个模式不是异常模式,所以并没有配备 SPSR,因此不能在 User 和 Sys 模式下访问 SPSR,会导致不可预知的结果。由于 SPSR 是 CPSR 的备份,因此 SPSR 和 CPSR 的寄存器结构相同,如图所示:

CPSR寄存器

N(bit31):当两个补码表示的 有符号整数运算的时候, N=1 表示运算对的结果为负数, N=0 表示结果为正数。
Z(bit30):Z=1 表示运算结果为零, Z=0 表示运算结果不为零,对于 CMP 指令, Z=1 表示进行比较的两个数大小相等。
C(bit29):在加法指令中,当结果产生了进位,则 C=1,表示无符号数运算发生上溢,其它情况下 C=0。在减法指令中,当运算中发生借位,则 C=0,表示无符号数运算发生下溢,其它情况下 C=1。对于包含移位操作的非加/减法运算指令, C 中包含最后一次溢出的位的数值,对于其它非加/减运算指令, C 位的值通常不受影响。
V(bit28):对于加/减法运算指令,当操作数和运算结果表示为二进制的补码表示的带符号数时, V=1 表示符号位溢出,通常其他位不影响 V 位。
Q(bit27):仅 ARM v5TE_J 架构支持,表示饱和状态, Q=1 表示累积饱和, Q=0 表示累积不饱和。
IT[1:0](bit26:25):和 IT[7:2](bit15:bit10)一起组成 IT[7:0],作为 IF-THEN 指令执行状态。
J(bit24):仅 ARM_v5TE-J 架构支持, J=1 表示处于 Jazelle 状态,此位通常和 T(bit5)位一
起表示当前所使用的指令集

JT描述
00ARM
01Thumb
11

ThumbEE

10Jazelle

GE[3:0](bit19:16):SIMD 指令有效,大于或等于。
IT[7:2](bit15:10):参考 IT[1:0]。
E(bit9):大小端控制位, E=1 表示大端模式, E=0 表示小端模式。
A(bit8):禁止异步中断位, A=1 表示禁止异步中断。
I(bit7):I=1 禁止 IRQ, I=0 使能 IRQ。
F(bit6):F=1 禁止 FIQ, F=0 使能 FIQ。
T(bit5):控制指令执行状态,表明本指令是 ARM 指令还是 Thumb 指令,通常和 J(bit24)一起表明指令类型,参考 J(bit24)位。
M[4:0]:处理器模式控制位,含义如表所示

二编:补充一点寄存器理解

你(CPU)去内存(大仓库)取材料(数据)来加工,但内存太远了,跑一趟很慢。所以你在面前摆了 40 个工位(寄存器),把最常用的材料、半成品、工作计划表都放在手边,这样干活就飞快。

第一类:通用寄存器 (R0-R12) —— 临时工位

这是 13 个(R0-R12)可以随便用的临时工位。你可以把任何数字、地址暂时放在这里,加减乘除。

  • R0-R7:普通工位,任何时候都能用。

  • R8-R12:大部分时间也是普通工位。但有一种叫FIQ(快速中断)的紧急情况发生时,CPU 会瞬间切换到另一套专属工位。这样它就不用花时间收拾你留下的烂摊子,直接开工,所以叫“快速”。

一句话:R0-R12 就是你的草稿纸,随便写,但小心被系统紧急任务给覆盖了。

第二类:专用寄存器 (R13, R14, R15) —— 特殊功能工位

这三个不能乱用,各有专职:

R13 (SP, Stack Pointer,栈指针)
  • 功能:指向栈内存的当前位置。

  • 白话:栈就像一张堆纸。SP 指着“下一张空白纸在哪”。你要临时存点东西(比如:去厕所前把工作进度记下来),就放在 SP 指的地方,然后 SP 自动移到下一个空白处。回来时,从 SP 指回的地方把进度取出来。

  • 重点每种工作模式(比如用户态、中断态)都有自己的专属 SP,互不干扰。所以切换模式时,不会弄乱别人的栈。

R14 (LR, Link Register,链接寄存器)
  • 功能记住回家的路

  • 白话:你正在 A 点干活,突然要去 B 点执行一个子任务。出发前,LR 会自动记下“A 点 + 8 个字节”这个地址(因为流水线原因,不是 A 点本身)。在 B 点干完活,执行MOV PC, LR就能跳回 LR 记录的地址,继续 A 点的活。

  • 另一个用途:发生异常(比如中断)时,LR 会记下“异常返回后应该去哪”。这就像你正走路,突然被绊了一下(异常),你的脑子记下“站稳后继续往前走”,然后去处理绊倒这件事。

R15 (PC, Program Counter,程序计数器)
  • 功能指向当前正在执行的指令(严格说是指向 +8 字节处的指令,因为流水线)。

  • 白话:PC 就像一个指挥棒,指着 CPU 当前要执行哪一行代码。CPU 执行完一行,PC 自动移到下一行。你也可以强行把某个地址写进 PC(比如MOV PC, LR),这就会让 CPU 跳去执行那个地址的代码,实现函数调用或返回。

总结

  • R13 (SP):指向“栈顶”,用于临时保存数据(如函数局部变量、返回地址)。

  • R14 (LR):调用函数时,自动保存返回地址

  • R15 (PC):指向当前执行的指令,控制程序流程。


第三类:状态寄存器 (CPSR/SPSR) —— 记录器与快照

这是一个32 位的状态面板(每位是一个开关/标志),记录着 CPU 当前的状态。

CPSR (Current Program Status Register,当前程序状态寄存器)
  • 功能:实时反映 CPU 的运行状态。

  • 白话:CPSR 就像汽车的仪表盘,告诉你当前速度、油量、哪个灯亮了。

它的主要位段:

名称含义(白话)
31N(Negative)上一步运算结果是负数吗?(是→1,否→0)
30Z(Zero)上一步运算结果是零吗?(是→1,否→0)
29C(Carry)加法产生进位/减法产生借位了吗?(产生→1/0)
28V(oVerflow)有符号数运算溢出(结果超出范围)了吗?(溢出→1)
7I(IRQ)普通中断总开关(1=关,0=开)
6F(FIQ)快速中断总开关(1=关,0=开)
5T(Thumb)当前是 ARM 指令集(0)还是 Thumb 指令集(1)
4-0M[4:0]当前 CPU 处于哪种模式(用户、系统、中断、管理...)
SPSR (Saved Program Status Register,保存的程序状态寄存器)
  • 功能:当发生异常(中断、错误等)时,自动保存CPSR 的快照

  • 白话:就像游戏里的自动存档。当 CPU 被紧急事件打断时,它会把当前的 CPSR(仪表盘状态)存到 SPSR 里,然后去处理紧急事件。处理完后,再从 SPSR 恢复 CPSR,就像读档一样,CPU 就能回到打断前的状态继续运行。

注意:只有UserSystem模式没有 SPSR(因为它们不是异常模式)。

一句话总结

  • CPSR:当前 CPU 状态仪表盘。

  • SPSR:异常发生时的 CPSR 备份,用于恢复现场。


整体串联:一个函数调用的故事

假设 CPU 正在执行main()

  1. R15 (PC)指着main()里的某条指令。

  2. R13 (SP)指着当前栈顶,存放着main()的局部变量。

  3. CPSR的 I 和 F 位可能为 0(开中断),M 位是 0b10000(用户模式)。

现在执行bl add_function(调用加法函数):

  1. CPU 自动

    • 返回地址(当前 PC + 4 或 8)存入R14 (LR)

    • CPSR备份到SPSR(如果切换模式)。

    • 修改PCadd_function的地址,跳转过去。

    • 可能切换模式(如从 User 切到 Supervisor),R13 (SP)自动切换到该模式的专属栈。

  2. add_function里:

    • 可以用PUSH {LR}把 R14 压入栈(防止嵌套调用时丢失返回地址)。

    • 计算结果放在 R0 里(ARM 约定 R0 作为返回值)。

  3. 执行POP {PC}

    • 从栈中弹出之前保存的 LR 值到PC,实现返回。

    • 如果切换了模式,硬件会从SPSR恢复CPSR

  4. CPU 回到main()继续执行,所有状态恢复如初。


你需要记住的核心

  1. R0-R12:草稿纸,随便用,但要小心 FIQ 模式下的 R8-R12。

  2. R13 (SP):栈指针,每种模式有自己的栈。

  3. R14 (LR):保存返回地址。

  4. R15 (PC):当前执行的指令地址。

  5. CPSR:CPU 状态仪表盘(标志位 + 模式 + 中断开关)。

  6. SPSR:异常时的 CPSR 自动备份,用于恢复。

对于写 ARM 汇编(比如 led.s):主要会用 R0-R12 来操作数据,用 R14 (LR) 返回,用 R15 (PC) 跳转。CPSR 的 N、Z、C、V 标志位会在你执行条件跳转(如beq跳转到 label)时自动被判断。

文章部分内容参考正点原子教程

http://www.jsqmd.com/news/638515/

相关文章:

  • 用MediaPipe Objectron和Python做个AR小玩具:实时把桌上的杯子“抓”到屏幕里
  • 手把手教你用LKS32MC07x配置无刷电机PWM(含死区时间与中心对齐模式详解)
  • Hitboxer SOCD清理器架构解析:游戏按键重映射系统的深度优化
  • 忍者像素绘卷:天界画坊算法优化实践:提升像素艺术生成效率
  • IT服务台投入越来越高,效率却没有提升?企业正在忽视的ITSM系统成本陷阱
  • 全球最小气雾化制粉设备问世:上海研倍新材颠覆传统路径,低气压循环氩气技术降低能耗90% - 企业推荐官【官方】
  • 终极WeMod专业版免费解锁指南:Wand-Enhancer完整教程
  • 揭秘万商卡变现线上平台的优选技巧,轻松获取现金! - 团团收购物卡回收
  • 终极B站会员购抢票神器:告别手速比拼,轻松获取心仪漫展门票
  • 做泰国外贸生意,企业该如何预防合作骗局?
  • MogFace人脸检测模型-WebUI实战教程:使用ffmpeg抽帧+批量检测实现视频人脸分析
  • 通义千问2.5-7B本地部署实战:4GB显存低成本运行方案
  • NVIDIA Profile Inspector终极指南:解锁显卡隐藏设置,轻松提升游戏性能
  • 2026 年优质网站建设公司大盘点:助力企业开启数字化新征程 - 企业推荐官【官方】
  • 握拍姿势的正确掌握
  • LangExtract实战:用Ollama本地部署,零成本为你的私有知识库构建实体抽取引擎
  • 双频 WiFi 机柜天线:2.4G+5.8G 全覆盖无死角
  • 视觉导航Agent的“认知盲区”图谱(基于奇点大会17家头部企业217个真实场景故障日志)
  • 1.2 希腊字母速查表 + 公式阅读实战
  • 医疗用气电混合连接器:实现安全性与稳定性平衡的实用技巧
  • 靠谱的圆形冷却塔生产厂怎么选,解读专业加工厂费用情况 - 工业推荐榜
  • Ostrakon-VL-8B集成Node.js实战:构建智能图片描述REST API
  • 吉林周边陶粒仓库现货
  • Qwen3.5-9B-AWQ-4bit网络协议分析与故障模拟实战
  • 2026年深度测评:蚂蚁GEO优化究竟涵盖了哪些平台?
  • 零基础入门TensorFlow-v2.9:SSH远程调优常见问题解答
  • React Hooks 状态更新机制剖析
  • 【亲测可用】图片批量无痕去杂物?聊聊我最近用的一款高效工具
  • 终极NS-USBLoader使用指南:三分钟掌握Switch文件传输与RCM注入
  • 口碑好的学生窗帘定制厂家聊聊,艺术学校学生窗帘定制靠谱推荐 - mypinpai