Benchmark clif release builds with ./y.rs bench
This commit is contained in:
parent
88ae8fc9c8
commit
a43f08363e
@ -1,11 +1,10 @@
|
|||||||
use std::env;
|
use std::env;
|
||||||
use std::fs;
|
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
|
|
||||||
use super::path::{Dirs, RelPath};
|
use super::path::{Dirs, RelPath};
|
||||||
use super::prepare::GitRepo;
|
use super::prepare::GitRepo;
|
||||||
use super::rustc_info::get_file_name;
|
use super::rustc_info::get_file_name;
|
||||||
use super::utils::{hyperfine_command, spawn_and_wait, CargoProject, Compiler};
|
use super::utils::{hyperfine_command, spawn_and_wait};
|
||||||
|
|
||||||
static SIMPLE_RAYTRACER_REPO: GitRepo = GitRepo::github(
|
static SIMPLE_RAYTRACER_REPO: GitRepo = GitRepo::github(
|
||||||
"ebobby",
|
"ebobby",
|
||||||
@ -14,18 +13,11 @@
|
|||||||
"<none>",
|
"<none>",
|
||||||
);
|
);
|
||||||
|
|
||||||
// Use a separate target dir for the initial LLVM build to reduce unnecessary recompiles
|
pub(crate) fn benchmark(dirs: &Dirs) {
|
||||||
static SIMPLE_RAYTRACER_LLVM: CargoProject =
|
benchmark_simple_raytracer(dirs);
|
||||||
CargoProject::new(&SIMPLE_RAYTRACER_REPO.source_dir(), "simple_raytracer_llvm");
|
|
||||||
|
|
||||||
static SIMPLE_RAYTRACER: CargoProject =
|
|
||||||
CargoProject::new(&SIMPLE_RAYTRACER_REPO.source_dir(), "simple_raytracer");
|
|
||||||
|
|
||||||
pub(crate) fn benchmark(dirs: &Dirs, bootstrap_host_compiler: &Compiler) {
|
|
||||||
benchmark_simple_raytracer(dirs, bootstrap_host_compiler);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn benchmark_simple_raytracer(dirs: &Dirs, bootstrap_host_compiler: &Compiler) {
|
fn benchmark_simple_raytracer(dirs: &Dirs) {
|
||||||
if std::process::Command::new("hyperfine").output().is_err() {
|
if std::process::Command::new("hyperfine").output().is_err() {
|
||||||
eprintln!("Hyperfine not installed");
|
eprintln!("Hyperfine not installed");
|
||||||
eprintln!("Hint: Try `cargo install hyperfine` to install hyperfine");
|
eprintln!("Hint: Try `cargo install hyperfine` to install hyperfine");
|
||||||
@ -34,33 +26,15 @@ fn benchmark_simple_raytracer(dirs: &Dirs, bootstrap_host_compiler: &Compiler) {
|
|||||||
|
|
||||||
if !SIMPLE_RAYTRACER_REPO.source_dir().to_path(dirs).exists() {
|
if !SIMPLE_RAYTRACER_REPO.source_dir().to_path(dirs).exists() {
|
||||||
SIMPLE_RAYTRACER_REPO.fetch(dirs);
|
SIMPLE_RAYTRACER_REPO.fetch(dirs);
|
||||||
spawn_and_wait(SIMPLE_RAYTRACER.fetch(
|
|
||||||
&bootstrap_host_compiler.cargo,
|
|
||||||
&bootstrap_host_compiler.rustc,
|
|
||||||
dirs,
|
|
||||||
));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
eprintln!("[LLVM BUILD] simple-raytracer");
|
|
||||||
let build_cmd = SIMPLE_RAYTRACER_LLVM.build(bootstrap_host_compiler, dirs);
|
|
||||||
spawn_and_wait(build_cmd);
|
|
||||||
fs::copy(
|
|
||||||
SIMPLE_RAYTRACER_LLVM
|
|
||||||
.target_dir(dirs)
|
|
||||||
.join(&bootstrap_host_compiler.triple)
|
|
||||||
.join("debug")
|
|
||||||
.join(get_file_name("main", "bin")),
|
|
||||||
RelPath::BUILD.to_path(dirs).join(get_file_name("raytracer_cg_llvm", "bin")),
|
|
||||||
)
|
|
||||||
.unwrap();
|
|
||||||
|
|
||||||
let bench_runs = env::var("BENCH_RUNS").unwrap_or_else(|_| "10".to_string()).parse().unwrap();
|
let bench_runs = env::var("BENCH_RUNS").unwrap_or_else(|_| "10".to_string()).parse().unwrap();
|
||||||
|
|
||||||
eprintln!("[BENCH COMPILE] ebobby/simple-raytracer");
|
eprintln!("[BENCH COMPILE] ebobby/simple-raytracer");
|
||||||
let cargo_clif =
|
let cargo_clif =
|
||||||
RelPath::DIST.to_path(dirs).join(get_file_name("cargo_clif", "bin").replace('_', "-"));
|
RelPath::DIST.to_path(dirs).join(get_file_name("cargo_clif", "bin").replace('_', "-"));
|
||||||
let manifest_path = SIMPLE_RAYTRACER.manifest_path(dirs);
|
let manifest_path = SIMPLE_RAYTRACER_REPO.source_dir().to_path(dirs).join("Cargo.toml");
|
||||||
let target_dir = SIMPLE_RAYTRACER.target_dir(dirs);
|
let target_dir = RelPath::BUILD.join("simple_raytracer").to_path(dirs);
|
||||||
|
|
||||||
let clean_cmd = format!(
|
let clean_cmd = format!(
|
||||||
"RUSTC=rustc cargo clean --manifest-path {manifest_path} --target-dir {target_dir}",
|
"RUSTC=rustc cargo clean --manifest-path {manifest_path} --target-dir {target_dir}",
|
||||||
@ -68,28 +42,33 @@ fn benchmark_simple_raytracer(dirs: &Dirs, bootstrap_host_compiler: &Compiler) {
|
|||||||
target_dir = target_dir.display(),
|
target_dir = target_dir.display(),
|
||||||
);
|
);
|
||||||
let llvm_build_cmd = format!(
|
let llvm_build_cmd = format!(
|
||||||
"RUSTC=rustc cargo build --manifest-path {manifest_path} --target-dir {target_dir}",
|
"RUSTC=rustc cargo build --manifest-path {manifest_path} --target-dir {target_dir} && (rm build/raytracer_cg_llvm || true) && ln build/simple_raytracer/debug/main build/raytracer_cg_llvm",
|
||||||
manifest_path = manifest_path.display(),
|
manifest_path = manifest_path.display(),
|
||||||
target_dir = target_dir.display(),
|
target_dir = target_dir.display(),
|
||||||
);
|
);
|
||||||
let clif_build_cmd = format!(
|
let clif_build_cmd = format!(
|
||||||
"RUSTC=rustc {cargo_clif} build --manifest-path {manifest_path} --target-dir {target_dir}",
|
"RUSTC=rustc {cargo_clif} build --manifest-path {manifest_path} --target-dir {target_dir} && (rm build/raytracer_cg_clif || true) && ln build/simple_raytracer/debug/main build/raytracer_cg_clif",
|
||||||
|
cargo_clif = cargo_clif.display(),
|
||||||
|
manifest_path = manifest_path.display(),
|
||||||
|
target_dir = target_dir.display(),
|
||||||
|
);
|
||||||
|
let clif_build_opt_cmd = format!(
|
||||||
|
"RUSTC=rustc {cargo_clif} build --manifest-path {manifest_path} --target-dir {target_dir} --release && (rm build/raytracer_cg_clif_opt || true) && ln build/simple_raytracer/release/main build/raytracer_cg_clif_opt",
|
||||||
cargo_clif = cargo_clif.display(),
|
cargo_clif = cargo_clif.display(),
|
||||||
manifest_path = manifest_path.display(),
|
manifest_path = manifest_path.display(),
|
||||||
target_dir = target_dir.display(),
|
target_dir = target_dir.display(),
|
||||||
);
|
);
|
||||||
|
|
||||||
let bench_compile =
|
let bench_compile = hyperfine_command(
|
||||||
hyperfine_command(1, bench_runs, Some(&clean_cmd), &[&llvm_build_cmd, &clif_build_cmd]);
|
1,
|
||||||
|
bench_runs,
|
||||||
|
Some(&clean_cmd),
|
||||||
|
&[&llvm_build_cmd, &clif_build_cmd, &clif_build_opt_cmd],
|
||||||
|
);
|
||||||
|
|
||||||
spawn_and_wait(bench_compile);
|
spawn_and_wait(bench_compile);
|
||||||
|
|
||||||
eprintln!("[BENCH RUN] ebobby/simple-raytracer");
|
eprintln!("[BENCH RUN] ebobby/simple-raytracer");
|
||||||
fs::copy(
|
|
||||||
target_dir.join("debug").join(get_file_name("main", "bin")),
|
|
||||||
RelPath::BUILD.to_path(dirs).join(get_file_name("raytracer_cg_clif", "bin")),
|
|
||||||
)
|
|
||||||
.unwrap();
|
|
||||||
|
|
||||||
let mut bench_run = hyperfine_command(
|
let mut bench_run = hyperfine_command(
|
||||||
0,
|
0,
|
||||||
@ -98,6 +77,7 @@ fn benchmark_simple_raytracer(dirs: &Dirs, bootstrap_host_compiler: &Compiler) {
|
|||||||
&[
|
&[
|
||||||
Path::new(".").join(get_file_name("raytracer_cg_llvm", "bin")).to_str().unwrap(),
|
Path::new(".").join(get_file_name("raytracer_cg_llvm", "bin")).to_str().unwrap(),
|
||||||
Path::new(".").join(get_file_name("raytracer_cg_clif", "bin")).to_str().unwrap(),
|
Path::new(".").join(get_file_name("raytracer_cg_clif", "bin")).to_str().unwrap(),
|
||||||
|
Path::new(".").join(get_file_name("raytracer_cg_clif_opt", "bin")).to_str().unwrap(),
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
bench_run.current_dir(RelPath::BUILD.to_path(dirs));
|
bench_run.current_dir(RelPath::BUILD.to_path(dirs));
|
||||||
|
@ -187,7 +187,7 @@ pub(crate) fn main() {
|
|||||||
&bootstrap_host_compiler,
|
&bootstrap_host_compiler,
|
||||||
target_triple,
|
target_triple,
|
||||||
);
|
);
|
||||||
bench::benchmark(&dirs, &bootstrap_host_compiler);
|
bench::benchmark(&dirs);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user