gen_darwin.sh 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. #!/bin/bash
  2. # This script is intended to run inside the go generate
  3. # working directory must be ./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. COMMON_DARWIN_DEFS="-DCMAKE_OSX_DEPLOYMENT_TARGET=11.0 -DCMAKE_SYSTEM_NAME=Darwin -DLLAMA_ACCELERATE=off"
  13. case "${GOARCH}" in
  14. "amd64")
  15. COMMON_CPU_DEFS="${COMMON_DARWIN_DEFS} -DCMAKE_SYSTEM_PROCESSOR=${ARCH} -DCMAKE_OSX_ARCHITECTURES=${ARCH} -DLLAMA_METAL=off -DLLAMA_NATIVE=off"
  16. #
  17. # CPU first for the default library, set up as lowest common denominator for maximum compatibility (including Rosetta)
  18. #
  19. CMAKE_DEFS="${COMMON_CPU_DEFS} -DLLAMA_AVX=off -DLLAMA_AVX2=off -DLLAMA_AVX512=off -DLLAMA_FMA=off -DLLAMA_F16C=off ${CMAKE_DEFS}"
  20. BUILD_DIR="${LLAMACPP_DIR}/build/darwin/${ARCH}/cpu"
  21. echo "Building LCD CPU"
  22. build
  23. compress_libs
  24. #
  25. # ~2011 CPU Dynamic library with more capabilities turned on to optimize performance
  26. # Approximately 400% faster than LCD on same CPU
  27. #
  28. init_vars
  29. CMAKE_DEFS="${COMMON_CPU_DEFS} -DLLAMA_AVX=on -DLLAMA_AVX2=off -DLLAMA_AVX512=off -DLLAMA_FMA=off -DLLAMA_F16C=off ${CMAKE_DEFS}"
  30. BUILD_DIR="${LLAMACPP_DIR}/build/darwin/${ARCH}/cpu_avx"
  31. echo "Building AVX CPU"
  32. build
  33. compress_libs
  34. #
  35. # ~2013 CPU Dynamic library
  36. # Approximately 10% faster than AVX on same CPU
  37. #
  38. init_vars
  39. CMAKE_DEFS="${COMMON_CPU_DEFS} -DLLAMA_AVX=on -DLLAMA_AVX2=on -DLLAMA_AVX512=off -DLLAMA_FMA=on -DLLAMA_F16C=on ${CMAKE_DEFS}"
  40. BUILD_DIR="${LLAMACPP_DIR}/build/darwin/${ARCH}/cpu_avx2"
  41. echo "Building AVX2 CPU"
  42. build
  43. compress_libs
  44. ;;
  45. "arm64")
  46. CMAKE_DEFS="${COMMON_DARWIN_DEFS} -DCMAKE_SYSTEM_PROCESSOR=${ARCH} -DCMAKE_OSX_ARCHITECTURES=${ARCH} -DLLAMA_METAL=on -DLLAMA_ACCELERATE=on ${CMAKE_DEFS}"
  47. BUILD_DIR="${LLAMACPP_DIR}/build/darwin/${ARCH}/metal"
  48. EXTRA_LIBS="${EXTRA_LIBS} -framework Accelerate -framework Foundation -framework Metal -framework MetalKit -framework MetalPerformanceShaders"
  49. build
  50. compress_libs
  51. ;;
  52. *)
  53. echo "GOARCH must be set"
  54. echo "this script is meant to be run from within go generate"
  55. exit 1
  56. ;;
  57. esac
  58. cleanup