2024-06-05 12:07:20 -07:00
|
|
|
package gpu
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bufio"
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/ollama/ollama/format"
|
|
|
|
)
|
|
|
|
|
|
|
|
var CudartGlobs = []string{
|
|
|
|
"/usr/local/cuda/lib64/libcudart.so*",
|
|
|
|
"/usr/lib/x86_64-linux-gnu/nvidia/current/libcudart.so*",
|
|
|
|
"/usr/lib/x86_64-linux-gnu/libcudart.so*",
|
|
|
|
"/usr/lib/wsl/lib/libcudart.so*",
|
|
|
|
"/usr/lib/wsl/drivers/*/libcudart.so*",
|
|
|
|
"/opt/cuda/lib64/libcudart.so*",
|
|
|
|
"/usr/local/cuda*/targets/aarch64-linux/lib/libcudart.so*",
|
|
|
|
"/usr/lib/aarch64-linux-gnu/nvidia/current/libcudart.so*",
|
|
|
|
"/usr/lib/aarch64-linux-gnu/libcudart.so*",
|
|
|
|
"/usr/local/cuda/lib*/libcudart.so*",
|
|
|
|
"/usr/lib*/libcudart.so*",
|
|
|
|
"/usr/local/lib*/libcudart.so*",
|
|
|
|
}
|
|
|
|
|
|
|
|
var NvmlGlobs = []string{}
|
|
|
|
|
|
|
|
var NvcudaGlobs = []string{
|
|
|
|
"/usr/local/cuda*/targets/*/lib/libcuda.so*",
|
|
|
|
"/usr/lib/*-linux-gnu/nvidia/current/libcuda.so*",
|
|
|
|
"/usr/lib/*-linux-gnu/libcuda.so*",
|
|
|
|
"/usr/lib/wsl/lib/libcuda.so*",
|
|
|
|
"/usr/lib/wsl/drivers/*/libcuda.so*",
|
|
|
|
"/opt/cuda/lib*/libcuda.so*",
|
|
|
|
"/usr/local/cuda/lib*/libcuda.so*",
|
|
|
|
"/usr/lib*/libcuda.so*",
|
|
|
|
"/usr/local/lib*/libcuda.so*",
|
|
|
|
}
|
|
|
|
|
|
|
|
var OneapiGlobs = []string{
|
|
|
|
"/usr/lib/x86_64-linux-gnu/libze_intel_gpu.so*",
|
|
|
|
"/usr/lib*/libze_intel_gpu.so*",
|
|
|
|
}
|
|
|
|
|
2024-08-01 14:52:15 -07:00
|
|
|
var (
|
|
|
|
CudartMgmtName = "libcudart.so*"
|
|
|
|
NvcudaMgmtName = "libcuda.so*"
|
|
|
|
NvmlMgmtName = "" // not currently wired on linux
|
2024-07-08 12:50:11 -07:00
|
|
|
OneapiMgmtName = "libze_intel_gpu.so*"
|
2024-08-01 14:52:15 -07:00
|
|
|
)
|
2024-06-05 12:07:20 -07:00
|
|
|
|
|
|
|
func GetCPUMem() (memInfo, error) {
|
|
|
|
var mem memInfo
|
2024-07-11 16:42:57 -07:00
|
|
|
var total, available, free, buffers, cached, freeSwap uint64
|
2024-06-05 12:07:20 -07:00
|
|
|
f, err := os.Open("/proc/meminfo")
|
|
|
|
if err != nil {
|
|
|
|
return mem, err
|
|
|
|
}
|
|
|
|
defer f.Close()
|
|
|
|
s := bufio.NewScanner(f)
|
|
|
|
for s.Scan() {
|
|
|
|
line := s.Text()
|
|
|
|
switch {
|
|
|
|
case strings.HasPrefix(line, "MemTotal:"):
|
|
|
|
_, err = fmt.Sscanf(line, "MemTotal:%d", &total)
|
|
|
|
case strings.HasPrefix(line, "MemAvailable:"):
|
|
|
|
_, err = fmt.Sscanf(line, "MemAvailable:%d", &available)
|
|
|
|
case strings.HasPrefix(line, "MemFree:"):
|
|
|
|
_, err = fmt.Sscanf(line, "MemFree:%d", &free)
|
|
|
|
case strings.HasPrefix(line, "Buffers:"):
|
|
|
|
_, err = fmt.Sscanf(line, "Buffers:%d", &buffers)
|
|
|
|
case strings.HasPrefix(line, "Cached:"):
|
|
|
|
_, err = fmt.Sscanf(line, "Cached:%d", &cached)
|
2024-07-11 16:42:57 -07:00
|
|
|
case strings.HasPrefix(line, "SwapFree:"):
|
|
|
|
_, err = fmt.Sscanf(line, "SwapFree:%d", &freeSwap)
|
2024-06-05 12:07:20 -07:00
|
|
|
default:
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if err != nil {
|
|
|
|
return mem, err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
mem.TotalMemory = total * format.KibiByte
|
2024-07-11 16:42:57 -07:00
|
|
|
mem.FreeSwap = freeSwap * format.KibiByte
|
|
|
|
if available > 0 {
|
|
|
|
mem.FreeMemory = available * format.KibiByte
|
|
|
|
} else {
|
|
|
|
mem.FreeMemory = (free + buffers + cached) * format.KibiByte
|
|
|
|
}
|
2024-06-05 12:07:20 -07:00
|
|
|
return mem, nil
|
|
|
|
}
|