|
@@ -1,6 +1,7 @@
|
|
|
//go:build darwin
|
|
|
|
|
|
package gpu
|
|
|
+
|
|
|
/*
|
|
|
#cgo CFLAGS: -x objective-c
|
|
|
#cgo LDFLAGS: -framework Foundation -framework CoreGraphics -framework Metal
|
|
@@ -8,11 +9,25 @@ package gpu
|
|
|
*/
|
|
|
import "C"
|
|
|
import (
|
|
|
+ "fmt"
|
|
|
+ "log/slog"
|
|
|
+ "os"
|
|
|
"runtime"
|
|
|
+ "strconv"
|
|
|
)
|
|
|
|
|
|
// CheckVRAM returns the free VRAM in bytes on Linux machines with NVIDIA GPUs
|
|
|
func CheckVRAM() (int64, error) {
|
|
|
+ userLimit := os.Getenv("OLLAMA_MAX_VRAM")
|
|
|
+ if userLimit != "" {
|
|
|
+ avail, err := strconv.ParseInt(userLimit, 10, 64)
|
|
|
+ if err != nil {
|
|
|
+ return 0, fmt.Errorf("Invalid OLLAMA_MAX_VRAM setting %s: %s", userLimit, err)
|
|
|
+ }
|
|
|
+ slog.Info(fmt.Sprintf("user override OLLAMA_MAX_VRAM=%d", avail))
|
|
|
+ return avail, nil
|
|
|
+ }
|
|
|
+
|
|
|
if runtime.GOARCH == "amd64" {
|
|
|
// gpu not supported, this may not be metal
|
|
|
return 0, nil
|