Skip to content

Commit

Permalink
Build library/profiler_builtins from ci-llvm if appropriate
Browse files Browse the repository at this point in the history
  • Loading branch information
Zalathar committed Aug 23, 2024
1 parent 585804f commit a1d2971
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 16 deletions.
12 changes: 8 additions & 4 deletions library/profiler_builtins/build.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
//! See the build.rs for libcompiler_builtins crate for details.
use std::env;
use std::path::Path;
use std::path::PathBuf;

fn main() {
println!("cargo:rerun-if-env-changed=LLVM_PROFILER_RT_LIB");
Expand Down Expand Up @@ -79,9 +79,13 @@ fn main() {
cfg.define("COMPILER_RT_HAS_ATOMICS", Some("1"));
}

// Note that this should exist if we're going to run (otherwise we just
// don't build profiler builtins at all).
let root = Path::new("../../src/llvm-project/compiler-rt");
// Get the LLVM `compiler-rt` directory from bootstrap.
println!("cargo:rerun-if-env-changed=RUST_COMPILER_RT_FOR_PROFILER");
let root = PathBuf::from(env::var("RUST_COMPILER_RT_FOR_PROFILER").unwrap_or_else(|_| {
let path = "../../src/llvm-project/compiler-rt";
println!("RUST_COMPILER_RT_FOR_PROFILER was not set; falling back to {path:?}");
path.to_owned()
}));

let src_root = root.join("lib").join("profile");
assert!(src_root.exists(), "profiler runtime source directory not found: {src_root:?}");
Expand Down
31 changes: 19 additions & 12 deletions src/bootstrap/src/core/build_steps/compile.rs
Original file line number Diff line number Diff line change
Expand Up @@ -199,16 +199,6 @@ impl Step for Std {

builder.require_submodule("library/stdarch", None);

// Profiler information requires LLVM's compiler-rt
if builder.config.profiler {
builder.require_submodule(
"src/llvm-project",
Some(
"The `build.profiler` config option requires `compiler-rt` sources from LLVM.",
),
);
}

let mut target_deps = builder.ensure(StartupObjects { compiler, target });

let compiler_to_use = builder.compiler_for(compiler.stage, compiler.host, target);
Expand Down Expand Up @@ -473,8 +463,25 @@ pub fn std_cargo(builder: &Builder<'_>, target: TargetSelection, stage: u32, car
cargo.env("MACOSX_DEPLOYMENT_TARGET", target);
}

// Paths needed by `library/profiler_builtins/build.rs`.
if let Some(path) = builder.config.profiler_path(target) {
cargo.env("LLVM_PROFILER_RT_LIB", path);
} else if builder.config.profiler_enabled(target) {
let compiler_rt = if builder.config.llvm_from_ci {
// There's a copy of `compiler-rt` in the CI LLVM tarball,
// so we don't need to check out the LLVM submodule.
builder.config.ci_llvm_root().join("compiler-rt")
} else {
builder.require_submodule("src/llvm-project", {
Some("The `build.profiler` config option requires `compiler-rt` sources from LLVM.")
});
builder.src.join("src/llvm-project/compiler-rt")
};
assert!(compiler_rt.exists(), "compiler-rt directory not found: {compiler_rt:?}");
// Currently this is separate from the env var used by `compiler_builtins`
// (below) so that adding support for CI LLVM here doesn't risk breaking
// the compiler builtins. But they could be unified if desired.
cargo.env("RUST_COMPILER_RT_FOR_PROFILER", compiler_rt);
}

// Determine if we're going to compile in optimized C intrinsics to
Expand Down Expand Up @@ -507,8 +514,8 @@ pub fn std_cargo(builder: &Builder<'_>, target: TargetSelection, stage: u32, car
);
let compiler_builtins_root = builder.src.join("src/llvm-project/compiler-rt");
assert!(compiler_builtins_root.exists());
// Note that `libprofiler_builtins/build.rs` also computes this so if
// you're changing something here please also change that.
// The path to `compiler-rt` is also used by `profiler_builtins` (above),
// so if you're changing something here please also change that as appropriate.
cargo.env("RUST_COMPILER_RT_ROOT", &compiler_builtins_root);
" compiler-builtins-c"
} else {
Expand Down

0 comments on commit a1d2971

Please sign in to comment.