在 Skylake 中使用 MSR 正确禁用硬件预取

Correctly disable Hardware Prefetching with MSR in Skylake

我试图在我的机器上禁用硬件预取:

CPU 家庭:6

型号:78

型号名称:Intel(R) Core(TM) i5-6200U CPU @ 2.30GHz

我已经检查过:gcc -march=native -Q --help=target|grep march - 命令,它是 Skylake 微架构。

我已经安装了 msr-tools。 grep -i msr /boot/config-$(uname -r) 这给出了结果:CONFIG_X86_MSR=m - 我不确定是否有必要将其设置为 Y,或者如何设置。我试图使用这个 posts:

How do I programmatically disable hardware prefetching?

Unable to disable Hardware prefetcher in Core i7

不过我假设 posts 有点旧并且不使用 0x1a4 地址。同样在评论中,它没有描述如何使用这个地址来完成它,或者修改 0x1a4 或 0x1a0 之间是否没有区别。

我读过这篇文章:https://software.intel.com/en-us/articles/disclosure-of-hw-prefetcher-control-on-some-intel-processors,其中说可以通过将 0x1A4 中的 0-3 位设置为 1 来禁用预取。 modprobe msr - 执行此命令不会出错(也不会打印任何消息)。然后我正在尝试这两个命令:

sudo wrmsr -p 0 0x1a4 15 //for core 0

sudo wrmsr -p 2 0x1a4 15 //for core 2

15 用于将所有最后 4 位设置为 1

你能帮我确保我正确地禁用了预取器吗?由于我对 sudo wrmsr -p 0 0x1a4 15 - 命令做了很多假设,所以我不确定我是否正确使用了它。我试图提供所有信息,但如果需要任何其他信息,请告诉我。 (我已经缩短了 post,因为我觉得它太长了,无法通过)

我发现这个命令运行正常。 sudo modprobe msr - 应该首先执行。主要问题是我用 papi 事件测试它的方式