| 
									
										
										
										
											2019-03-02 08:58:17 -08:00
										 |  |  | use std::env;
 | 
					
						
							|  |  |  | use std::fs;
 | 
					
						
							|  |  |  | use std::path::Path;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | fn main() {
 | 
					
						
							|  |  |  |     println!("cargo:rerun-if-changed=build.rs");
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let perf_libs_dir = {
 | 
					
						
							|  |  |  |         let manifest_dir = env::var("CARGO_MANIFEST_DIR").unwrap();
 | 
					
						
							|  |  |  |         let mut path = Path::new(&manifest_dir);
 | 
					
						
							|  |  |  |         path = path.parent().unwrap();
 | 
					
						
							|  |  |  |         path.join(Path::new("target/perf-libs"))
 | 
					
						
							|  |  |  |     };
 | 
					
						
							|  |  |  |     let perf_libs_dir = perf_libs_dir.to_str().unwrap();
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     let chacha = !env::var("CARGO_FEATURE_CHACHA").is_err();
 | 
					
						
							|  |  |  |     let cuda = !env::var("CARGO_FEATURE_CUDA").is_err();
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-18 21:56:43 -07:00
										 |  |  |     if chacha || cuda {
 | 
					
						
							| 
									
										
										
										
											2019-06-04 08:51:20 -07:00
										 |  |  |         // Ensure `perf_libs_dir` exists.  It's been observed that
 | 
					
						
							|  |  |  |         // a cargo:rerun-if-changed= directive with a non-existent
 | 
					
						
							|  |  |  |         // directory triggers a rebuild on every |cargo build| invocation
 | 
					
						
							|  |  |  |         fs::create_dir_all(&perf_libs_dir).unwrap_or_else(|err| {
 | 
					
						
							|  |  |  |             if err.kind() != std::io::ErrorKind::AlreadyExists {
 | 
					
						
							|  |  |  |                 panic!("Unable to create {}: {:?}", perf_libs_dir, err);
 | 
					
						
							|  |  |  |             }
 | 
					
						
							|  |  |  |         });
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-02 08:58:17 -08:00
										 |  |  |         println!("cargo:rerun-if-changed={}", perf_libs_dir);
 | 
					
						
							|  |  |  |         println!("cargo:rustc-link-search=native={}", perf_libs_dir);
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  |     if chacha {
 | 
					
						
							|  |  |  |         println!("cargo:rerun-if-changed={}/libcpu-crypt.a", perf_libs_dir);
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  |     if cuda {
 | 
					
						
							|  |  |  |         let cuda_home = match env::var("CUDA_HOME") {
 | 
					
						
							|  |  |  |             Ok(cuda_home) => cuda_home,
 | 
					
						
							|  |  |  |             Err(_) => String::from("/usr/local/cuda"),
 | 
					
						
							|  |  |  |         };
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         println!("cargo:rerun-if-changed={}/libcuda-crypt.a", perf_libs_dir);
 | 
					
						
							|  |  |  |         println!("cargo:rustc-link-lib=static=cuda-crypt");
 | 
					
						
							|  |  |  |         println!("cargo:rustc-link-search=native={}/lib64", cuda_home);
 | 
					
						
							|  |  |  |         println!("cargo:rustc-link-lib=dylib=cudart");
 | 
					
						
							|  |  |  |         println!("cargo:rustc-link-lib=dylib=cuda");
 | 
					
						
							|  |  |  |         println!("cargo:rustc-link-lib=dylib=cudadevrt");
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | }
 |