CPU内部结构窥探·「7」--ARMv8架构中的缓存机制

news2024/9/22 7:27:20

浅析ARMv8架构中的缓存机制

在现代计算机体系结构中,缓存(Cache)是提高系统性能的关键组件之一。对于ARMv8架构来说,缓存的设计和管理至关重要。本文将详细介绍ARMv8架构中的缓存机制,包括其结构、工作原理、缓存一致性和缓存管理策略等内容,力求通俗易懂。

一、缓存的基本概念

1.1 什么是缓存

缓存是位于CPU与主存(DRAM)之间的小而快速的存储器,CPU处理器运行速度非常快,而主存(RAM)的速度相对较慢,因为缓存的访问速度远高于主存,为了让CPU不会因等待数据而停顿,缓存充当了一个快速的临时存储器,存储CPU最常用的数据,可以显著降低CPU访问数据的延迟,提高系统的整体性能。
如下图,是arm core访问数据的过程,arm core发起数据访问指令,经过mmu,会现在cache中查找是否存在,如果存在则为cache hit,如果不存在再继续再main memory中查找,并将其加载进cache。
在这里插入图片描述

1.2 缓存的层次结构

缓存通常分为多个层次,包括一级缓存(L1 Cache)、二级缓存(L2 Cache)和三级缓存(L3 Cache)。每一层缓存都有不同的大小和速度,以平衡成本和性能:

  • 如下图,一般cpu内部会存在多个cluster,每个core一般都有独立的L1 Cache,且会分Dcache和Icache
  • cluster内部的多个core之间,可以通过L2 Cache共享资源。
  • cpu内部的多个cluster之间,可以通过L3 Cache共享资源。
    在这里插入图片描述

二、Cache结构

Cache是由Cache控制器和Cache存储器组成:

  • Cache控制器:通过使用处理器提供的地址,选择Cache存储器中的内容。
  • Cache存储器:专用的存储器阵列,其访问单元为cache line。
  • 写缓冲器:容量非常小的高速FIFO存储缓冲器,用来临时存放处理器将要写入内存中的数据。

三、缓存工作原理

3.1 缓存如何工作

缓存的基本工作原理可以概括为以下几点:

  1. 缓存命中:如果CPU需要的数据已经在缓存中,称为缓存命中,数据直接从缓存读取。
  2. 缓存未命中:如果CPU需要的数据不在缓存中,称为缓存未命中,数据需要从主存读取并加载到缓存中。

3.2 缓存一致性

在多处理器系统中,多个CPU可能同时访问和修改相同的内存数据,这时需要确保所有处理器看到的数据是一致的。ARMv8使用缓存一致性协议(如MESI协议)来解决这个问题。

  • M(修改):缓存行已被修改,与主存中的内容不一致,且仅存在于当前缓存。
  • E(独占):缓存行与主存内容一致,且仅存在于当前缓存。
  • S(共享):缓存行与主存内容一致,且可能存在于多个缓存中。
  • I(无效):缓存行无效。

3.3 缓存协同

ARMv8架构支持多种缓存协同操作,如:

  • Cache Line Fill:当缓存未命中时,从主存加载数据到缓存中。
  • Write-Through:写操作同时更新缓存和主存,保证一致性。
  • Write-Back:写操作只更新缓存,当缓存行被替换时,再写回主存。

四、缓存管理策略

4.1 替换策略

当缓存已满,需要将旧的数据替换掉以存储新数据。常见的替换策略包括:

  • LRU(Least Recently Used):替换最近最少使用的缓存行。
  • Random:随机选择缓存行进行替换。
  • FIFO(First In First Out):替换最早进入缓存的缓存行。

4.2 写策略

缓存的写策略决定了数据写入缓存和主存的时机。主要有两种:

  • Write-Through:每次写操作都同时更新缓存和主存,保证数据一致性,但性能较低。
  • Write-Back:写操作只更新缓存,减少主存写操作的频率,提高性能,只有当缓存行被替换时才写回主存。

4.3 缓存预取

缓存预取是指在数据实际需要之前,将其加载到缓存中。ARMv8支持多种预取机制:

  • 静态预取:编译器在编译时插入预取指令。
  • 动态预取:硬件动态检测访问模式并自动预取数据。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1990292.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

高精度加法c++

题目描述 计算ab的值,a,b皆为不超过240位的正整数。 输入 两个正整数,每行一个 输出 一个数,代表两个整数的和 样例输入 111111111111111111111111111111111111 222222222222222222222222222222222222 样例输出 3333333333333333333…

渗透--ubuntuan安装nginx、php部署 -- sql注入

ubuntuan安装nginx以及php部署 ​ 1.安装依赖包 方法一: rootzbn-virtual-machine:~# apt-get install gcc libpcre3 libpcre3-dev zliblg zliblg-dev openssl libssl-dev方法二: rootzbn:/# apt install gcc rootzbn:/# apt install libpcre3 libpcre3…

2017-架构师案例(九)

某软件企业受该省教育部门委托建设高校数字化教育教学资源共享平台,实现以众筹众创的方式组织省内普通高校联合开展教育教学资源内容建设,实现全省优质教学资源整合和共享。该资源共享平台的主要功能模块包括: (1)统一身份认证模块:提供统一的认证入口&…

微信小程序--详情实现日期选择期(年月日)

案例&#xff1a; html: <view class"huanhang"><view class"fontBold">发起时间&#xff1a;</view><view class"fontBold"> <picker class"getBusTime" mode"date" data-namesa"staDa…

aop时什么,用时统计怎么开发

spring aop,作用&#xff1a;可以对service层代码进行监听&#xff0c;统计每个方法用时 aop是什么&#xff1a;面向切面编程&#xff08;aop开发出来的代码&#xff09; 用在哪里&#xff1a;&#xff08;压测/提效&#xff09; 1.controller层方法用时不用统计,核心都在服务…

Vue+Vite+Element Plus基础操作

Vue.js 是一个流行的前端框架&#xff0c;‌而 Vite 是一个快速构建前端应用的新型开发服务器和构建工具&#xff0c;‌两者结合可以显著提升开发效率和体验。‌ Vue.js 是一个用于构建用户界面的渐进式框架&#xff0c;‌它易于上手且功能强大。‌Vue 的核心库只关注视图层&a…

前端构建工具|vite快速入门

认识vite vite组成部分 Vite是一种新型前端构建工具&#xff0c;能够显著提升前端开发体验。它主要由两部分组成&#xff1a; 一个开发服务器&#xff0c;它基于 原生 ES 模块 提供了 丰富的内建功能&#xff0c;如速度快到惊人的 模块热更新&#xff08;HMR&#xff09;。一…

DERPNSTINK: 1-打靶渗透【附代码】(权限提升)

DerpNStink 靶机下载地址&#xff1a; https://www.vulnhub.com/entry/derpnstink-1,221/#downloadhttps://www.vulnhub.com/entry/derpnstink-1,221/#download 1. 主机发现端口扫描目录扫描操作系统等信息收集 1.1. 主机发现 nmap -sn 192.168.7.0/24|grep -B 2 08:00:27…

Rabbit高级特性 - 消息重试机制(两种实现)

文章目录 消息重试机制概述实现方式一&#xff1a;基于消息手动确认机制&#xff0c;返回 nack 实现配置文件交换机、队列、绑定生产者接口消费者演示和结论 实现方式二&#xff1a;基于重试配置实现配置文件交换机、队列、绑定生产者接口消费者演示和结论 消息重试机制 概述 …

对深度学习神经网络做了小改进,效果提升明显,可以发论文吗?

小改了深度学习神经网络某一层&#xff0c;效果提升显著&#xff0c;可以发顶会吗&#xff1f; 结论就是&#xff0c;当然可以发&#xff0c;只是能不能发出高质量论文&#xff0c;中稿顶会&#xff0c;还得看你这个小改进的具体情况还有你讲故事的能力。 先说改进的具体情况…

国家统计局中国主要城市面板数据(1990-2023年)

数据说明&#xff1a;数据来源于国家统计局&#xff0c;指标包含&#xff1a;城市、年份、第三产业增加值、第一产业增加值 地区生产总值、第二产业增加值、年末户籍人口、城镇非私营单位在岗职工平均工资 房地产开发投资额、房地产开发住宅投资额、房地产开发办公楼投资额、房…

什么是股指期权与股指期货的套利策略?

沪深300股指期权和沪深300股指期货就像是孪生兄弟&#xff0c;它们不仅到期时间一样&#xff0c;结算价格也一样&#xff0c;而且都是现金结算。这意味着&#xff0c;如果你用期权的方式“造”出一个期货来&#xff0c;跟市场上真实交易的期货&#xff0c;在到期那天&#xff0…

Eclipse 首选项(Preferences)

设置首选项 该对话框可通过框架管理但是其他插件可以设置其他页面来管理首选项的配置。 我们可以通过 Window 菜单选择 Preferences 菜单项来开启该对话框。 首选项页面有多个分类组成。你可以在左侧菜单中展开各个节点来查看首选项的配置。 左上角的输入框可以快速查找首选…

#子传父父传子props和emits #封装的table #vue3

#子传父&父传子props和emits #封装的table #vue3 父组件&#xff1a;emits defineEmits props 子组件&#xff1a; 子组件 <template><el-table v-bind"$attrs" ref"innerTableRef" v-loading"loading" border :data"tabl…

鸿蒙HarmonyOS开发:如何灵活运用动画效果提升用户体验

文章目录 一、动画概述1、动画的目的 二、显式动画 (animateTo)1、接口2、参数3、AnimateParam对象说明4、示例5、效果 三、属性动画 (animation)1、接口2、参数3、AnimateParam对象说明4、系统可动画属性4、示例5、效果 一、动画概述 动画的原理是在一个时间段内&#xff0c;…

QT使用ui文件创建窗口

目录 带ui文件 添加状态栏 资源文件的使用 添加文件资源 使用文件资源 带ui文件 编辑 添加状态栏 MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow) {ui->setupUi(this);// 添加状态栏ui->statusbar->addWidget(new QLab…

codeforces查看题解

文章目录 1. 步骤一&#xff1a;右键单击箭头指向位置&#xff0c;根据提示打开链接2. 步骤二&#xff1a;左键单击箭头指向位置3. 结果&#xff1a;红线上方是参考代码&#xff0c;下方是测试样例4. 补充&#xff1a;① 右边这个方框可以筛选想要查看代码的状态(Accepted、Wro…

AI在医学领域:残差扩散模型预测特发性肺纤维化 (IPF)

关键词&#xff1a; IPF 进展预测、残差扩散模型、临床信息 特发性肺纤维化&#xff08;Idiopathic Pulmonary Fibrosis&#xff0c;IPF&#xff09;是一种严重且不可逆的肺部疾病&#xff0c;它会导致肺部组织出现瘢痕和增厚&#xff0c;从而引起呼吸困难。。及时对IPF进行治…

Unity入门4——常用接口

C#中常用类和接口 DateTime&#xff1a;表示某个时刻 DateTime.Now&#xff1a;拿到系统当前时间DtaTime.TimeOfDay&#xff1a;获取此实例当天的时间 Quaternion&#xff1a;用来旋转&#xff0c;采用四元数&#xff0c;由w&#xff08;实部&#xff09;和x,y,z&#xff08;虚…

ChinaJoy 2024: 维塔士携自研游戏亮相,探讨数据驱动游戏开发

2024年7月30日,上海——全球领先的视频游戏开发公司维塔士精彩亮相第二十一届中国国际数码互动娱乐展览会(ChinaJoy),并首次公开自研游戏《唐传奇:琵琶行》DEMO试玩。在展会首日举办的2024中国游戏开发者大会(CGDC)上,来自维塔士西安工作室的执行制作人熊鹏昱受邀发表题为《维塔…