- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是关于跨cache
不同层的缓存一致性协议(protocol)。 .我对L1
的理解(X86_64)就是说,它由一个核心和 L2
独家拥有。介于 2 个内核和 L3
之间用于 CPU 插槽中的所有内核。我已阅读 MESI
协议(protocol)功能,关于存储缓冲区,使队列无效,使消息无效等。我的疑问是 MESI
适用于 L1
仅适用于 L2
和 L3
以及。或者 L2
之间是否有不同的缓存同步和 L3
.
最佳答案
缓存级别的数量、每个级别相对于系统中其他处理器或内核的组织方式以及在每个缓存中实现的一致性协议(protocol)由核心微架构、非核心微架构以及在某些情况下相关的引导定义。时间配置选项。这些设计方面因供应商和处理器代以及同一代中的型号而异。即使仅考虑过去几年发布的处理器,也有很多不同的设计。
Intel 和 AMD 始终清楚地记录了缓存层次结构的组织。然而,一致性协议(protocol)并不总是清楚地记录在案。您不会在任何官方文档中找到直接告诉您缓存使用的所有协议(protocol)的部分。一些硬件性能事件名称暗示事件适用的缓存中使用的一致性协议(protocol)。
指令缓存 (L1I) 始终使用 SI 协议(protocol),因为在填充点和失效点之间永远不会修改一行。因此,条目可以处于 S 或 I 状态。 M 和 E 状态仅相关且缓存支持修改现有行。
一些微架构具有仅支持直写写入命中策略的缓存。例如,AMD Bulldozer 中的 L1D 是直写式缓存。 M 状态在直写缓存中没有意义。这意味着 L1D 要么使用 SI,要么使用 ESI。 SI 更有可能,因为它每个条目只需要一个状态位。
英特尔处理器几乎总是支持所有数据和统一缓存中的回写策略。具有两级缓存的旧英特尔处理器(90 年代和 2000 年代初)使用 MESI 作为 L1D 和 L2。具有三级缓存的英特尔处理器也将 MESI 用于 L1D 和 L2。四个状态可用的事实并不一定意味着所有状态都被使用。物理地址位于直写 (WT) 内存类型区域内的缓存线不使用 M 状态。 (类型可能从 WB 更改为 WT,因此第一个 WT 访问可能在 M 中命中。)因此,WT 线路的有效协议(protocol)是 ESI 或 SI。
从 Nehalem-EX 开始的 Intel 处理器中的 L3 缓存使用 MESIF 协议(protocol),其中包含整个 NUMA 节点的包含目录(在命中时使用)。 Nehalem-EX 还使用内存中的 2 状态目录来跟踪哪些线路属于外包装 IOH。内存目录协议(protocol)在 Westmere-EX 中发生了变化,然后在至强 E5 中再次发生了变化,在至强 E5/E7 v2 中再次发生了变化,在至强 E5/E7 v3 中再次发生了变化。这些处理器还支持 L3-miss 场景中的多种一致性协议(protocol),但具有不同的权衡。
我不知道还能说什么来回答你的问题。我猜你可以说 MESI 或多或少适用于 L2 和 L3。
关于caching - 不同级别缓存(即 L1、L2 和 L3)之间的缓存一致性(MESI 协议(protocol)),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66731349/
GhostScript PDF/A 生成好像有错误 当您通过 GhostScript 生成 PDF/A 文档时,当您单击 Adobe Reader 时,会出现一个一致性选项卡,其中显示: “一致性
我有一个需要测试的 XPath 引擎实现。 是否有一组标准的一致性测试可以用来验证是否符合 XPath 规范(与 XSLT 相关)。 什么将是完美的 XML 文档 XPath 表达式和预期的结果。 最
帮助我了解在这种情况下我可以期望与 MongoDB 的一致性级别。 我们正在运行一个副本集,其中 Mongoid 中的 consistency 标志设置为 strong,这意味着只读到 master。
假设我有一个采用一个参数的方法。 此参数应满足以下要求: 'of type':方法需要知道参数属于特定类(或子类)。 'implements interface':方法需要知道参数实现了特定的接口(i
当协议(protocol)将属性声明为可选而具体类型将其声明为非可选时,如何使具体类型符合协议(protocol)? 这是问题所在: protocol Track { var trackNum
我正在考虑使用浏览器的 navigator.mimeTypes 数组作为第三级用户/浏览器标识符。例如,当我在 Chrome 上运行时... console.log(navigator.mimeTyp
我有以下协议(protocol): protocol ProtoAInput { func funcA() } protocol ProtoA { var input: ProtoAI
如果选择“最终”一致性,则发生写入的区域内的一致性是什么? 如果我只需要区域强一致性,应该选择哪个选项? 最佳答案 如果您需要在主要区域内进行强读取,则应该选择强一致性或有界过时一致性。 关于azur
您好,我是一名初学者,目前正在尝试学习 java 编程。课本上的问题: 编写一个程序来帮助人们决定是否购买混合动力汽车。你的程序的输入应该是:•新车的成本•预计每年行驶里程•预计汽油价格 •每加仑英里
我正在尝试制作一个可以在 UILabel 上使用的 Swift 协议(protocol), UITextField , 和 UITextView包含他们的text , attributedText ,
我有一个类扩展: extension UICollectionViewCell { class func registerFromNibInCollectionView(collectionV
为了在 Swift 中模拟对象进行测试,我通常遵循这样的模式:编写一个协议(protocol)来描述我想要的对象的行为,然后使用 Cuckoo 为其生成模拟以进行测试。 通常,这些协议(protoco
假设我有两个非通用协议(protocol)(1) protocol StringValue { var asString: String {get} } protocol StringProv
我有一组协议(protocol)可以在 UITableView 中显示一个元素: protocol TableRepresentableRow { var title: String { get
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
用“class”标记 CacheManager 解决了我的问题。 案例:一个简单的缓存器,mutating get 不是我想要的,那么对于引用类型或类类型应该怎么做? protocol Cacher
我想要一个符合协议(protocol)的变量,但是 swift 编译器告诉我协议(protocol)没有确认。 protocol A {} protocol B { var a : A { g
如果我有一个类 Christmas 和一个协议(protocol) Merry,要使 Christmas 符合 Merry,很多人会这样做: class Christmas { ... } e
@objc public protocol P1 { func p1foo() } @objc public protocol P2 { func p2foo() } class A: NSO
我有一些结构符合的基本协议(protocol)(模型)。它们也符合 Hashable protocol Model {} struct Contact: Model, Hashable { v
我是一名优秀的程序员,十分优秀!