问题描述
我正在开展一个项目,该项目需要在 Intel Skylake Xeon Gold 6126 服务器 cpu 上读取和设置 Uncore 频率(我需要为另一个基于 Haswell 的处理器执行相同操作)。我正在使用 Linux 4.15.0-134 运行 Ubuntu。
我已经加载了 msr
内核模块。
我现在试图首先读取当前的 Uncore 频率。我正在执行以下操作:
sudo wrmsr 0x700 0x2000000000000000
sudo wrmsr 0x703 0x400000
sudo rdmsr 0x704
上找到了上述解决方案
但是,我现在正在尝试修改最小和最大非核心频率。 为此,我首先尝试读取最小频率(将其存储以供以后参考):
sudo rdmsr 0x620
以上返回 1818。我不确定这个数字是多少。 technical document 将其前 7 位称为 minimum frequency ratio
(十进制值为 24)。但我不确定这个值是什么。此外,根据文档,第 8-14 位存储 maximum frequency ratio
。但是,第 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。