热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何在Linux中通过编程手段禁用硬件预取功能?

本文探讨了如何通过编程手段在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);


推荐阅读
  • 本文详细介绍了如何解压并安装MySQL集群压缩包,创建用户和组,初始化数据库,配置环境变量,并启动相关服务。此外,还提供了详细的命令行操作步骤和常见问题的解决方案。 ... [详细]
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • Linux环境下进程间通信:深入解析信号机制
    本文详细探讨了Linux系统中信号的生命周期,从信号生成到处理函数执行完毕的全过程,并介绍了信号编程中的注意事项和常见应用实例。通过分析信号在进程中的注册、注销及处理过程,帮助读者理解如何高效利用信号进行进程间通信。 ... [详细]
  • 对于许多初学者而言,遇到总线错误(bus error)或段错误(segmentation fault/core dump)是极其令人困扰的。本文详细探讨了这两种错误的成因、表现形式及解决方法,并提供了实用的调试技巧。 ... [详细]
  • 当您感觉当前使用的微型计算机CPU性能不足,需要更换更高性能的CPU时,正确的拆卸方法至关重要。本文将详细介绍几种安全有效的微型计算机CPU拆卸方法,帮助您顺利完成升级。 ... [详细]
  • 目录一、salt-job管理#job存放数据目录#缓存时间设置#Others二、returns模块配置job数据入库#配置returns返回值信息#mysql安全设置#创建模块相关 ... [详细]
  • Linux环境下C语言实现定时向文件写入当前时间
    本文介绍如何在Linux系统中使用C语言编程,实现在每秒钟向指定文件中写入当前时间戳。通过此示例,读者可以了解基本的文件操作、时间处理以及循环控制。 ... [详细]
  • 本文详细介绍了Java中实现异步调用的多种方式,包括线程创建、Future接口、CompletableFuture类以及Spring框架的@Async注解。通过代码示例和深入解析,帮助读者理解并掌握这些技术。 ... [详细]
  • 在尝试从数据库获取设置的过程中,遇到了一个致命错误:Fatal error: Call to a member function bind_param() on boolean。本文将详细分析该错误的原因,并提供解决方案。 ... [详细]
  • CentOS 6.8 上安装 Oracle 10.2.0.1 的常见问题及解决方案
    本文记录了在 CentOS 6.8 系统上安装 Oracle 10.2.0.1 数据库时遇到的问题及解决方法,包括依赖库缺失、操作系统版本不兼容、用户权限不足等问题。 ... [详细]
  • Webpack中实现环境与代码的有效分离
    本文探讨了如何在Webpack中有效地区分开发与生产环境,并实现代码的合理分离,以提高项目的可维护性和加载性能。 ... [详细]
  • 在使用 Spring Cloud Config 作为配置中心时,若在配置文件中指定了请求路径但未能生效,本文将探讨其原因及解决方案。 ... [详细]
  • 本文提供了一个详细的PHP用户认证和管理的代码示例,包括用户登录验证、数据库连接、错误处理等关键部分的实现。 ... [详细]
  • Eclipse 中 Maven 的基础配置指南
    本文详细介绍了如何在 Eclipse 环境中配置 Maven,包括环境变量的设置、Maven 插件的安装与配置等关键步骤,旨在帮助开发者顺利搭建开发环境。 ... [详细]
author-avatar
松恋崖
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有