x86 - 读取当前非核心频率并设置非核心倍频器

标签 x86 intel cpu-architecture msr

我正在从事一个需要在 Intel Skylake Xeon Gold 6126 服务器 CPU 上读取和设置 Uncore Frequency 的项目(我需要对另一个基于 Haswell 的处理器执行相同的操作)。我正在运行带有 Linux 4.15.0-134 的 Ubuntu。 我已经加载了 msr 内核模块。 我现在试图首先读取当前的 Uncore 频率。我正在做以下事情:

sudo wrmsr 0x700 0x2000000000000000
sudo wrmsr 0x703 0x400000
sudo rdmsr 0x704

我在 Intel discussion thread 上找到了上述解决方案

但是,我现在正在尝试修改最小和最大非核心频率。 为此,我首先尝试读取最小频率(将其存储以备后用):

sudo rdmsr 0x620

以上返回 1818。我不确定这个数字是多少。 technical document将它的前 7 位称为 最小频率比(十进制值为 24)。但我不确定这个值是多少。此外,根据文档,第 8-14 位存储最大频率比。然而,第 8-14 位结果也是 24。

有人可以解释一下这些值是什么吗?它们是根据哪个值计算的?

此外,更改非核心频率是否只需要写入 0x620 处的适当寄存器位,就像这样?

sudo wrmsr 0x620 0x1c18

对于上述问题的任何指导,我将不胜感激。

最佳答案

您的非核心频率监控方法是正确的。您必须在 (U_MSR_PMON_FIXED_CTL) 中启用监控,然后您可以读取性能计数器 (U_MSR_PMON_FIXED_CTR)。根据我的经验,写入 U_MSR_PMON_GLOBAL_CTL 是没有必要的。参见 Uncore performance monitoring manual .

您的非核心频率比率 24,代表频率 2.4 GHz,您可以从 U_MSR_PMON_FIXED_CTR 中看到。

默认情况下,MSR_UNCORE_RATIO_LIMIT 保留可能的最小值和最大值,这两个值并不相同。据我所知,这些限制未存储在任何其他可用的 MSR 中,因此您应该存储它们。重启系统将恢复默认值。

两个额外提示:

要在 Intel 上读/写 MSR(也适用于 AMD CPU),使用 msr-safe 是个好方法,因为它允许根据寄存器列表(指定可以访问哪个寄存器)及其掩码(指定可以写入哪些位)访问没有 sudo 权限的寄存器。

要调整和监控(不仅是)非核心频率,您可以使用我的库 MERIC .

关于x86 - 读取当前非核心频率并设置非核心倍频器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66084371/

相关文章:

glsl - Alderlake GT1 上的着色器编译器 : SIMD32 shader inefficient

x86 - 英特尔 Nehalem 微架构可以实现的最大 IPC 是多少?

java - 为 Booth 算法实现算术右移

更正 sys_uname 的内联汇编代码

x86 - 三重故障不会使系统复位

assembly - 64 位模式下的地址覆盖前缀

tomcat - cpu如何分配给一个进程?

assembly - 为什么没有一个寄存器包含 EAX 的高字节?

c - 在程序集中搜索 2 个不同值的最快方法

assembly - ascii char 到 char 的转换 汇编x86?