ARMv8-A architecture overview

从今天起,正式学习ARMv8-A架构的知识,其中会涉及到ARMv7-A的一些知识,用来和ARMv8-A做对比使用。

学习过程中使用的文档:

首先来看下ARM架构演进的一个过程

从上面的图上我们可以得出以下几个结论:

  • ARM架构的演变过程是从ARMv4, ARMv5, ARMv6, ARMv7, ARMv8-A
  • 其中芯片的命名从ARM11开始使用新的命名规范Cortex,比如现在最新的高通SM865使用的是ARMv8-A架构,Cortex-A77的core
  • ARMv4到ARMv7都是只支持32位,从ARMv8-A开始支持64位,就是我们常说的AArch64。同时ARMv8也为了兼容ARMv7的应用,也支持32位
  • 虚拟化(Virtualization)也是在ARMv7后面开始引入,在ARMv8-A已经开始全面支持
  • TrustZone技术在ARMv7和ARMv8已经大范围使用

那ARMv8-A都包含了那些模块呢? 我们已Cortex-A57举例

主要涉及的模块有:

  • ARM CoreSight 技术,用于debug使用
  • Generic Interrupt Controller(GIC)中断控制器
  • Memory Protection Unit(MMU)MMU用于将虚拟地址转化为物理地址
  • 每个Core中都有一个L1 指令和数据Cache,一般每四个core会在一个Cluster中的
  • 存在一个L2 cache
  • 多个core可能通过Coherent Bus通信
     

我们再来看一个多个Cluster的设计图

可以看到一个Cluster中每个core都有一个L1 Cache,一个Cluster存在一个L2cache用于多个core之间共享数据。而多个Cluster通过AMB Coherent Bus总线沟通交流。

ARMv8-A相对于ARMv7架构都有啥区别呢:

  • 在ARMv7架构下只能访问最大4GB的地址空间,而在ARMv8-A可以访问更大的地址空间。
  • ARMv7只支持4KB的page,在ARMv8-A下可以支持多种页类型(4K,16K, 64K),地址范围【32, 48】最大48位
  • 所以ARMv8-A架构下下应用程序可以访问更大的虚拟地址空间
  • ARMv8-A首次引入了Exception Level的概念,在ARMv7下使用的是PL0, PL1, PL2。 而在ARMv8-A下使用的是EL0-EL3
  • ARMv8-A增加了通用寄存器的数量,可以减少函数栈的大小。ARMv8-A下使用了30个通用寄存器,ARMv7下只有15个通用寄存器
  • ARMv8-A增加了TLB的大小,减少TLB MISS的概率
  • ARMv8-A架构完全支持ARMv7架构下的应用程序
  • 等等等

下面的几节文章从以下几个模块分析

  • ARMv8-A下通用寄存器和ARMv7通用寄存器做对比
  • ARMv8-A新引入的Exception Level
  • ARMv8下的异常
  • ARMv8下Memory,MMU, LTB
  • ARMv8下GIC,中断

我的博客即将同步至腾讯云+社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=35qnbn3ijyasw

发布了187 篇原创文章 · 获赞 108 · 访问量 37万+

猜你喜欢

转载自blog.csdn.net/longwang155069/article/details/104996106