内容摘录自正点原子文档

Cortex-A7 MPCore 简介

Cortex-A7 MPcore 处理器支持 1-4 核,在 28nm 工艺下,Cortex-A7 可以运行在1.2-1.6GHz,Cortex-A7 在获得与 Cortex-A9 相似性能的情况下,其功耗更低。Cortex-A7 MPCore 支持在一个处理器上选配 1-4 个内核,Cortex-A7 MPCore 多核配置如图:
L1 可选择 8KB、16KB、32KB、64KB,
L2L2 Cache 可以不配,也可以选择 128KB、256KB、512KB、1024KB。
比如:
I.MX6UL 配置了 32KB 的 L1 指令 Cache 和 32KB 的
L1 数据 Cache,以及 128KB 的 L2 Cache。

Cortex-A7MPCore 使用 ARMv7-A 架构,主要特性如下:

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

Cortex-A 处理器运行模型

以前的 ARM 处理器有 7 中运行模型:User、FIQ、IRQ、Supervisor(SVC)、Abort、Undef和 System,其中 User 是非特权模式,其余 6 中都是特权模式。但新的 Cortex-A 架构加入了TrustZone 安全扩展,所以就新加了一种运行模式:Monitor,新的处理器架构还支持虚拟化扩展,因此又加入了另一个运行模式:Hyp,所以 Cortex-A7 处理器有 9 种处理模式,如表所示:
上述表中,除了user模式以外,其他都是特权模式,并且可以任意切换,也可以通过中断或者异常来切换,大多数程序运行在用户模式,用户模式权限有限,特殊权限访问需要去切换模式。通过应用程序产生异常来切换模式。
当中断或者异常发生以后,处理器就会进入到相应的异常模式中,每一种模式都有一组寄存器供异常处理程序使用,这样的目的是为了保证在进入异常模式以后,用户模式下的寄存器不会被破坏。

Cortex-A 寄存器组

ARM 架构提供了 16 个 32 位的通用寄存器(R0-R15)供软件使用,前 15 个(R0~R14)可以用作通用的数据储,R15 是程序计数器 PC,用来保存将要执行的指令。ARM 还提供了一个当前程序状态寄存器CPSR和一个备份程序状态寄存器SPSR,SPSR 寄存器就是CPSR 寄存器的备份。这 18 个寄存器如图所示:

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


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

通用寄存器

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

1、未备份寄存器

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

2、备份寄存器
备份寄存器中的 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 也可以当作普通寄存器使用。

3、程序计数器 R15

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

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

6.3.2 程序状态寄存器

所有的处理器模式都共用一个 CPSR 物理寄存器,因此 CPSR 可以在任何模式下被访问。CPSR 是当前程序状态寄存器,该寄存器包含了条件标志位、中断禁止位、当前处理器模式标志等一些状态位以及一些控制位。所有的处理器模式都共用一个 CPSR 必然会导致冲突,为此,除了 User 和 Sys 这两个模式以外,其他 7 个模式每个都配备了一个专用的物理状态寄存器,叫做 SPSR(备份程序状态寄存器),当特定的异常中断发生时,SPSR 寄存器用来保存当前程序状态寄存器(CPSR)的值,当异常退出以后可以用 SPSR 中保存的值来恢复CPSR。因为 User 和 Sys 这两个模式不是异常模式,所以并没有配备 SPSR,因此不能在 User 和Sys 模式下访问 SPSR,会导致不可预知的结果。由于 SPSR 是 CPSR 的备份,因此 SPSR 和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]和 IT[7:2])(bit15:bit10)一起组成 IT[7:0],作为 IF-THEN 指令执行状态。

J(bit24):仅 ARM_v5TE-J 架构支持,J=1 表示处于 Jazelle 状态,此位通常和 T(bit5)位一起表示当前所使用的指令集,如表 6.3.2.1 所示



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]:处理器模式控制位,含义如表 6.3.2.2 所示:

Cortex-A7 MPCore 架构相关推荐

  1. cortex—A7 cortex—A9 cortex—A53

    晕了,不去了解就敷衍回答是不负责任的!这里回答的人居然都想当然的回答A9比A7新,A7是刚刚才推出的最新架构,比神马A8,A9,A15,A5都要新,28mm制程,高性能,低功耗. Cortex-A7 ...

  2. A7跑linux芯片,ST意法半导法发布第一款Cortex A7架构处理器芯片

    最近,意法半导体推出其第一款Cortex A7架构的处理器芯片系列,STM32MP1.不仅有双核A7, 内部还有Cortex M4,来运行一些低功耗的任务. STM32MP1有三种型号: STM32M ...

  3. i.MX6UL: i.MX 6UltraLite处理器 - 低功耗,安全,Arm® Cortex®-A7内核

    i.MX6UL: i.MX 6UltraLite处理器 - 低功耗,安全,Arm® Cortex®-A7内核 概述 i. MX6UltraLite作为i.MX6系列的扩展,一系列高性能.超高效的处理器 ...

  4. stm32mp1安装linux系统,stm32mp1linux开发环境搭建(cortex a7)

    原标题:stm32mp1linux开发环境搭建(cortex a7) 写在前面: 本文章为<STM32MP1系列教程之Cortex-A7开发篇>系列中的一篇,全系列总计11篇.笔者使用的开 ...

  5. Cortex M3内核架构

    CortexM3内核架构 宗旨:技术的学习是有限的,分享的精神是无限的. 1.ARMCortex-M3处理器 Cortex-M3处理器内核是单片机的中央处理单元( CPU). 完整的基于CM3的MCU ...

  6. linux 返回非法指令,linux – ARM Cortex A7在内核模式下返回PMCCNTR = 0,在用户模式下返回非法指令(即使在PMUSERENR = 1之后)...

    我想在Raspberry Pi 2上读取循环计数寄存器(PMCCNTR),它有一个ARM Cortex A7内核.我为它编译了一个内核模块,如下所示: #include #include int in ...

  7. 4核a5中断linux,Cortex A5 MPcore寄存器TPIDRPRW复位值不为零,造成Linux Kernel不能启动的问题...

    问题现象: Cortex A5 MPcore寄存器TPIDRPRW复位值不为零,造成Linux Kernel不能启动的问题. 问题原因分析: 由于Linux Kernel内核配置使能了CONFIG_T ...

  8. STM32MP157C-DK2->Develop on Arm® Cortex®-A7之 C语言开发uart例程

    编写C代码开启STM32MP157C-DK2开发板上的uart7的接收功能,并将收到的数据打印到控制台,并通过uart7发送出"uart"字符串. STM32MP157C-DK2的 ...

  9. ARM Cortex A7 架构简介

    Cortex-A7 MPCore 简介 MP表示是多核的意思,Cortex-A7 MPcore 处理器支持 1~4 核,A7主打低功耗,因此多用于运行普通应用,通常和Cortex-A15 组成 big ...

  10. Cortex - A7架构的基本资料

    A7支持一到四核,是小核,通常与大核如Cortex - A15 配合,大核负责高性能运算,小核负责普通应用.A7性能堪比A9,但是lower power A7有九种运行模式,我们常用的是 user用户 ...

最新文章

  1. 在嵌入式学习过程中,很多人都有这样的困惑!——为什么要学习嵌入式技术?...
  2. Qt5 中 QWebEngineView 的使用,让桌面客户端和 web 端友好通信
  3. [c++]Struct和Class的区别
  4. [Node.js] 模块化 -- http服务器模块
  5. 分享一个导出数据到 Excel 的类库
  6. tensorflow2.0内存溢出解决办法
  7. zktime 协议_zktime5.0考勤管理系统使用说明书(1.2版).pdf
  8. 编辑器 UEditor 百度富文本web编辑器
  9. 共阳极管的代码_共阳极数码管显示
  10. 企业微信打卡怎么防止作弊?看看其他企业是怎么做的
  11. Webpack前端资源加载/打包工具
  12. 截至2022年12月共计451个信息安全国家标准汇总
  13. 逻辑运算符及其优先级,C语言逻辑运算符及其优先级详解
  14. 除了闹过腥风血雨的fastjson,你还知道哪些Java解析JSON的利器?
  15. Ubuntu: failed to fetch
  16. 梦幻哪个服务器最多牛人,梦幻西游:盘点经久不衰的十大火区!你所在的服务器是否上榜?...
  17. ThinkPad笔记本风扇转速控制软件
  18. 工业树莓派的应用:助力构建智慧能源管理系统
  19. 幼儿抽象逻辑思维举例_孩子嘴巴巧不巧,逻辑思维能力很关键,玩一玩这些游戏有帮助...
  20. 网站不写SEO文案? SEO就算了吧!

热门文章

  1. Java实现anagram算法
  2. 十年互联网,十个风云人物——历史会记住他们!
  3. 商品进销差价_商品进销差价如何计算及账务处理怎么做?
  4. python实现whois查询_python实现whois查询功能的方法
  5. 怎么美化Typora的标题格式
  6. 【codecademy笔记1】
  7. 小程序Progress组件介绍
  8. 【AAAI2022】FDIWN - Feature Distillation Interaction Weighting Network for Lightweight Image SR
  9. Cesium离线地图极简教程
  10. 开发者 发展 程序物语