- 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/
话说,尾部的++在这里没有实际作用? 最佳答案 l+l++ 未定义。您的表达式中没有序列点来分隔对 l 的访问和后增量。它可以做任何事情,包括具有与 l+l 相同的效果。 编辑:问题和答案在 Why
我正在研究成员资格算法,我正在研究这个特定问题,该问题说明如下: 展示一种算法,给定任何常规语言 L,确定 L 是否 = L* 所以,我的第一个想法是,我们有 L*,它是 L 的 Kleene 星并确
我试图弄清楚如何使用 Javascript 生成一个随机 11 个字符串,该字符串需要特定的字母/数字序列,以及位置。 ----------------------------------------
我一直在 LinqPad 中试验查询。我们有一个表 Lot,其中有一列 Side char(1)。当我编写 linq to sql 查询 Lots.Where(l => l.Side == 'A')
这个问题在这里已经有了答案: Iterate over all pairs of consecutive items in a list [duplicate] (7 个答案) 关闭 7 年前。 假
列表 ['a','a #2','a(Old)'] 应变为 {'a'} 因为 '# ' 和 '(Old)' 将被删除,并且不需要重复项列表。我努力用生成器开发列表理解,并决定这样做,因为我知道它会起作用
我正在为蛇和梯子制作一 block 板,到目前为止,我已经按降序打印了板。但是,我需要以正确的方式打印电路板。 编辑“螺旋下降”意味着 100...91 81...90 80...71 ...
字符串“Hello\n”等于 {'H','e','l','l','o','\','n','\0'} 或 {'H','e','l','l','o','\n','\0'}? 是否在字符串定义中添加转义序列
这个问题在这里已经有了答案: Different behaviour for list.__iadd__ and list.__add__ (3 个答案) 关闭 8 年前。 ls = [1,2,3]
当我在编写一个程序时,我在我的代码中看到了一个奇怪的行为。这是我所看到的。 >>> l = [1,2,3,4,5,6,7,8] >>> g = [] >>> for i in l: ... g
我明白了what a Y Combinator is , 但我不明白这个来自 Wikipedia page 的“新颖”组合子的例子: Yk = (L L L L L L L L L L L L L
Exception ParseException is not compatible with throws clause in Comparator.compare(L, L). 我在java 6上
期望的输出 我想要一个函数返回一个列表,这样,给定一个“困惑的”列表 l,每个元素都是 l 对应元素的索引,如果 l 已排序。 (抱歉,我想不出更简单的说法。) 示例 f([3,1,2]) = [2,
你好,我正在查看“假设一个排序数组在你事先不知道的某个枢轴旋转。(即 0 1 2 4 5 6 7 可能变成 4 5 6 7 0 1 2)”这个问题的 C++ 解决方案。你如何有效地在旋转数组中找到一个
让我们考虑这个简单的例子: import numpy as np a=np.arange(90) a=a.reshape(6,3,5) 我想得到一个数组 b形状 (6*5,3+1=4) 与 b[0:6
我正在编写一个 q 脚本,它在特定路径中加载一个数据库并对其进行一些处理。 db 的位置目前在脚本中是硬编码的,但我想将 db 路径作为参数传递并让它从变量中的路径加载。 目前它看起来像这样: q)
为什么我收到错误 Device: (3:9741) (0,l.useLinkBuilder) is not a function。 (在 '(0,l.useLinkBuilder)()' 中,'(0,
我有 ADT 版本 23.0.4 并安装了 Android 5.0 的 SDK 平台。 我读到 Android 5.0 Lolipop 的 API 级别为 21。但是在 Eclipse 的“新建应用程
我在 Google Play Store 中实现了一个抽屉导航,我想在 DrawerLayout 中设置列 TableView 的选定项目。但是后来发现在touch模式下无法选中item,有一个i
作为 C++ 的新手,我基本上有一个关于 g++ 编译器的问题,尤其是库的包含。考虑以下生成文件: CPPFLAGS= -I libraries/boost_1_43_0-bin/include/ -
我是一名优秀的程序员,十分优秀!