llama_darwin.go 899 B

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. package llama
  2. import (
  3. "errors"
  4. "io"
  5. "log"
  6. "os"
  7. "path/filepath"
  8. )
  9. func init() {
  10. if err := initBackend(); err != nil {
  11. log.Printf("WARNING: GPU could not be initialized correctly: %v", err)
  12. log.Printf("WARNING: falling back to CPU")
  13. }
  14. }
  15. func initBackend() error {
  16. exec, err := os.Executable()
  17. if err != nil {
  18. return err
  19. }
  20. exec, err = filepath.EvalSymlinks(exec)
  21. if err != nil {
  22. return err
  23. }
  24. metal := filepath.Join(filepath.Dir(exec), "ggml-metal.metal")
  25. if _, err := os.Stat(metal); err != nil {
  26. if !errors.Is(err, os.ErrNotExist) {
  27. return err
  28. }
  29. dst, err := os.Create(filepath.Join(filepath.Dir(exec), "ggml-metal.metal"))
  30. if err != nil {
  31. return err
  32. }
  33. defer dst.Close()
  34. src, err := fs.Open("ggml-metal.metal")
  35. if err != nil {
  36. return err
  37. }
  38. defer src.Close()
  39. if _, err := io.Copy(dst, src); err != nil {
  40. return err
  41. }
  42. }
  43. return nil
  44. }