From d3d652353bf824bff45c42a480c35b3214b0af86 Mon Sep 17 00:00:00 2001 From: Britt Lewis Date: Wed, 24 Jul 2024 23:33:50 -0400 Subject: [PATCH 1/2] Fix metal compilation on macos * changes upstream in ggerganov/llama.cpp#8006 - https://github.com/ggerganov/llama.cpp/commit/f3f65429c44bb195a9195bfdc19a30a79709db7b --- llama-cpp-sys-2/build.rs | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/llama-cpp-sys-2/build.rs b/llama-cpp-sys-2/build.rs index 0e4c9a57..9442d495 100644 --- a/llama-cpp-sys-2/build.rs +++ b/llama-cpp-sys-2/build.rs @@ -457,7 +457,7 @@ fn compile_cuda(cx: &mut Build, cxx: &mut Build, featless_cxx: Build) -> &'stati let lib_name = "ggml-cuda"; let ggml_path = LLAMA_PATH.join("ggml"); let ggml_src = ggml_path.join("src"); - let cuda_path = ggml_src.join("ggml-cuda"); + let cuda_path = ggml_src.join(lib_name); let cuda_sources = read_dir(cuda_path.as_path()) .unwrap() .map(|f| f.unwrap()) @@ -497,15 +497,19 @@ fn compile_metal(cx: &mut Build, cxx: &mut Build) { // It's idiomatic to use OUT_DIR for intermediate c/c++ artifacts let out_dir = env::var("OUT_DIR").unwrap(); - let ggml_metal_shader_path = LLAMA_PATH.join("ggml-metal.metal"); + let lib_name = "ggml-metal.metal"; + let ggml_path = LLAMA_PATH.join("ggml"); + let ggml_src = ggml_path.join("src"); + let ggml_include = ggml_path.join("include"); + let ggml_metal_shader_path = ggml_src.join(lib_name); // Create a temporary assembly file that will allow for static linking to the metal shader. let ggml_metal_embed_assembly_path = PathBuf::from(&out_dir).join("ggml-metal-embed.asm"); let mut ggml_metal_embed_assembly_file = File::create(&ggml_metal_embed_assembly_path) .expect("Failed to open ggml-metal-embed.asm file"); - let ggml_metal_shader_out_path = PathBuf::from(&out_dir).join("ggml-metal.metal"); - let common = LLAMA_PATH.join("ggml-common.h"); + let ggml_metal_shader_out_path = PathBuf::from(&out_dir).join(lib_name); + let common = ggml_src.join("ggml-common.h"); let input_file = File::open(ggml_metal_shader_path).expect("Failed to open input file"); let output_file = @@ -580,8 +584,8 @@ fn compile_metal(cx: &mut Build, cxx: &mut Build) { println!("cargo:rustc-link-search=native={}", &out_dir); println!("cargo:rustc-link-lib=static=ggml-metal-embed"); - cx.include(LLAMA_PATH.join("ggml-metal.h")) - .file(LLAMA_PATH.join("ggml-metal.m")); + cx.include(ggml_include.join("ggml-metal.h")) + .file(ggml_src.join("ggml-metal.m")); } fn find_windows_vulkan_sdk() -> PathBuf { From 22db5f44641d47b9730caadc3897405364744997 Mon Sep 17 00:00:00 2001 From: Britt Lewis Date: Thu, 25 Jul 2024 01:05:29 -0400 Subject: [PATCH 2/2] Fix LLAMA_HEADER env override typo --- llama-cpp-sys-2/build.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/llama-cpp-sys-2/build.rs b/llama-cpp-sys-2/build.rs index 9442d495..3e85bc4c 100644 --- a/llama-cpp-sys-2/build.rs +++ b/llama-cpp-sys-2/build.rs @@ -687,7 +687,7 @@ fn main() { println!("cargo:rustc-link-lib=llama"); println!("cargo:rustc-link-lib=ggml"); - let llama_header_path = std::env::var("LLAMA_HEADE"); + let llama_header_path = std::env::var("LLAMA_HEADER"); if let Ok(llama_header_path) = llama_header_path { compile_bindings(&out_path, Path::new(&llama_header_path)) .expect("failed to generate bindings");