Merge pull request #433 from bachandi/respect_amd_power_state

Add respect_power_state option
This commit is contained in:
Jordi Sanfeliu 2022-08-29 11:46:22 +02:00 committed by GitHub
commit d2ab758ed3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 66 additions and 14 deletions

View File

@ -196,6 +196,7 @@ sub amdgpu_update {
my $rrd = $config->{base_lib} . $package . ".rrd"; my $rrd = $config->{base_lib} . $package . ".rrd";
my $amdgpu = $config->{amdgpu}; my $amdgpu = $config->{amdgpu};
my $use_nan_for_missing_data = lc($amdgpu->{use_nan_for_missing_data} || "") eq "y" ? 1 : 0; my $use_nan_for_missing_data = lc($amdgpu->{use_nan_for_missing_data} || "") eq "y" ? 1 : 0;
my $respect_power_state = lc($amdgpu->{respect_power_state} || "") eq "y" ? 1 : 0;
my @sensors; my @sensors;
@ -216,21 +217,44 @@ sub amdgpu_update {
my $str = trim($gpu_group[$n] || ""); my $str = trim($gpu_group[$n] || "");
my @sensor_names = split(',', $amdgpu->{sensors}->{$str}); my @sensor_names = split(',', $amdgpu->{sensors}->{$str});
for(my $i_sensor = 0; $i_sensor < $number_of_values_per_gpu_in_rrd; $i_sensor++) { my $gpu_in_d3_state = 0;
if ($i_sensor < scalar(@sensor_names)) { if ($respect_power_state) {
my $sensor_name = $sensor_names[$i_sensor]; my $power_state_sensor_name = $amdgpu->{power_states}->{$str};
chomp($sensor_name); if (defined($power_state_sensor_name)) {
$sensor_name = trim($sensor_name); chomp($power_state_sensor_name);
if ($sensor_name ne "") { $power_state_sensor_name = trim($power_state_sensor_name);
my $sensor_file = $sensor_name; if ($power_state_sensor_name ne "") {
if(open(IN, $sensor_file)) { my $power_state_sensor_file = $power_state_sensor_name;
if(open(IN, $power_state_sensor_file)) {
my $val = <IN>; my $val = <IN>;
close(IN); close(IN);
$val = trim($val); if (index(lc($val), lc("D3")) != -1) {
chomp($val); $gpu_in_d3_state = 1;
$sensors[$i_sensor] = $val; }
} else { } else {
logger("$myself: ERROR: unable to open '$sensor_file'."); logger("$myself: ERROR: unable to open power state sensor file '$power_state_sensor_file'.");
}
}
}
}
if (!$gpu_in_d3_state) {
for(my $i_sensor = 0; $i_sensor < $number_of_values_per_gpu_in_rrd; $i_sensor++) {
if ($i_sensor < scalar(@sensor_names)) {
my $sensor_name = $sensor_names[$i_sensor];
chomp($sensor_name);
$sensor_name = trim($sensor_name);
if ($sensor_name ne "") {
my $sensor_file = $sensor_name;
if(open(IN, $sensor_file)) {
my $val = <IN>;
close(IN);
$val = trim($val);
chomp($val);
$sensors[$i_sensor] = $val;
} else {
logger("$myself: ERROR: unable to open '$sensor_file'.");
}
} }
} }
} }

View File

@ -2012,6 +2012,28 @@ This option, when enabled via \fIy\fP, combined with the \fIshow_gaps\fP option
.P .P
Default value: \fIn\fP Default value: \fIn\fP
.RE .RE
.P
.BI respect_power_state
.RS
This option, when enabled via \fIy\fP, will respect the AMD GPU D3 power state. Monitorix won't wake up a GPU in D3 power state to check the sensors values but skip it. The power state sensor has to be specified via the \fpower_states\fP option for each GPU that should be respected.
.P
Default value: \fIn\fP
.RE
.P
.BI power_states
.RS
This list complements the \fBrespect_power_state\fP option. You can specify the power_state sensor for each GPU that should not be woken up if in D3.
.P
.RS
<power_states>
.br
amd-w6800 = /dev/hwmon-w6800/device/power_state
.br
amd-rx6900 = /dev/hwmon-rx6900/device/power_state
.br
</power_states>
.RE
.RE
.SS NVIDIA GPU temperatures and usage (nvidiagpu.pm) .SS NVIDIA GPU temperatures and usage (nvidiagpu.pm)
This graph is able to monitor an unlimited number of Nvidia GPUs via \fInvidia-smi\fP. This graph is able to monitor an unlimited number of Nvidia GPUs via \fInvidia-smi\fP.
.P .P

View File

@ -389,10 +389,16 @@ secure_log_date_format = %b %e
amd-wx5100 = WX 5100 amd-wx5100 = WX 5100
</map> </map>
<sensors> <sensors>
amd-w6800 = /dev/device/gpu_busy_percent, /dev/device/mem_busy_percent, /dev/freq1_input, /dev/freq2_input, /dev/device/mem_info_vram_used, /dev/power1_average, /dev/power1_cap, pwm1, /dev/temp1_input, /dev/temp2_input, /dev/temp3_input amd-w6800 = /dev/device1/gpu_busy_percent, /dev/device1/mem_busy_percent, /dev/device1/freq1_input, /dev/device1/freq2_input, /dev/device1/mem_info_vram_used, /dev/device1/power1_average, /dev/device1/power1_cap, /dev/device1/pwm1, /dev/device1/temp1_input, /dev/device1/temp2_input, /dev/device1/temp3_input
amd-wx5100 = /dev/device/gpu_busy_percent, /dev/device/mem_busy_percent, /dev/freq1_input, /dev/freq2_input, /dev/device/mem_info_vram_used, power1_average, /dev/power1_cap, /dev/pwm1, /dev/temp1_input, , amd-wx5100 = /dev/device2/gpu_busy_percent, /dev/device2/mem_busy_percent, /dev/device2/freq1_input, /dev/device2/freq2_input, /dev/device2/mem_info_vram_used, /dev/device2/power1_average, /dev/device2/power1_cap, /dev/device2/pwm1, /dev/device2/temp1_input, ,
</sensors> </sensors>
respect_power_state = n
<power_states>
amd-w6800 = /dev/device1/power_state
amd-wx5100 = /dev/device2/power_state
</power_states>
<alerts> <alerts>
coretemp_enabled = n coretemp_enabled = n
coretemp_timeintvl = 0 coretemp_timeintvl = 0