如何以编程方式禁用硬件预取?

2024-10-21 09:14:00
admin
原创
370
摘要:问题描述:我想以编程方式禁用硬件预取。从使用硬件实现的预取器优化英特尔® 酷睿™ 微架构上的应用程序性能和 如何在 32 位英特尔® 架构上选择硬件和软件预取,我需要更新 MSR 以禁用硬件预取。以下是相关片段:IA32_MISC_ENABLE “DPL 预取和 L2 流预取设置也可以通过编写设备驱动程序实用...

问题描述:

我想以编程方式禁用硬件预取。

从使用硬件实现的预取器优化英特尔® 酷睿™ 微架构上的应用程序性能和
如何在 32 位英特尔® 架构上选择硬件和软件预取,我需要更新 MSR 以禁用硬件预取。

以下是相关片段:

IA32_MISC_ENABLE
“DPL 预取和 L2 流预取设置也可以通过编写设备驱动程序实用程序来更改寄存器中的位 -来以编程方式更改MSR 0x1A0。此类实用程序可以启用或禁用预取机制,而无需任何服务器停机时间。

IA32_MISC_ENABLE MSR下表显示了为了控制DPL和 L2 流预取而必须更改的位:

Prefetcher Type MSR (0x1A0) Bit Value 
DPL (Hardware Prefetch) Bit 9 0 = Enable 1 = Disable 
L2 Streamer (Adjacent Cache Line Prefetch) Bit 19 0 = Enable 1 = Disable"

我尝试使用http://etallen.com/msr.html,但没有成功。我还尝试直接使用,wrmsrasm/msr.h会出现段错误。我尝试在内核模块中执行此操作……结果导致机器死机。

顺便说一句 - 我正在使用内核 2.6.18-92.el5 并且它已MSR在内核中链接:

$ grep -i msr /boot/config-$(uname -r)
CONFIG_X86_MSR=y
...

解决方案 1:

您可以使用 msr-tools http://www.kernel.org/pub/linux/utils/cpu/msr-tools/启用或禁用硬件预取器

下面启用硬件预取器(通过取消设置位 9):

[root@... msr-tools-1.2]# ./wrmsr -p 0 0x1a0 0x60628e2089 
[root@... msr-tools-1.2]# ./rdmsr 0x1a0 
60628e2089

下面禁用硬件预取器(通过启用位 9):

[root@... msr-tools-1.2]# ./wrmsr -p 0 0x1a0 0x60628e2289 
[root@... msr-tools-1.2]# ./rdmsr 0x1a0 
60628e2289

通过编程,您可以以 root 身份执行此操作,通过打开/dev/cpu/<cpunumber>/msr并使用 pwrite 以偏移量写入 msr“文件” 0x1a0

解决方案 2:

来自英特尔参考:

此指令必须在特权级别 0 或实地址模式下执行;否则,将生成一般保护异常 #GP(0)。在 ECX 中指定保留或未实现的 MSR 地址也会导致一般保护异常。...

使用此指令之前,应使用 CPUID 指令确定是否支持 MSR(EDX[5]=1)。

因此,您的错误可能与不支持 MSR 的 CPU 或使用错误的 MSR 地址有关。

内核源代码中有很多使用 MSR 的示例:

在内核源代码中,对于单个 CPU,它演示了在 arch/i386/kernel/cpu/intel.c 中的函数中禁用 Xeon 的预取:

static void __cpuinit Intel_errata_workarounds(struct cpuinfo_x86 *c)

rdmsr 函数参数是 msr 编号、指向低 32 位字的指针和指向高 32 位字的指针。

wrmsr 函数参数是 msr 编号、低 32 位字值和高 32 位字值。

多核或 smp 系统必须将 cpu 结构作为第一个参数传入:

void rdmsr_on_cpu(unsigned int cpu, u32 msr_no, u32 l, u32 h);

void wrmsr_on_cpu(unsigned int cpu, u32 msr_no, u32 l, u32 h);

解决方案 3:

2014 年,英特尔发布了有关使用 0x1a4 msr (1a4 msr) 禁用 Nehalem、Westmere、Sandy Bridge 、 Ivy Bridge、Haswell、Broadwell(可能还有更新的内核)的硬件预取器的信息。bholanath 在此处找到了链接:

https://software.intel.com/en-us/articles/disclosure-of-hw-prefetcher-control-on-some-intel-processors披露部分英特尔处理器上的硬件预取器控制 - Vish Viswanathan (英特尔),2014 年 9 月 24 日

本文公开了可用于控制基于以下微架构的英特尔处理器上可用的各种硬件预取器的 MSR 设置:Nehalem、Westmere、Sandy Bridge、Ivy Bridge、Haswell 和 Broadwell。

上述处理器支持 4 种类型的硬件预取器来预取数据。其中 2 种预取器与 L1 数据缓存相关(也称为 DCU DCU 预取器、DCU IP 预取器),2 种预取器与 L2 缓存相关(L2 硬件预取器、L2 相邻缓存行预取器)

每个内核都有一个地址为 0x1A4 的模型专用寄存器 (MSR),可用于控制这 4 个预取器。此寄存器中的位 0-3 可用于启用或禁用这些预取器。此 MSR 的其他位被保留。

它们对于每个 CPU 核心都是本地的,并且可以在 Linux 内核驱动程序的帮助下由 root 进行更改msr。它们被 Intel 用于通过 Intel MLC 工具测量 NUMA 中的内存延迟:

例如,英特尔内存延迟检查器工具(http://www.intel.com/software/mlc)通过写入 MSR 0x1a4 来修改预取器,以测量准确的延迟,并在退出时将其恢复到原始状态。

解决方案 4:

我在这里添加一个答案,因为前面的可能并不适用于所有英特尔处理器。

对于我的 Intel Xeon 5650(06_2CH 系列)处理器,手册第 35 章指定地址 0x1A0 处的寄存器 IA32_MISC_ENABLE 的第 10 至 8 位是保留的。我猜这意味着我无法通过 MSR 打开和关闭预取器。

根据英特尔员工的回答: “英特尔尚未透露如何禁用 Nehalem 及更高版本处理器上的预取器。您需要使用 BIOS 中的选项来禁用预取器。”

相关推荐
  政府信创国产化的10大政策解读一、信创国产化的背景与意义信创国产化,即信息技术应用创新国产化,是当前中国信息技术领域的一个重要发展方向。其核心在于通过自主研发和创新,实现信息技术应用的自主可控,减少对外部技术的依赖,并规避潜在的技术制裁和风险。随着全球信息技术竞争的加剧,以及某些国家对中国在科技领域的打压,信创国产化显...
工程项目管理   2098  
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1460  
  建筑行业正处于数字化转型的关键时期,建筑产品生命周期管理(PLM)系统的实施对于提升项目效率、质量和协同性至关重要。特别是在 2025 年,基于建筑信息模型(BIM)的项目进度优化工具成为众多建筑企业关注的焦点。这些工具不仅能够整合项目全生命周期的数据,还能通过精准的分析和模拟,为项目进度管理提供强大支持。BIM 与建...
plm是什么软件   13  
  PLM系统开发的重要性与现状PLM(产品生命周期管理)系统在现代企业的产品研发、生产与管理过程中扮演着至关重要的角色。它贯穿产品从概念设计到退役的整个生命周期,整合了产品数据、流程以及人员等多方面的资源,极大地提高了企业的协同效率和创新能力。通过PLM系统,企业能够实现产品信息的集中管理与共享,不同部门之间可以实时获取...
国产plm软件   15  
  PLM(产品生命周期管理)系统在企业产品研发与管理过程中扮演着至关重要的角色。随着市场竞争的加剧和技术的飞速发展,企业对PLM系统的迭代周期优化需求日益迫切。2025年敏捷认证对项目管理提出了新的要求,其中燃尽图作为一种强大的可视化工具,在PLM系统迭代周期优化中有着广泛且重要的应用。深入探讨这些应用,对于提升企业的项...
plm系统主要干什么的   16  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用