- 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/
internal protocol Reducer { associatedtype S : BaseState associatedtype A : BaseActi
我在考虑我的应用程序中的验证检查,我认为在任何模型上调用 ValidatorFactory,实现 Validee,这意味着说哪个类负责 ValidatorCreation 听起来不错。但是下面的代码不
我已经定义了 2 个协议(protocol)。我需要第一个 (NameProtocol) 来执行 Equatable 协议(protocol)。而另一个类 (BuilderProtocol) 有一个返
在上传方面,WebDAV 协议(protocol)在哪些方面优于 HTTP 协议(protocol)。 Socket Upload 协议(protocol)和 WebDav Upload 协议(pro
是否可以在任何版本的 Swift 中扩展具有混合类/协议(protocol)类型约束的协议(protocol)?例如,仅当 Self 是 UIViewController 的子类并且符合 Protoc
我有一个协议(protocol) (ProtocolA),其中包含符合第二个协议(protocol) (ProtocolB) 的单个属性。 public protocol ProtocolA {
NSObject 协议(protocol)带有常用的协议(protocol)模板,但它似乎并不是协议(protocol)实际实现所必需的。将其排除在外似乎完全没有任何改变。那么,协议(protocol
我想根据这两种协议(protocol)的一般特征(例如开销(数据包)、安全性、信息建模和可靠性)来比较 OPC UA 和 MQTT。我在哪里可以找到每个协议(protocol)的开销和其他特性的一些示
使用 Swift 4,我正在尝试编写一个自定义协议(protocol),它提供对 @objc 协议(protocol)的一致性。 一些代码 更具体地说,我有一个自定义协议(protocol) Sear
我想定义一个在 Viper 架构中使用的协议(protocol),以使用具有弱属性的协议(protocol)在 Viper 组件之间建立连接,但我收到以下错误消息: 'weak' may only b
我在同一个网络中有 3 个 docker 容器: 存储 (golang) - 它提供了用于上传视频文件的 API。 主播 (nginx) - 它流式传输上传的文件 反向代理 (姑且称之为代理) 我有
我打算在我的项目中使用 php socket。它需要用户登录才能根据 session 填充内容。所以我的问题是,TCP/IP 协议(protocol)也像 HTTP 协议(protocol)一样为每个
目前,我的网站有两个版本。一种带有 https://-证书,一种没有。我想将我网站的 http 版本上的所有用户 301 重定向到我网站的 https://版本。 这似乎不可能,因为创建重定向将导致重
目前,我的网站有两个版本。一种带有 https://-证书,一种没有。我想将我网站的 http 版本上的所有用户 301 重定向到我网站的 https://版本。 这似乎不可能,因为创建重定向将导致重
我有一个 Swift View Controller ,它定义了一个在 Objective-C View Controller 中应该遵循的协议(protocol): ChildViewControl
我在客户那里有数百个硬件设备,需要通过telnet接口(interface)发送HTTP数据。 目标是等待数据的 Apache 2 Web 服务器和 PHP 脚本。 这已经可以正常工作了,但是我们发现
我发现如果我创建一个这样的协议(protocol): protocol MyProtocol { } 我不能这样做: weak var myVar: MyProtocol? 我找到了解决这个问题的方法
Xcode 基于模板生成了这个头文件: // this file is XYZAppDelegate.h #import @interface XYZAppDelegate : UIRespond
我在 github 中有一个公开的存储库,我正在开发一个开源应用程序,用于制作产品目录和小型 cms 内容。 我还有一个私有(private)仓库(不托管在github),它是在托管在github的开
您好,我想让别人看到私有(private) repo 代码,但不想公开我的 repo ,也不希望他们有能力更改内容。这可能吗?我查看了网站的“管理”部分,但没有找到合适的内容。谢谢大家。 最佳答案 据
我是一名优秀的程序员,十分优秀!