Cortex-A53架构(记笔记的方法)

1.前言一颗芯片最主要的就是CPU核了,处理CPUCore之外,还存在很多其他IP,包括Graphical、Multimedia、MemoryController、USBController等等。ARMproducts列出了主要产品,其中Architecture和Processors需要重点关注。Architecture扩展的四大领域:SecurityExtensio…

大家好,又见面了,我是你们的朋友全栈君。

1. 前言

一颗芯片最主要的就是CPU核了,处理CPU Core之外,还存在很多其他IP,包括Graphical、Multimedia、Memory Controller、USB Controller等等。

ARM products列出了主要产品,其中ArchitectureProcessors需要重点关注。

Architecture扩展的四大领域:

  • Security Extensions (TrustZone technology)————安全技术
  • Advanced SIMD (NEON technology)———————Single Instruction Multiple Data,单指令多数据流技术
  • Virtualization Extensions, introduced in Armv7-A.——虚拟化技术
  • Cryptographic Extensions, introduced in Armv8-A.—–

更具不同的应用场景将处理器分为三大配置:

 

同样也有对应的A、R、M三大类处理器:

Cortex-ACortex-RCortex-M,重点看Cortex-A系列:Cortex-A75Cortex-A73Cortex-A72Cortex-A57Cortex-A55Cortex-A53Cortex-A35Cortex-A32Cortex-A17Cortex-A15Cortex-A9Cortex-A8Cortex-A7Cortex-A5

其他还包括Corelink、GIC、MMU、DMA、L2 Cache、Memory、IO。

2. Cortex-A53处理器技术参考手册(ARM Cortex-A53 Processor Technical Reference Manual)

官方文档位置:https://developer.arm.com/docs/ddi0500/latest/preface

 本书阅读笔记目录如下: 

2 Functional Description

3 Programmers Model

5 Memory Management Unit

6 Level 1 Memory System

7 Level 2 Memory System

9 Generic Interrupt Controller CPU Interface

10 Generic Timer

12 Performance Monitor Unit

 

2 Functional Description

2.1 About the Cortex-A53 processor functions

Cortex-A53处理的的框架图:

Cortex-A53架构(记笔记的方法)

 

Core[n]包括 

2.2 Interfaces

2.3 Clocking and resets

2.3.1 Clocks

整个A53处理器公用一个时钟输入CLKIN,所有核和SCU使用CLKIN分发的时钟。

CLKIN经过一些使能信号转换成不同频率的时钟,有的CLKIN:XXX频比是3:1,有的是1:1。

PCLKENDBG–>PCLK

ACLKENM–>ACLKM

ACLKENS–>ACLKS

SCLKEN–>SCLK

ATCLKEN–>ATCLK

CNTCLKEN–>CNTCLK

2.3.2 Input synchronization

A53包含以下5个低有效复位信号“

nCPUPORESET[CN:0] 

nCORERESET[CN:0] 

nPRESETDBG

nL2RESET

nMBISTRESET  

这5种复位信号产生多种如下组合:

 

2.4 Power management

从Figure 2-1框架图中可以看出Core<n>包括L1 Cache、FPU、NEON、Crypto、Debug and trace等。核间公用的包括L2 cache、SCU等。

将其划分为四个Power Domain如下:

Power Domain Description More
PDCORTEXA53

This includes the SCU, the optional L2 cache controller, and debug registers described as being in the
debug domain.

此电源域应该是包括SCU、L2 cache除了RAM部分和debug。
PDL2 This includes the L2 data RAM, L2 tag RAM, L2 victim RAM, and the SCU duplicate tag RAM. 主要是L2 cache和SCU里面的RAM部分。
PDCPU<n>

This includes the optional Advanced SIMD and floating-point Extension, the L1 TLB, L1 processor
RAMs, and debug registers described as being in the processor domain.

此部分是单独Core内部的。
PDCPUADVSIMD<n> This represents the Advanced SIMD and floating-point block of core n. 仅包括某个Core内部的Advanced SIMD和FPU。

下图每种颜色对应一种电源域,可以看出哪些器件在上面四中电源域中的一种。

 Cortex-A53架构(记笔记的方法)

2.4.2 Power Modes

在上面介绍了四种电源域,这四种电源域可以单独被打开或者关闭。但并不是所有的组合都是合法或有效的。

每个电源域至此后的状态有:

Cortex-A53架构(记笔记的方法)

那么芯片支持哪几种组合的状态呢?分为两大类:处理器支持的功耗状态和核支持的功耗状态,其中核支持的功耗状态在核间是独立的。

处理器功耗状态:

Processor off所有的电源域都关闭’

L2 Cache Dormance Mode只有PDL2处于On/Ret状态。

其他都是Processor On,然后L2和Core的不同组合。

Cortex-A53架构(记笔记的方法)

核的工作状态除了Core off,必须要在PDCORTEXA53 On和PDL2 On/Ret转改下才有意义。

Cortex-A53架构(记笔记的方法)

基于上面的处理器功耗状态和核功耗状态的组合,有下面的功耗模式。

Normal state

处理器所有功能都可用,A53通过门控时钟和门控来关闭未用功能块。

Standby state(P42)

Standby state还包括三种情况Core WFI、Core WFE和L2 WFI。

Core WFI:通过关闭核中大部分时钟但保持核供电以进入低功耗模式。软件通过执行WFI指令使核进入WFI低功耗模式。

  WFI退出条件:a reset、

Core WFE:也是通过关闭核中大部分时钟但保留核供电来达到省电,只是触发的方式不一样。软件可以通过执行WFE指令使核进入低功耗模式。

  WFE退出条件:A L2 snoop request that must be serviced by the core L1 data cache

          A cache or TLB maintenance operation that must be serviced by the core L1 icache/dcache/TLB/

          An APB access to the debug or trace registers residing in the core power domain

L2 WFI:在所有核都进入WFI低功耗状态是,共用的L2也可以进入WFI低功耗状态。

  L2 WFI退出条件:A physical IRQ or FIQ

          A debug event

          Powerup or Warm reset

Individual core shutdown mode

里面详细介绍了Power down、Power up一个核的流程。

Cluster shutdown mode without system driven L2 flush

 

Cluster shutdown mode with system driven L2 flush

 

Dormant mode

Dormant模式是Cluster级别的,所有的Core和L2控制逻辑都被关闭,只有L2 cache RAM处于Power up或者retain状态。

L2 cache RAM包括:L2 tag RAM、L2 data RAM和L2 victim RAM。

Retention state

 

 2.4.4 Communication to the Power Management Controller

A53和系统电源管理控制器之间的通信有两种方式:分别是Core WFI、L2 WFI和Q-Channel。

STANDBYWFI[n]表示某个核处于idle和低功耗模式,电源管理控制器可以将此核的供电移除。

但是STANDBYWFIL2在所有核和L2都处于idle和低功耗模式才会触发。

Cortex-A53架构(记笔记的方法)

Q-Channel是一个管理设备接口时钟和电源的控制器。

3 Programmers Model

3.1 About the programmers model

Exception levels:从EL0到EL3

指令集:AArch64执行态A64指令集,AArch32执行态T32和A32指令集。

还可能包含Advanced SIMD、FPU,Cryptography。

5 Memory Management Unit

5.1 About the MMU

TLB:Translation Lookaside Buffer

Cortex-A53支持两种架构AArch32(LPAE和Virtualization Extension两种地址转换)AArch64(Long Descriptor Format地址转换)

MMU将虚拟地址转换成物理地址,MMU提供一组虚拟地址转物理地址映射以及也表中内存属性来控制存储系统。

当地址被存取时,这些数据被加载到TLB中。

 

5.2 TLB organization

IPA:Intermediate Physical Address。

Micro TLB是转换表信息的第一层缓存,在每个指令或者数据侧都有一个。

Main TLB处理Micro TLB没命中的存取,它是512-entry、4-way、set-associative结构。

IPA cache RAM:保存IPA到Physical Address的映射。

 

5.3 TLB match process

每个TLB包含一个VA、block size、PA以及类似存储类型/存取权限的属性。

 

 

6 Level 1 Memory System

6.1 About the L1 memory system

 L1包含独立的指令和数据cache,并且大小可以独立配置,8KB、16KB、32KB或64KB。

6.4 L1 Instruction memory system

L1指令cache负责提供指令流到DPU,为了提高性能和降低功耗,包括两个功能:

  • 动态分支预测
  • 指令缓存

程序流程预测主要包括三类:Predicted and non-predicted instructions、T32 state conditional branches、Return stack predictions。

6.5 L1 Data memory system

L1数据cache是物理寻址的cache,内部的TLB在访问cache之前就将虚拟地址转化成物理地址。

6.6 Data prefectching

 

7 Level 2 Memory System

7.1 About the L2 memory system

L2存储系统主要包括SCU(Snoop Control Unit)和L2 Cache。

SCU连接到Cluster中的四个核,SCU中同时保存了L1数据的备份。

L2存储系统通过AMBA 4 ACE或者AMBA 5 CHI总线和外部存储器连接,总线宽度128bit。

 

L2 cache大小有128KB、256KB、512KB、1MB。2MB。

 

7.2 Snoop Control Unit

SCP用户维护A53的核间L1数据一致性。

9 Generic Interrupt Controller CPU Interface

此部分只是关于GIC CPU Interface的概要介绍,GIC的实现细节有专门的技术参考手册介绍。

GIC CPU Interface与GIC接口,是CPU与GIC的桥梁。GIC CPU Interface和对应的GIC需要符合同样的规范,比如GICv2、GICv3、GICv4。

9.1 About the GIC CPU Interface

GIC CPU接口和外部中断分发器件集成提供了整个Cluster支持和管理中断的资源。

GIC CPU接口提供了管理中断源、中断行为、中断路由到一个或多个核的寄存器。

A53处理器GIC CPU接口实现了GICv4规范,并且和GICv3或GICv4中断分发器件接口。

GICv4架构提供如下功能:

•Two security states.
•Interrupt virtualization.
• Software-generated Interrupts (SGIs).
•Message Based Interrupts.
•System register access.
•Memory-mapped register access.
•Interrupt masking and prioritization.
•Cluster environments, including systems that contain more than eight cores.
•Wake-up events in power management environments.

 

在复位时将GICCDISABLE拉高,可以将GIC CPU接口关闭。

9.2 GIC programmers model

主要介绍GIC CPU接口相关寄存器,主要包括三部分:CPU Interface、Virtual Interface Control、Virtual CPU Interface。

每个CPU Interface模块在芯片内部提供A53和GIC分发器的接口。

Virtual Interface Control寄存器提供对A53处理器上软件配置,使其只被Hypervisor可见。

Virtual CPU Interface将虚拟中断转发到A53处理器,也遵守普通的GIC处理和优先级规则。

GIC相关阅读 – 《阅读GIC-500 Technical Reference Manual笔记

10 Generic Timer

更详细的描述在ARMv8架构参考手册的G6: AArch32 System Register Descriptions

10.1 About the Generic Timer

Generic Timer根据计数递增值产生event和触发中断。

10.2 Generic Timer functional description

A53 cluster中每个核都有一系列timer相关寄存器:EL1 Non-secure physical timer、EL1 Secure physical timer、EL2 physical timer、Virtual Timer。

A53处理器内部并不包含system counter,system counter在SoC中。

A53处理器通过CNTVALUEB[63:0]来读取system counter的值,CNTCLKEN作为CNTVALUEB时钟的使能信号。

Cortex-A53架构(记笔记的方法)

10.3 Generic Timer register summary

每个核内部都有一组Generic Timer寄存器,这些寄存器有根据32位和64位架构不同分为两类。

12 Performance Monitor Unit

A53的performance monitor版本是PMUv3,enable you to gather various statistics on the operation of the processor and its memory system during runtime。

PMU包括6个counters,每个counter可以对任何一种时间计数。

12.2 PMU functional description

Cortex-A53架构(记笔记的方法)

Event interface从各种外部单元接收事件,Counters对各种事件进行计数。通过PMU register可以对PMU各种行为进行配置,对这些寄存器的配置可以通过APB接口等。

12.5 AArch32 PMU register summary

32位架构下可以通过MCR/MRC指令获取执行状态,64位对应MCRR/MRRC。

下面是PMU寄存器列表,更详细的描述在12.6 AArch32 PMU register descriptions。 

Cortex-A53架构(记笔记的方法)

Cortex-A53架构(记笔记的方法)

12.9 Events

在对PMU基本架构和寄存器有了了解过后,再来看看都有哪些事件?

Table 12-28  PMU events给出了事件列表,主要包括L1 I、L1 D、L2 D、Exception、Branch、Bus等等。

这些事件只有在事件优化中实践一次,估计才能有具体感受。在此做个记录,知道PMU可以统计那些事件。

12.10 Interrupts

PMU产生中断然后通过触发nPMUIRQ输出。

12.11 Exporting PMU events

PMU事件有两个外部接口,一个是通过PMUEVENT,另一个是通过ETM trace。

通过Figure-14 Debug system components可以看出:

Cortex-A53架构(记笔记的方法)

在PMU Events一节可以看出不同事件是否可以输出到PMUEVENT/Trace,以及其编号。

 如何使用PMU进行性能调优呢?

 

1.Disable performance counters
2.Set what each event counter will count
3.Set cycle counter tick rate
4.Reset performance counters
5.Enable performance counters
6.Call function to profile
7.Disable performance counters
8.Read out performance counters
9.Check that performance counters did not overflow

 

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/129090.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • python把数据存入txt_python数据保存为csv文件

    python把数据存入txt_python数据保存为csv文件参考:Python中文件的读取和写入PYTHON将list或/dict对象写入txt/json文件python(如何将数据写入本地txt文本文件)python中文件写入TXTPython中将变量按行写入txt文本中python把变量写入txt文件。Python读写文件python文件操作Python之文件读写Python程序输出到文件中python把一个unicode字符串…

  • PotPlayer快捷键查询[通俗易懂]

    PotPlayer快捷键查询[通俗易懂]快捷键指令————————–常用—————————C播放->播放速度->加速+Z播放->播放速度->正常/之前的速度X播放->播放速度->减速-`…

  • eigen使用教程_kafka简单使用

    eigen使用教程_kafka简单使用Eigen是可以用来进行线性代数、矩阵、向量操作等运算的C++库,它里面包含了很多算法。它的License是MPL2。它支持多平台。Eigen采用源码的方式提供给用户使用,在使用时只需要包含Eigen的头文件即可进行使用。之所以采用这种方式,是因为Eigen采用模板方式实现,由于模板函数不支持分离编译,所以只能提供源码而不是动态库的方式供用户使用。矩阵的定义:E…

    2022年10月18日
  • 机器学习算法(一)SVM

    机器学习算法(一)SVM支持向量机(supportvectormachines,SVM)是一种二分类模型,它将实例的特征向量映射为空间中的一些点,SVM的目的就是想要画出一条线,以“最好地”区分这两类点,以至如果以后有了新的点,这条线也能做出很好的分类。SVM适合中小型数据样本、非线性、高维的分类问题。SVM最早是由VladimirN.Vapnik和AlexeyYa.Chervonenkis在1963年提出,目前的版本(softmargin)是由CorinnaCortes和Vapnik在1

  • Java安全之Commons Collections1分析(二)

    Java安全之CommonsCollections1分析(二)0x00前言续上篇文,继续调试cc链。在上篇文章调试的cc链其实并不是一个完整的链。只是使用了几个方法的的互相调用弹出一个计算器。

    2021年12月12日
  • HOG(方向梯度直方图)

    HOG(方向梯度直方图)

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号