gen_darwin.sh 3.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. #!/bin/bash
  2. # This script is intended to run inside the `go run build.go` script, which
  3. # sets the working directory to the correct location: ./llm/generate/.
  4. # TODO - add hardening to detect missing tools (cmake, etc.)
  5. set -ex
  6. set -o pipefail
  7. echo "Starting darwin generate script"
  8. source $(dirname $0)/gen_common.sh
  9. init_vars
  10. git_module_setup
  11. apply_patches
  12. sign() {
  13. if [ -n "$APPLE_IDENTITY" ]; then
  14. codesign -f --timestamp --deep --options=runtime --sign "$APPLE_IDENTITY" --identifier ai.ollama.ollama $1
  15. fi
  16. }
  17. COMMON_DARWIN_DEFS="-DCMAKE_OSX_DEPLOYMENT_TARGET=11.3 -DLLAMA_METAL_MACOSX_VERSION_MIN=11.3 -DCMAKE_SYSTEM_NAME=Darwin -DLLAMA_METAL_EMBED_LIBRARY=on"
  18. case "${GOARCH}" in
  19. "amd64")
  20. COMMON_CPU_DEFS="${COMMON_DARWIN_DEFS} -DCMAKE_SYSTEM_PROCESSOR=${ARCH} -DCMAKE_OSX_ARCHITECTURES=${ARCH} -DLLAMA_METAL=off -DLLAMA_NATIVE=off"
  21. # Static build for linking into the Go binary
  22. init_vars
  23. CMAKE_TARGETS="--target llama --target ggml"
  24. CMAKE_DEFS="${COMMON_CPU_DEFS} -DBUILD_SHARED_LIBS=off -DLLAMA_ACCELERATE=off -DLLAMA_AVX=off -DLLAMA_AVX2=off -DLLAMA_AVX512=off -DLLAMA_FMA=off -DLLAMA_F16C=off ${CMAKE_DEFS}"
  25. BUILD_DIR="../build/darwin/${ARCH}_static"
  26. echo "Building static library"
  27. build
  28. #
  29. # CPU first for the default library, set up as lowest common denominator for maximum compatibility (including Rosetta)
  30. #
  31. init_vars
  32. CMAKE_DEFS="${COMMON_CPU_DEFS} -DLLAMA_ACCELERATE=off -DLLAMA_AVX=off -DLLAMA_AVX2=off -DLLAMA_AVX512=off -DLLAMA_FMA=off -DLLAMA_F16C=off ${CMAKE_DEFS}"
  33. BUILD_DIR="../build/darwin/${ARCH}/cpu"
  34. echo "Building LCD CPU"
  35. build
  36. sign ${BUILD_DIR}/bin/ollama_llama_server
  37. compress
  38. #
  39. # ~2011 CPU Dynamic library with more capabilities turned on to optimize performance
  40. # Approximately 400% faster than LCD on same CPU
  41. #
  42. init_vars
  43. CMAKE_DEFS="${COMMON_CPU_DEFS} -DLLAMA_ACCELERATE=off -DLLAMA_AVX=on -DLLAMA_AVX2=off -DLLAMA_AVX512=off -DLLAMA_FMA=off -DLLAMA_F16C=off ${CMAKE_DEFS}"
  44. BUILD_DIR="../build/darwin/${ARCH}/cpu_avx"
  45. echo "Building AVX CPU"
  46. build
  47. sign ${BUILD_DIR}/bin/ollama_llama_server
  48. compress
  49. #
  50. # ~2013 CPU Dynamic library
  51. # Approximately 10% faster than AVX on same CPU
  52. #
  53. init_vars
  54. CMAKE_DEFS="${COMMON_CPU_DEFS} -DLLAMA_ACCELERATE=on -DLLAMA_AVX=on -DLLAMA_AVX2=on -DLLAMA_AVX512=off -DLLAMA_FMA=on -DLLAMA_F16C=on ${CMAKE_DEFS}"
  55. BUILD_DIR="../build/darwin/${ARCH}/cpu_avx2"
  56. echo "Building AVX2 CPU"
  57. EXTRA_LIBS="${EXTRA_LIBS} -framework Accelerate -framework Foundation"
  58. build
  59. sign ${BUILD_DIR}/bin/ollama_llama_server
  60. compress
  61. ;;
  62. "arm64")
  63. # Static build for linking into the Go binary
  64. init_vars
  65. CMAKE_TARGETS="--target llama --target ggml"
  66. CMAKE_DEFS="-DCMAKE_OSX_DEPLOYMENT_TARGET=11.3 -DCMAKE_SYSTEM_NAME=Darwin -DBUILD_SHARED_LIBS=off -DCMAKE_SYSTEM_PROCESSOR=${ARCH} -DCMAKE_OSX_ARCHITECTURES=${ARCH} -DLLAMA_METAL=off -DLLAMA_ACCELERATE=off -DLLAMA_AVX=off -DLLAMA_AVX2=off -DLLAMA_AVX512=off -DLLAMA_FMA=off -DLLAMA_F16C=off ${CMAKE_DEFS}"
  67. BUILD_DIR="../build/darwin/${ARCH}_static"
  68. echo "Building static library"
  69. build
  70. init_vars
  71. CMAKE_DEFS="${COMMON_DARWIN_DEFS} -DLLAMA_ACCELERATE=on -DCMAKE_SYSTEM_PROCESSOR=${ARCH} -DCMAKE_OSX_ARCHITECTURES=${ARCH} -DLLAMA_METAL=on ${CMAKE_DEFS}"
  72. BUILD_DIR="../build/darwin/${ARCH}/metal"
  73. EXTRA_LIBS="${EXTRA_LIBS} -framework Accelerate -framework Foundation -framework Metal -framework MetalKit -framework MetalPerformanceShaders"
  74. build
  75. sign ${BUILD_DIR}/bin/ollama_llama_server
  76. compress
  77. ;;
  78. *)
  79. echo "GOARCH must be set"
  80. echo "this script is meant to be run from within 'go run build.go'"
  81. exit 1
  82. ;;
  83. esac
  84. cleanup
  85. echo "code generation completed. LLM runners: $(cd ${BUILD_DIR}/..; echo *)"