作者:松恋崖 | 来源:互联网 | 2024-11-10 14:02
本文探讨了如何通过编程手段在Linux系统中禁用硬件预取功能。基于Intel®Core™微架构的应用性能优化需求,文章详细介绍了相关配置方法和代码实现,旨在帮助开发人员有效控制硬件预取行为,提升应用程序的运行效率。
我想以编程方式禁用硬件预取.
从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);