- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
物理上如何组合Write-Combine缓冲区?我已经看到了说明许多变体的框图:
L1和内存 Controller 之间的
最佳答案
写缓冲区在不同处理器中可以具有不同的用途或不同的用途。此答案可能不适用于未特别提及的处理器。我想强调一下,“写缓冲区”一词在不同的上下文中可能意味着不同的东西。该答案仅与Intel和AMD处理器有关。
英特尔处理器上的写合并缓冲区
每个高速缓存可能伴随着零个或多个行填充缓冲区(也称为填充缓冲区)。 L2处的填充缓冲区的集合称为 super 队列或超队列( super 队列中的每个条目都是一个填充缓冲区)。如果高速缓存是在逻辑核心或物理核心之间共享的,则相关的填充缓冲区也将在核心之间共享。每个填充缓冲区可以容纳单个高速缓存行以及描述高速缓存行(如果已被占用)的其他信息,包括高速缓存行的地址,内存类型和一组有效位,其中位数取决于跟踪缓存行的各个字节。在早期处理器(例如Pentium II)中,只有一个填充缓冲区能够进行写合并(和写折叠)。随着新型处理器的出现,行缓冲区和能够进行写合并的缓冲区的总数稳步增长。
直到Broadwell的Nehalem在每个L1数据高速缓存中都包含10个填充缓冲区。核心和核心2每个物理核心具有8个LFB。根据this的说明,Skylake上有12个LFB。 @BeeOnRope已观察到Cannon湖上有20个LFB。我在手册中找不到明确的说法,说所有这些微体系结构中的LFB与WCB相同。但是,Intel的一位人士写的这首article表示:
Consult the Intel® 64 and IA-32 Architectures Optimization Reference Manual for the number of fill buffers in a particular processor; typically the number is 8 to 10. Note that sometimes these are also referred to as "Write Combining Buffers", since on some older processors only streaming stores were supported.
MOVNTDQA
)也使用LFB。但是,第12.10.3节说,流负载将目标行提取到称为流负载缓冲区的缓冲区中,这显然在物理上不同于LFB/WCB。
If you search for 'fill buffer' in the PDF you can see that the Line fill buffer (LFB) is allocated after an L1D miss. The LFB holds the data as it comes in to satisfy the L1D miss but before all the data is ready tobe written to the L1D cache.
The L1 DCache can maintain up to 64 load micro-ops from allocation until retirement. It can maintain up to 36 store operations from allocation until the store value is committed to the cache, or written to the line fill buffers (LFB) in the case of non-temporal stores.
L1D_PEND_MISS.FB_FULL
的文档指示UC存储区分配在相同的LFB中(无论该行处于高速缓存还是其一致性状态)。像可缓存存储区一样,但与WC不同,UC存储区不在LFB中合并。
IN
和
OUT
指令的请求。有关更多信息,请参见:
How do Intel CPUs that use the ring bus topology decode and handle port I/O operations。
On the older AMD processors (K8 and Family 10h), non-temporal stores used a set of four “write-combining registers” that were independent of the eight buffers used for L1 data cache misses.
关于x86 - 写合并缓冲区在哪里? x86,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49959963/
我有几个长度不等的 vector ,我想对其进行cbind。我将 vector 放入列表中,并尝试结合使用do.call(cbind, ...): nm <- list(1:8, 3:8, 1:5)
合并(合并)两个 JSONObjects 的最佳方式是什么? JSONObject o1 = { "one": "1", "two": "2", "three": "3" }
我在一个表中有许多空间实体,其中有一个名为 Boundaries 的 geometry 字段。我想生成一个具有简化形状/几何图形的 GeoJson 文件。 这是我的第一次尝试: var entitie
谁能说出为什么这个选择返回 3.0 而不是 3.5: SELECT coalesce(1.0*(7/2),0) as foo 这个返回 3: SELECT coalesce(7/2,0) as foo
首先抱歉,也许这个问题已经提出,但我找不到任何可以帮助我的东西,可能是因为我对 XSLT 缺乏了解。 我有以下 XML: 0 OK
有时用户会使用 Windows 资源管理器复制文件并在他们应该执行 svn 存储库级别的复制或合并时提交它们。因此,SVN 没有正确跟踪这些变化。一旦我发现这一点,损坏显然已经完成,并且可能已经对相关
我想组合/堆叠 2 个不同列的值并获得唯一值。 如果范围相邻,则可以正常工作。例如: =UNIQUE(FILTERXML(""&SUBSTITUTE(TEXTJOIN(",",TRUE,TRANSPO
使用iTextSharp,如何将多个PDF合并为一个PDF,而又不丢失每个PDF中的“表单字段”及其属性? (我希望有一个使用来自数据库的流的示例,但文件系统也可以) 我发现this code可以正常
是否有一个合并函数可以优先考虑公共(public)变量中的非缺失值? 考虑以下示例。 首先,我们生成两个 data.frames,它们具有相同的 ID,但在特定变量上有互补的缺失值: set.seed
我们正在尝试实现 ALM Rangers 在最新的 Visual Studio TFS Branching and Merging Guide 中描述的“基本双分支计划”。 .从指导: The bas
我在不同目录(3个不同名称)中有很多(3个只是一个例子)文本文件,如下所示: 目录:A,文件名:run.txt 格式:txt制表符分隔 ; file one 10 0.2 0.5 0.
我有一张包含学生等级关系的表: Student Grade StartDate EndDate 1 1 09/01/2009 NULL 2
我在学习 https://www.doctrine-project.org/projects/doctrine-orm/en/2.6/reference/working-with-associatio
我觉得我有世界上最简单的 SVN 用例: 我有一个文件,Test.java在 trunk SVN的。 我分行trunk至 dev-branch . 我搬家Test.java进入 com/mycompa
我有两个数据框,其中一些列名称相同,而另一些列名称不同。数据框看起来像这样: df1 ID hello world hockey soccer 1 1 NA NA
Elasticsearch 中是否缺少以扁平化形式(多个子/子aggs)返回结果的方法? 例如,当前我正在尝试获取所有产品类型及其状态(在线/离线)。 这就是我最终得到的: aggs [ { key:
如何合并如下所示的 map : Map1 = Map(1 -> Class1(1), 2 -> Class1(2)) Map2 = Map(2 -> Class2(1), 3 -> Class2(2)
我试图通过从netezza服务器导入数据来合并两个数据集。 以下是数据集,其数字为,ID为,字母为,名称为: 下表都是使用命令从netezza导入的: sqoop import --connect n
我有两个数组 $array1 = array('first', 'second', 'third', 'fourth'); $array2 = array('first', 'third', 'fou
我正在 SQL Server 中运行合并。在我的更新中,我只想在值发生更改时更新该行。有一个版本行在每次更新时都会递增。下面是一个例子: MERGE Employee as tgt USING (SE
我是一名优秀的程序员,十分优秀!