系统相关
首页 > 系统相关> > linux – 如何以编程方式禁用硬件预取?

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

作者:互联网

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

Optimizing Application Performance on Intel® Core™ Microarchitecture Using Hardware-Implemented Prefetchers
How to Choose between Hardware and Software Prefetch on 32-Bit Intel® Architecture,
我需要更新MSR以禁用硬件预取.

这是一个相关的片段:

“DPL Prefetch and L2 Streaming Prefetch settings can also be changed programmatically
by writing a device driver utility for changing the bits in the IA32_MISC_ENABLE
register – MSR 0x1A0. Such a utility offers the ability to enable or disable prefetch
mechanisms without requiring any server downtime.

下表显示了IA32_MISC_ENABLE MSR中为了控制DPL和L2 Streaming Prefetch而必须更改的位:

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,但这不起作用.
我也尝试直接在asm / msr.h中使用wrmsr但是段错误.
我尝试在内核模块中执行此操作…并杀死了计算机.

BTW – 我使用的是内核2.6.18-92.el5,它在内核中链接了MSR:

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

解决方法:

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


CPUID指令应用于确定是否支持MSR(EDX [5] = 1)
在使用此说明之前.

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

在内核源代码中有很多使用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);

标签:prefetch,linux,kernel
来源: https://codeday.me/bug/20190917/1809111.html