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

【Cache缓存】cache的刷新

目录

Clean(缓存清理)

Invalidate(缓存失效)

flush


        每条cache line 都有两个标志位 valid bit 和 dirty bit。 vaild bit:表示cache line中数据是否有效。1代表有效;0代表无效。当系统刚启动时,cache中的数据都应该是无效的。

  1. dirty bit:表示cache line里面的数据是否和下一级存储器内容一致。0代表非dirty,和下一级存储器内容一致。1代表dirty,和下一级存储内容不一致。

  2. 当cache外部的存储器数据发生改变时,需要清除相应位置的cache标志位。如果cache采用的写策略是write-back,还需要将cache中的旧数据刷到外部存储器。

        ARM中通常使用术语clean和invalidate,有的地方会使用flush(invalidate+clean)描述两个操作。

        在多核处理器的缓存系统中,cache clean(缓存清理)和cache invalidate(缓存失效)是维护缓存一致性、保证共享数据正确性的两个核心操作。

Clean(缓存清理)

        clean指的是将响应位置的cache line状态置为脏(1: dirty)。通过这种方式可以让cache line中的数据和主存中的数据保持一致。

Invalidate(缓存失效)

        invalidate指的是将相应位置的cache line状态置为无效(0: invalid),强制后续访问该数据时必须从下一级存储重新加载。这时候并不需要真的清除相应位置的cacheline数据。

        在一般的系统中,复位必须清除掉所有cache line的valid状态,不然的话,这个cache的状态位就能够让芯片变成石头,因为复位后的内存访问可能会hit,从而拿到错误的不可预知的数据。如果cache采用了write-back写策略,cacheline可能包含了dirty数据,这个时候直接invalidate这个cache line也是不对的,可能会丢失本应该写入到主存中的数据。

flush

每条cache line 先clean,再invalid.

http://www.dtcms.com/a/569565.html

相关文章:

  • 水坑攻击的攻击原理和特点+案例和防御方法
  • Git 如何从某个 commit 新建分支
  • 做商业广告有什么网站好推销的无锡百姓网推广
  • 云南建个网站哪家便宜河北工程建设造价信息网
  • Spring Boot 集成 EMQ X 4.0 完整技术指南
  • git/github入门基操(终端版)
  • Spring Boot 集成 InfluxDB 2.x 完整技术指南
  • 汕头企业网站模板建站cm域名网站
  • 【Vue】Vue框架的基础知识强化
  • 计算机大类常见单词
  • 无头浏览器的效率救赎:Playwright连接复用与请求拦截技巧
  • dirname basename 命令
  • 邯郸网站制作基本流程网上销售网站建设
  • 如何优雅地找到二叉树的最近公共祖先?
  • 网站建设公司一般几个人成都设计公司装修
  • TOON 协议与 AIDotNet.Toon 实践指南
  • PPOCR 再编译
  • 网站关键词修改工作汇报总结怎么写
  • Vue 3模板如何通过编译三阶段实现从声明式语法到高效渲染的跨越
  • 做网站用的什么编程语言学编程的费用一般是多少
  • 智能家居技术发展与应用综述
  • linux udp广播数据包实际用例
  • 什么公司需要建立网站电商平台运营策略
  • 厦门怎么没有 网站备案wordpress网站的彻底清理
  • 一文讲全volatile关键字
  • 西安高校网站建设保定手机网站制作
  • 对称加密与非对称加密
  • Swift添加字体到项目中
  • 大专建筑工程技术专业职业发展指南
  • 免费免费网站模板企业调查问卷