Browse Source

Fix: Add safety check to hwmon read

Avoid panic for accessing slice out of range in hwmon.

Fixes: https://github.com/prometheus/node_exporter/issues/3108

Signed-off-by: Ben Kochie <superq@gmail.com>
pull/3138/head
Ben Kochie 2 months ago committed by Johannes 'fish' Ziemke
parent
commit
1b332edfe8
  1. 4
      collector/hwmon_linux.go

4
collector/hwmon_linux.go

@ -18,6 +18,7 @@ package collector
import ( import (
"errors" "errors"
"fmt"
"log/slog" "log/slog"
"os" "os"
"path/filepath" "path/filepath"
@ -107,6 +108,9 @@ func sysReadFile(file string) ([]byte, error) {
if err != nil { if err != nil {
return nil, err return nil, err
} }
if n < 0 {
return nil, fmt.Errorf("failed to read file: %q, read returned negative bytes value: %d", file, n)
}
return b[:n], nil return b[:n], nil
} }

Loading…
Cancel
Save