Harden AMD driver lookup logic

It looks like the version file doesnt exist on older(?) drivers
This commit is contained in:
Daniel Hiltgen 2024-02-16 16:20:16 -08:00
parent 88622847c6
commit 9754c6d9d8
2 changed files with 16 additions and 3 deletions

View file

@ -2,6 +2,7 @@ package gpu
import ( import (
"bufio" "bufio"
"errors"
"fmt" "fmt"
"io" "io"
"log/slog" "log/slog"
@ -24,14 +25,23 @@ const (
) )
func AMDDetected() bool { func AMDDetected() bool {
_, err := AMDDriverVersion() // Some driver versions (older?) don't have a version file, so just lookup the parent dir
return err == nil sysfsDir := filepath.Dir(DriverVersionFile)
_, err := os.Stat(sysfsDir)
if errors.Is(err, os.ErrNotExist) {
slog.Debug("amd driver not detected " + sysfsDir)
return false
} else if err != nil {
slog.Debug(fmt.Sprintf("error looking up amd driver %s %s", sysfsDir, err))
return false
}
return true
} }
func AMDDriverVersion() (string, error) { func AMDDriverVersion() (string, error) {
_, err := os.Stat(DriverVersionFile) _, err := os.Stat(DriverVersionFile)
if err != nil { if err != nil {
return "", err return "", fmt.Errorf("amdgpu file stat error: %s %w", DriverVersionFile, err)
} }
fp, err := os.Open(DriverVersionFile) fp, err := os.Open(DriverVersionFile)
if err != nil { if err != nil {

View file

@ -153,6 +153,9 @@ func GetGPUInfo() GpuInfo {
ver, err := AMDDriverVersion() ver, err := AMDDriverVersion()
if err == nil { if err == nil {
slog.Info("AMD Driver: " + ver) slog.Info("AMD Driver: " + ver)
} else {
// For now this is benign, but we may eventually need to fail compatibility checks
slog.Debug("error looking up amd driver version: %s", err)
} }
gfx := AMDGFXVersions() gfx := AMDGFXVersions()
tooOld := false tooOld := false