Merge pull request #375 from bachandi/fix_wrong_array_check

Fixes a wrong array size check in amdgpu.pm and nvidiagpu.pm
This commit is contained in:
Jordi Sanfeliu 2021-12-21 10:08:38 +01:00 committed by GitHub
commit e376153760
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 9 additions and 9 deletions

View File

@ -53,7 +53,7 @@ sub amdgpu_init {
# values delimitted by ", " (comma + space) # values delimitted by ", " (comma + space)
my @gpu_group = split(', ', $amdgpu->{list}->{$k}); my @gpu_group = split(', ', $amdgpu->{list}->{$k});
for(my $n = 0; $n < $max_number_of_gpus; $n++) { for(my $n = 0; $n < $max_number_of_gpus; $n++) {
if($gpu_group[$n]) { if($n < scalar(@gpu_group)) {
my $d = trim($gpu_group[$n]); my $d = trim($gpu_group[$n]);
$d =~ s/^\"//; $d =~ s/^\"//;
$d =~ s/\"$//; $d =~ s/\"$//;
@ -543,7 +543,7 @@ sub amdgpu_cgi {
push(@tmp, "COMMENT: \\n"); push(@tmp, "COMMENT: \\n");
} }
for($n = 0; $n < $max_number_of_gpus; $n += 1) { for($n = 0; $n < $max_number_of_gpus; $n += 1) {
if($d[$n]) { if($n < scalar(@d)) {
my $dstr = trim($d[$n]); my $dstr = trim($d[$n]);
my $base = ""; my $base = "";
$dstr =~ s/^\"//; $dstr =~ s/^\"//;
@ -573,7 +573,7 @@ sub amdgpu_cgi {
my $value_name = "gpu" . $n . "_val" . $n_sensor; my $value_name = "gpu" . $n . "_val" . $n_sensor;
my $value_name2; my $value_name2;
push(@tmp, "LINE2:trans_" . $value_name . $LC[$n] . ":$str" . ($n_plot < $main_sensor_plots ? "" : ( $show_current_values ? "\\: \\g" : (($n%2 || !$d[$n+1]) ? "\\n" : "")))); push(@tmp, "LINE2:trans_" . $value_name . $LC[$n] . ":$str" . ($n_plot < $main_sensor_plots ? "" : ( $show_current_values ? "\\: \\g" : (($n%2 || ($n+1 == scalar(@d))) ? "\\n" : ""))));
push(@tmpz, "LINE2:trans_" . $value_name . $LC[$n] . ":$dstr"); push(@tmpz, "LINE2:trans_" . $value_name . $LC[$n] . ":$dstr");
if ($n_sensor2) { if ($n_sensor2) {
@ -612,7 +612,7 @@ sub amdgpu_cgi {
push(@tmp, "GPRINT:trans_" . $value_name . ":LAST:" . $legend_labels_per_sensor[$n_sensor] . "\\g"); push(@tmp, "GPRINT:trans_" . $value_name . ":LAST:" . $legend_labels_per_sensor[$n_sensor] . "\\g");
push(@tmp, "GPRINT:trans_" . $value_name2 . ":LAST: /" . $legend_labels_per_sensor[$n_sensor2] . " (actual/limit)\\n"); push(@tmp, "GPRINT:trans_" . $value_name2 . ":LAST: /" . $legend_labels_per_sensor[$n_sensor2] . " (actual/limit)\\n");
} else { } else {
push(@tmp, "GPRINT:trans_" . $value_name . ":LAST:" . $legend_labels_per_sensor[$n_sensor] . (($n%2 || !$d[$n+1]) ? "\\n" : "")); push(@tmp, "GPRINT:trans_" . $value_name . ":LAST:" . $legend_labels_per_sensor[$n_sensor] . (($n%2 || ($n+1 == scalar(@d))) ? "\\n" : ""));
} }
} }
} }

View File

@ -182,8 +182,8 @@ sub nvidiagpu_update {
for($n = 0; $n < $max_number_of_gpus; $n++) { for($n = 0; $n < $max_number_of_gpus; $n++) {
@sensors = ($use_nan_for_missing_data ? (0+"nan") : 0) x $number_of_values_per_gpu_in_rrd; @sensors = ($use_nan_for_missing_data ? (0+"nan") : 0) x $number_of_values_per_gpu_in_rrd;
if($gpu_group[$n]) { if($n < scalar(@gpu_group)) {
my $str = trim($gpu_group[$n] || ""); my $str = trim($gpu_group[$n]);
open(IN, "nvidia-smi --format=csv,noheader,nounits -i $str --query-gpu=clocks.current.graphics,clocks.current.memory,utilization.gpu,utilization.memory,temperature.gpu,temperature.memory,fan.speed,pstate,power.draw,power.limit,memory.used,memory.total |"); open(IN, "nvidia-smi --format=csv,noheader,nounits -i $str --query-gpu=clocks.current.graphics,clocks.current.memory,utilization.gpu,utilization.memory,temperature.gpu,temperature.memory,fan.speed,pstate,power.draw,power.limit,memory.used,memory.total |");
while(<IN>) { while(<IN>) {
@ -512,7 +512,7 @@ sub nvidiagpu_cgi {
push(@tmp, "COMMENT: \\n"); push(@tmp, "COMMENT: \\n");
} }
for($n = 0; $n < $max_number_of_gpus; $n += 1) { for($n = 0; $n < $max_number_of_gpus; $n += 1) {
if($d[$n]) { if($n < scalar(@d)) {
my $dstr = trim($d[$n]); my $dstr = trim($d[$n]);
my $base = ""; my $base = "";
$dstr =~ s/^\"//; $dstr =~ s/^\"//;
@ -542,7 +542,7 @@ sub nvidiagpu_cgi {
my $value_name = "gpu" . $n . "_val" . $n_sensor; my $value_name = "gpu" . $n . "_val" . $n_sensor;
my $value_name2; my $value_name2;
push(@tmp, "LINE2:trans_" . $value_name . $LC[$n] . ":$str" . ($n_plot < $main_sensor_plots ? "" : ( $show_current_values ? "\\: \\g" : (($n%2 || !$d[$n+1]) ? "\\n" : "")))); push(@tmp, "LINE2:trans_" . $value_name . $LC[$n] . ":$str" . ($n_plot < $main_sensor_plots ? "" : ( $show_current_values ? "\\: \\g" : (($n%2 || ($n+1 == scalar(@d))) ? "\\n" : ""))));
push(@tmpz, "LINE2:trans_" . $value_name . $LC[$n] . ":$dstr"); push(@tmpz, "LINE2:trans_" . $value_name . $LC[$n] . ":$dstr");
if ($n_sensor2) { if ($n_sensor2) {
@ -566,7 +566,7 @@ sub nvidiagpu_cgi {
push(@tmp, "GPRINT:trans_" . $value_name . ":LAST:" . $legend_labels_per_sensor[$n_sensor] . "\\g"); push(@tmp, "GPRINT:trans_" . $value_name . ":LAST:" . $legend_labels_per_sensor[$n_sensor] . "\\g");
push(@tmp, "GPRINT:trans_" . $value_name2 . ":LAST: /" . $legend_labels_per_sensor[$n_sensor2] . " (actual/limit)\\n"); push(@tmp, "GPRINT:trans_" . $value_name2 . ":LAST: /" . $legend_labels_per_sensor[$n_sensor2] . " (actual/limit)\\n");
} else { } else {
push(@tmp, "GPRINT:trans_" . $value_name . ":LAST:" . $legend_labels_per_sensor[$n_sensor] . (($n%2 || !$d[$n+1]) ? "\\n" : "")); push(@tmp, "GPRINT:trans_" . $value_name . ":LAST:" . $legend_labels_per_sensor[$n_sensor] . (($n%2 || ($n+1 == scalar(@d))) ? "\\n" : ""));
} }
} }
} }