Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: bundle CUDA DLL into the release #62

Open
wants to merge 28 commits into
base: main
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
52a48da
fix: bundle CUDA DLL into the release
louisgv Jul 2, 2023
43330d4
Merge branch 'main' into 61-bug-cuda-dlls
louisgv Jul 3, 2023
4d94a47
Merge branch 'main' into 61-bug-cuda-dlls
louisgv Jul 14, 2023
953af83
Merge branch 'main' into 61-bug-cuda-dlls
LLukas22 Jul 18, 2023
4b71716
Update `rustformers` + check gpu
LLukas22 Jul 18, 2023
4b8fe59
Set `n_batch` correctly
LLukas22 Jul 18, 2023
187b135
Copy cuda libraries
LLukas22 Jul 20, 2023
9343897
reduce feeding delay if gpu is enabled
LLukas22 Jul 21, 2023
a2a3dbf
Copy `opencl` dlls
LLukas22 Jul 21, 2023
a8b3bbf
create linux ci
LLukas22 Jul 21, 2023
21ae9e1
defaults for release infos
LLukas22 Jul 21, 2023
286574d
Fail if files aren't found
LLukas22 Jul 21, 2023
86cc051
Add windows build
LLukas22 Jul 21, 2023
47f9dfc
Macos build
LLukas22 Jul 21, 2023
7c1f25a
ci bugfixes
LLukas22 Jul 22, 2023
36e050b
More bugfixes and absolute paths
LLukas22 Jul 22, 2023
0b26205
Paths .... again
LLukas22 Jul 22, 2023
cc786f0
Make mac artifacts unique
LLukas22 Jul 22, 2023
89eb1fa
renable build for windows-cublas
LLukas22 Jul 22, 2023
0761d79
update character
louisgv Jul 30, 2023
7481edf
Slight refactor
louisgv Aug 1, 2023
9d23cfd
update character
louisgv Aug 2, 2023
5b51725
update llm
louisgv Aug 2, 2023
006cd5a
Merge branch 'main' into 61-bug-cuda-dlls
louisgv Sep 16, 2023
9b8d16d
fix build script
louisgv Sep 16, 2023
bc5edf6
use self-hosted runner for metal
louisgv Sep 16, 2023
18f04ed
remove build on push (consume too much compute atm)
louisgv Sep 16, 2023
1211cc2
Add todo
louisgv Sep 16, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Copy cuda libraries
LLukas22 committed Jul 20, 2023
commit 187b13552e220f6bcaedaa57f0eac8430b9d5843
13 changes: 13 additions & 0 deletions apps/desktop/src-tauri/Cargo.toml
Original file line number Diff line number Diff line change
@@ -9,10 +9,21 @@ edition = "2021"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[[bin]]
name = "force-build"
path = "build.rs"
required-features = ["build_deps"]

[build-dependencies]
tauri-build = { version = "1.4.0", features = [] }
glob = "0.3"

[dependencies]
# Only used when the build is run standalone
tauri-build = { version = "1.4.0", features = [] , optional = true }
glob = { version = "0.3", optional = true }


# Peg the llm version here to prevent unwanted breaking changes
llm = { git = "https://github.com/rustformers/llm", rev = "645093e", package = "llm", features = [
"default",
@@ -106,6 +117,8 @@ cublas = ["llm/cublas"]
clblast = ["llm/clblast"]
metal = ["llm/metal"]

build_deps = ["glob", "tauri-build"]

[profile.dev.package."*"]
opt-level = 3

98 changes: 75 additions & 23 deletions apps/desktop/src-tauri/build.rs
Original file line number Diff line number Diff line change
@@ -1,25 +1,77 @@
// #[cfg(any(target_os = "macos", target_os = "linux"))]
fn main() {
tauri_build::build()
use std::{env, path::{Path, PathBuf}, fs};
extern crate glob;
use glob::glob;

fn main() {
#[cfg(feature = "cublas")]
copy_cuda_dlls();
#[cfg(feature = "clblast")]
copy_opencl_dlls();

tauri_build::build();
}

fn get_build_dir()->PathBuf{
let manifest_dir = env::var("CARGO_MANIFEST_DIR").unwrap();
let mut build_dir = Path::new(&manifest_dir).join("target");
build_dir.push(env::var("PROFILE").unwrap());
build_dir
}

// #[cfg(target_os = "windows")]
// fn main() {
// let mut windows = tauri_build::WindowsAttributes::new();
// windows = windows.app_manifest(
// r#"
// <assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
// <trustInfo xmlns="urn:schemas-microsoft-com:asm.v3">
// <security>
// <requestedPrivileges>
// <requestedExecutionLevel level="requireAdministrator" uiAccess="false" />
// </requestedPrivileges>
// </security>
// </trustInfo>
// </assembly>
// "#,
// );

// tauri_build::try_build(tauri_build::Attributes::new().windows_attributes(windows))
// .expect("failed to run build script")
// }
fn copy_cuda_dlls(){
// Get the directory of the output executable.
let out_dir = get_build_dir();

// Get the CUDA path from the environment variable.
let cude_env = env::var("CUDA_PATH").expect("CUDA_PATH not found");
let cuda_path = Path::new(&cude_env);

// Patterns to search for the DLL files.
#[cfg(target_os = "windows")]
let patterns = [
"cublas64_*.dll",
"cublasLt64_*.dll",
"cudart64_*.dll"
];
#[cfg(target_os = "windows")]
let binary_path = cuda_path.join("bin");

#[cfg(target_os = "linux")]
let patterns = [
"libcudart.so",
"libcublasLt.so",
"libcublas.so"
];
#[cfg(target_os = "linux")]
let binary_path = cuda_path.join("lib64");


for pattern in &patterns {
// Construct the full glob pattern.
let full_pattern = format!("{}/{}", binary_path.to_str().unwrap(), pattern);

// Use glob to find the DLL files.
for entry in glob(&full_pattern).expect("Failed to read glob pattern") {
match entry {
Ok(dll_path) => {
// Copy the DLL file to the output directory.
let dll_file_name = dll_path.file_name().unwrap();
let destination = Path::new(&out_dir).join(dll_file_name);
if !destination.exists() {
fs::copy(&dll_path, &destination)
.expect("Failed to copy DLL");
println!("Moved {} to {}", dll_file_name.to_string_lossy(), destination.to_string_lossy());
}

},
Err(e) => panic!("{}",e),
}

}
}
}


fn copy_opencl_dlls(){
//TODO
}
8 changes: 0 additions & 8 deletions apps/desktop/src-tauri/tauri.windows.conf.json

This file was deleted.