3

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

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

我在英特尔讨论线程上找到了上述解决方案

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

sudo rdmsr 0x620

上面返回 1818。我不确定这个数字是多少。技术文档称它的前 7 位为 a minimum frequency ratio(十进制值为 24)。但我不确定这个值是多少。此外,根据文档,位 8-14 存储maximum frequency ratio. 但是,8-14 位也变成了 24 位。

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

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

sudo wrmsr 0x620 0x1c18

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

4

1 回答 1

0

您的非核心频率监控方法是正确的。您必须在 ( ) 中启用监控,U_MSR_PMON_FIXED_CTL然后才能读取性能计数器 ( U_MSR_PMON_FIXED_CTR)。U_MSR_PMON_GLOBAL_CTL根据我的经验,没有必要写到。请参阅Uncore 性能监控手册

您的非核心频率 24,代表频率 2.4 GHz,您可以从U_MSR_PMON_FIXED_CTR.

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

两个额外的提示:

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

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

于 2021-07-09T06:08:00.960 回答