2023-11-29 11:00:37 -08:00
|
|
|
#!/bin/bash
|
2024-04-09 15:57:45 -07:00
|
|
|
# This script is intended to run inside the go generate
|
|
|
|
# working directory must be ./llm/generate/
|
2023-11-13 17:20:34 -08:00
|
|
|
|
|
|
|
# TODO - add hardening to detect missing tools (cmake, etc.)
|
|
|
|
|
|
|
|
set -ex
|
|
|
|
set -o pipefail
|
2024-08-09 07:21:40 -07:00
|
|
|
compress_pids=""
|
2023-11-13 17:20:34 -08:00
|
|
|
echo "Starting darwin generate script"
|
|
|
|
source $(dirname $0)/gen_common.sh
|
|
|
|
init_vars
|
2024-01-12 16:28:00 -08:00
|
|
|
git_module_setup
|
|
|
|
apply_patches
|
|
|
|
|
2024-01-19 19:24:11 -05:00
|
|
|
sign() {
|
|
|
|
if [ -n "$APPLE_IDENTITY" ]; then
|
|
|
|
codesign -f --timestamp --deep --options=runtime --sign "$APPLE_IDENTITY" --identifier ai.ollama.ollama $1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2024-09-03 21:12:39 -04:00
|
|
|
COMMON_DARWIN_DEFS="-DBUILD_SHARED_LIBS=off -DCMAKE_OSX_DEPLOYMENT_TARGET=11.3 -DGGML_METAL_MACOSX_VERSION_MIN=11.3 -DCMAKE_SYSTEM_NAME=Darwin -DGGML_METAL_EMBED_LIBRARY=on -DGGML_OPENMP=off"
|
2024-01-12 16:28:00 -08:00
|
|
|
|
2023-11-13 17:20:34 -08:00
|
|
|
case "${GOARCH}" in
|
2023-12-22 09:51:53 -08:00
|
|
|
"amd64")
|
2024-07-05 13:25:58 -04:00
|
|
|
COMMON_CPU_DEFS="${COMMON_DARWIN_DEFS} -DCMAKE_SYSTEM_PROCESSOR=${ARCH} -DCMAKE_OSX_ARCHITECTURES=${ARCH} -DGGML_METAL=off -DGGML_NATIVE=off"
|
2024-01-12 16:28:00 -08:00
|
|
|
|
2024-03-14 10:24:13 -07:00
|
|
|
# Static build for linking into the Go binary
|
|
|
|
init_vars
|
|
|
|
CMAKE_TARGETS="--target llama --target ggml"
|
2024-07-05 21:48:31 -04:00
|
|
|
CMAKE_DEFS="${COMMON_CPU_DEFS} -DGGML_BLAS=off -DGGML_ACCELERATE=off -DGGML_AVX=off -DGGML_AVX2=off -DGGML_AVX512=off -DGGML_FMA=off -DGGML_F16C=off ${CMAKE_DEFS}"
|
2024-03-14 10:24:13 -07:00
|
|
|
BUILD_DIR="../build/darwin/${ARCH}_static"
|
|
|
|
echo "Building static library"
|
|
|
|
build
|
|
|
|
|
2024-05-30 21:43:15 -07:00
|
|
|
if [ -z "$OLLAMA_SKIP_CPU_GENERATE" ]; then
|
|
|
|
#
|
|
|
|
# CPU first for the default library, set up as lowest common denominator for maximum compatibility (including Rosetta)
|
|
|
|
#
|
|
|
|
init_vars
|
2024-07-05 13:25:58 -04:00
|
|
|
CMAKE_DEFS="${COMMON_CPU_DEFS} -DGGML_ACCELERATE=off -DGGML_BLAS=off -DGGML_AVX=off -DGGML_AVX2=off -DGGML_AVX512=off -DGGML_FMA=off -DGGML_F16C=off ${CMAKE_DEFS}"
|
2024-05-30 21:43:15 -07:00
|
|
|
BUILD_DIR="../build/darwin/${ARCH}/cpu"
|
|
|
|
echo "Building LCD CPU"
|
|
|
|
build
|
|
|
|
sign ${BUILD_DIR}/bin/ollama_llama_server
|
|
|
|
compress
|
2024-03-14 10:24:13 -07:00
|
|
|
|
2024-05-30 21:43:15 -07:00
|
|
|
#
|
|
|
|
# ~2011 CPU Dynamic library with more capabilities turned on to optimize performance
|
|
|
|
# Approximately 400% faster than LCD on same CPU
|
|
|
|
#
|
|
|
|
init_vars
|
2024-07-05 13:25:58 -04:00
|
|
|
CMAKE_DEFS="${COMMON_CPU_DEFS} -DGGML_ACCELERATE=off -DGGML_BLAS=off -DGGML_AVX=on -DGGML_AVX2=off -DGGML_AVX512=off -DGGML_FMA=off -DGGML_F16C=off ${CMAKE_DEFS}"
|
2024-05-30 21:43:15 -07:00
|
|
|
BUILD_DIR="../build/darwin/${ARCH}/cpu_avx"
|
|
|
|
echo "Building AVX CPU"
|
|
|
|
build
|
|
|
|
sign ${BUILD_DIR}/bin/ollama_llama_server
|
|
|
|
compress
|
2024-01-12 16:28:00 -08:00
|
|
|
|
2024-05-30 21:43:15 -07:00
|
|
|
#
|
|
|
|
# ~2013 CPU Dynamic library
|
|
|
|
# Approximately 10% faster than AVX on same CPU
|
|
|
|
#
|
|
|
|
init_vars
|
2024-07-05 13:25:58 -04:00
|
|
|
CMAKE_DEFS="${COMMON_CPU_DEFS} -DGGML_ACCELERATE=on -DGGML_BLAS=off -DGGML_AVX=on -DGGML_AVX2=on -DGGML_AVX512=off -DGGML_FMA=on -DGGML_F16C=on ${CMAKE_DEFS}"
|
2024-05-30 21:43:15 -07:00
|
|
|
BUILD_DIR="../build/darwin/${ARCH}/cpu_avx2"
|
|
|
|
echo "Building AVX2 CPU"
|
|
|
|
EXTRA_LIBS="${EXTRA_LIBS} -framework Accelerate -framework Foundation"
|
|
|
|
build
|
|
|
|
sign ${BUILD_DIR}/bin/ollama_llama_server
|
|
|
|
compress
|
|
|
|
fi
|
2023-12-22 09:51:53 -08:00
|
|
|
;;
|
|
|
|
"arm64")
|
2024-03-14 10:24:13 -07:00
|
|
|
|
|
|
|
# Static build for linking into the Go binary
|
|
|
|
init_vars
|
|
|
|
CMAKE_TARGETS="--target llama --target ggml"
|
2024-07-05 22:42:42 -04:00
|
|
|
CMAKE_DEFS="${COMMON_DARWIN_DEFS} -DCMAKE_OSX_DEPLOYMENT_TARGET=11.3 -DCMAKE_SYSTEM_NAME=Darwin -DCMAKE_SYSTEM_PROCESSOR=${ARCH} -DCMAKE_OSX_ARCHITECTURES=${ARCH} ${CMAKE_DEFS}"
|
2024-03-14 10:24:13 -07:00
|
|
|
BUILD_DIR="../build/darwin/${ARCH}_static"
|
|
|
|
echo "Building static library"
|
|
|
|
build
|
|
|
|
|
2024-05-30 21:43:15 -07:00
|
|
|
if [ -z "$OLLAMA_SKIP_METAL_GENERATE" ]; then
|
|
|
|
init_vars
|
2024-07-05 13:25:58 -04:00
|
|
|
CMAKE_DEFS="${COMMON_DARWIN_DEFS} -DCMAKE_SYSTEM_PROCESSOR=${ARCH} -DCMAKE_OSX_ARCHITECTURES=${ARCH} ${CMAKE_DEFS}"
|
2024-05-30 21:43:15 -07:00
|
|
|
BUILD_DIR="../build/darwin/${ARCH}/metal"
|
|
|
|
EXTRA_LIBS="${EXTRA_LIBS} -framework Accelerate -framework Foundation -framework Metal -framework MetalKit -framework MetalPerformanceShaders"
|
|
|
|
build
|
|
|
|
sign ${BUILD_DIR}/bin/ollama_llama_server
|
|
|
|
compress
|
|
|
|
fi
|
2023-12-22 09:51:53 -08:00
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo "GOARCH must be set"
|
2024-04-09 15:57:45 -07:00
|
|
|
echo "this script is meant to be run from within go generate"
|
2023-12-22 09:51:53 -08:00
|
|
|
exit 1
|
|
|
|
;;
|
2023-11-13 17:20:34 -08:00
|
|
|
esac
|
|
|
|
|
2023-12-22 09:51:53 -08:00
|
|
|
cleanup
|
2024-08-09 07:21:40 -07:00
|
|
|
wait_for_compress
|
2024-04-09 15:57:45 -07:00
|
|
|
echo "go generate completed. LLM runners: $(cd ${BUILD_DIR}/..; echo *)"
|