Rollup merge of #122248 - jieyouxu:rmake-sysroot, r=Mark-Simulacrum

Respect stage0 sysroot when compiling rmake.rs with COMPILETEST_FORCE_STAGE0

Context: <https://rust-lang.zulipchat.com/#narrow/stream/326414-t-infra.2Fbootstrap/topic/stage0.20compiletest.20broken>.
> cg_clif uses `COMPILETEST_FORCE_STAGE0=1 ./x.py test --stage 0` for running the rustc test suite. With the introduction of rmake.rs this broke. `librun_make_support.rlib` is compiled using the bootstrap rustc wrapper which sets `--sysroot build/aarch64-unknown-linux-gnu/stage0-sysroot`, but then compiletest will compile `rmake.rs` using the sysroot of the bootstrap compiler causing it to not find the `libstd.rlib` against which `librun_make_support.rlib` is compiled.

cc ``@bjorn3``

Fixes #122196.
This commit is contained in:
Matthias Krüger 2024-03-17 08:23:25 +01:00 committed by GitHub
commit a5dbdc2fa9
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -3734,36 +3734,42 @@ fn run_rmake_v2_test(&self) {
debug!(?support_lib_deps); debug!(?support_lib_deps);
debug!(?support_lib_deps_deps); debug!(?support_lib_deps_deps);
let res = self.cmd2procres( let mut cmd = Command::new(&self.config.rustc_path);
Command::new(&self.config.rustc_path) cmd.arg("-o")
.arg("-o") .arg(&recipe_bin)
.arg(&recipe_bin) .arg(format!("-Ldependency={}", &support_lib_path.parent().unwrap().to_string_lossy()))
.arg(format!( .arg(format!("-Ldependency={}", &support_lib_deps.to_string_lossy()))
"-Ldependency={}", .arg(format!("-Ldependency={}", &support_lib_deps_deps.to_string_lossy()))
&support_lib_path.parent().unwrap().to_string_lossy() .arg("--extern")
)) .arg(format!("run_make_support={}", &support_lib_path.to_string_lossy()))
.arg(format!("-Ldependency={}", &support_lib_deps.to_string_lossy())) .arg(&self.testpaths.file.join("rmake.rs"))
.arg(format!("-Ldependency={}", &support_lib_deps_deps.to_string_lossy())) .env("TARGET", &self.config.target)
.arg("--extern") .env("PYTHON", &self.config.python)
.arg(format!("run_make_support={}", &support_lib_path.to_string_lossy())) .env("S", &src_root)
.arg(&self.testpaths.file.join("rmake.rs")) .env("RUST_BUILD_STAGE", &self.config.stage_id)
.env("TARGET", &self.config.target) .env("RUSTC", cwd.join(&self.config.rustc_path))
.env("PYTHON", &self.config.python) .env("TMPDIR", &tmpdir)
.env("S", &src_root) .env("LD_LIB_PATH_ENVVAR", dylib_env_var())
.env("RUST_BUILD_STAGE", &self.config.stage_id) .env("HOST_RPATH_DIR", cwd.join(&self.config.compile_lib_path))
.env("RUSTC", cwd.join(&self.config.rustc_path)) .env("TARGET_RPATH_DIR", cwd.join(&self.config.run_lib_path))
.env("TMPDIR", &tmpdir) .env("LLVM_COMPONENTS", &self.config.llvm_components)
.env("LD_LIB_PATH_ENVVAR", dylib_env_var()) // We for sure don't want these tests to run in parallel, so make
.env("HOST_RPATH_DIR", cwd.join(&self.config.compile_lib_path)) // sure they don't have access to these vars if we run via `make`
.env("TARGET_RPATH_DIR", cwd.join(&self.config.run_lib_path)) // at the top level
.env("LLVM_COMPONENTS", &self.config.llvm_components) .env_remove("MAKEFLAGS")
// We for sure don't want these tests to run in parallel, so make .env_remove("MFLAGS")
// sure they don't have access to these vars if we run via `make` .env_remove("CARGO_MAKEFLAGS");
// at the top level
.env_remove("MAKEFLAGS") if std::env::var_os("COMPILETEST_FORCE_STAGE0").is_some() {
.env_remove("MFLAGS") let mut stage0_sysroot = build_root.clone();
.env_remove("CARGO_MAKEFLAGS"), stage0_sysroot.push("stage0-sysroot");
); debug!(?stage0_sysroot);
debug!(exists = stage0_sysroot.exists());
cmd.arg("--sysroot").arg(&stage0_sysroot);
}
let res = self.cmd2procres(&mut cmd);
if !res.status.success() { if !res.status.success() {
self.fatal_proc_rec("run-make test failed: could not build `rmake.rs` recipe", &res); self.fatal_proc_rec("run-make test failed: could not build `rmake.rs` recipe", &res);
} }