-
Notifications
You must be signed in to change notification settings - Fork 12.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Auto merge of #95170 - jyn514:ci-llvm, r=Mark-Simulacrum
Move `download-ci-llvm` out of bootstrap.py This is ready for review. It has been tested on Windows, Linux, and NixOS. The second commit ports the changes from #95234 to Rust; I can remove it if desired. Helps with #94829. As a follow-up, this makes it possible to avoid downloading llvm until it's needed for building `rustc_llvm`; it would be nice to do that, but it shouldn't go in the first draft. It might also be possible to avoid requiring python until tests run (currently there's a check in `sanity.rs`), but I haven't looked too much into that. `@rustbot` label +A-rustbuild
- Loading branch information
Showing
10 changed files
with
369 additions
and
184 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -500,81 +500,6 @@ def download_toolchain(self, stage0=True, rustc_channel=None): | |
with output(self.rustfmt_stamp()) as rustfmt_stamp: | ||
rustfmt_stamp.write(self.stage0_rustfmt.channel()) | ||
|
||
# Avoid downloading LLVM twice (once for stage0 and once for the master rustc) | ||
if self.downloading_llvm() and stage0: | ||
# We want the most recent LLVM submodule update to avoid downloading | ||
# LLVM more often than necessary. | ||
# | ||
# This git command finds that commit SHA, looking for bors-authored | ||
# commits that modified src/llvm-project or other relevant version | ||
# stamp files. | ||
# | ||
# This works even in a repository that has not yet initialized | ||
# submodules. | ||
top_level = subprocess.check_output([ | ||
"git", "rev-parse", "--show-toplevel", | ||
]).decode(sys.getdefaultencoding()).strip() | ||
llvm_sha = subprocess.check_output([ | ||
"git", "rev-list", "[email protected]", "-n1", | ||
"--first-parent", "HEAD", | ||
"--", | ||
"{}/src/llvm-project".format(top_level), | ||
"{}/src/bootstrap/download-ci-llvm-stamp".format(top_level), | ||
# the LLVM shared object file is named `LLVM-12-rust-{version}-nightly` | ||
"{}/src/version".format(top_level) | ||
]).decode(sys.getdefaultencoding()).strip() | ||
llvm_assertions = self.get_toml('assertions', 'llvm') == 'true' | ||
llvm_root = self.llvm_root() | ||
llvm_lib = os.path.join(llvm_root, "lib") | ||
if self.program_out_of_date(self.llvm_stamp(), llvm_sha + str(llvm_assertions)): | ||
self._download_ci_llvm(llvm_sha, llvm_assertions) | ||
for binary in ["llvm-config", "FileCheck"]: | ||
self.fix_bin_or_dylib(os.path.join(llvm_root, "bin", binary)) | ||
for lib in os.listdir(llvm_lib): | ||
if lib.endswith(".so"): | ||
self.fix_bin_or_dylib(os.path.join(llvm_lib, lib)) | ||
with output(self.llvm_stamp()) as llvm_stamp: | ||
llvm_stamp.write(llvm_sha + str(llvm_assertions)) | ||
|
||
def downloading_llvm(self): | ||
opt = self.get_toml('download-ci-llvm', 'llvm') | ||
# This is currently all tier 1 targets and tier 2 targets with host tools | ||
# (since others may not have CI artifacts) | ||
# https://doc.rust-lang.org/rustc/platform-support.html#tier-1 | ||
supported_platforms = [ | ||
# tier 1 | ||
"aarch64-unknown-linux-gnu", | ||
"i686-pc-windows-gnu", | ||
"i686-pc-windows-msvc", | ||
"i686-unknown-linux-gnu", | ||
"x86_64-unknown-linux-gnu", | ||
"x86_64-apple-darwin", | ||
"x86_64-pc-windows-gnu", | ||
"x86_64-pc-windows-msvc", | ||
# tier 2 with host tools | ||
"aarch64-apple-darwin", | ||
"aarch64-pc-windows-msvc", | ||
"aarch64-unknown-linux-musl", | ||
"arm-unknown-linux-gnueabi", | ||
"arm-unknown-linux-gnueabihf", | ||
"armv7-unknown-linux-gnueabihf", | ||
"mips-unknown-linux-gnu", | ||
"mips64-unknown-linux-gnuabi64", | ||
"mips64el-unknown-linux-gnuabi64", | ||
"mipsel-unknown-linux-gnu", | ||
"powerpc-unknown-linux-gnu", | ||
"powerpc64-unknown-linux-gnu", | ||
"powerpc64le-unknown-linux-gnu", | ||
"riscv64gc-unknown-linux-gnu", | ||
"s390x-unknown-linux-gnu", | ||
"x86_64-unknown-freebsd", | ||
"x86_64-unknown-illumos", | ||
"x86_64-unknown-linux-musl", | ||
"x86_64-unknown-netbsd", | ||
] | ||
return opt == "true" \ | ||
or (opt == "if-available" and self.build in supported_platforms) | ||
|
||
def _download_component_helper( | ||
self, filename, pattern, tarball_suffix, stage0=True, key=None | ||
): | ||
|
@@ -606,53 +531,6 @@ def _download_component_helper( | |
) | ||
unpack(tarball, tarball_suffix, self.bin_root(stage0), match=pattern, verbose=self.verbose) | ||
|
||
def _download_ci_llvm(self, llvm_sha, llvm_assertions): | ||
if not llvm_sha: | ||
print("error: could not find commit hash for downloading LLVM") | ||
print("help: maybe your repository history is too shallow?") | ||
print("help: consider disabling `download-ci-llvm`") | ||
print("help: or fetch enough history to include one upstream commit") | ||
exit(1) | ||
cache_prefix = "llvm-{}-{}".format(llvm_sha, llvm_assertions) | ||
cache_dst = os.path.join(self.build_dir, "cache") | ||
rustc_cache = os.path.join(cache_dst, cache_prefix) | ||
if not os.path.exists(rustc_cache): | ||
os.makedirs(rustc_cache) | ||
|
||
base = "https://ci-artifacts.rust-lang.org" | ||
url = "rustc-builds/{}".format(llvm_sha) | ||
if llvm_assertions: | ||
url = url.replace('rustc-builds', 'rustc-builds-alt') | ||
# ci-artifacts are only stored as .xz, not .gz | ||
if not support_xz(): | ||
print("error: XZ support is required to download LLVM") | ||
print("help: consider disabling `download-ci-llvm` or using python3") | ||
exit(1) | ||
tarball_suffix = '.tar.xz' | ||
filename = "rust-dev-nightly-" + self.build + tarball_suffix | ||
tarball = os.path.join(rustc_cache, filename) | ||
if not os.path.exists(tarball): | ||
help_on_error = "error: failed to download llvm from ci" | ||
help_on_error += "\nhelp: old builds get deleted after a certain time" | ||
help_on_error += "\nhelp: if trying to compile an old commit of rustc," | ||
help_on_error += " disable `download-ci-llvm` in config.toml:" | ||
help_on_error += "\n" | ||
help_on_error += "\n[llvm]" | ||
help_on_error += "\ndownload-ci-llvm = false" | ||
help_on_error += "\n" | ||
get( | ||
base, | ||
"{}/{}".format(url, filename), | ||
tarball, | ||
self.checksums_sha256, | ||
verbose=self.verbose, | ||
do_verify=False, | ||
help_on_error=help_on_error, | ||
) | ||
unpack(tarball, tarball_suffix, self.llvm_root(), | ||
match="rust-dev", | ||
verbose=self.verbose) | ||
|
||
def fix_bin_or_dylib(self, fname): | ||
"""Modifies the interpreter section of 'fname' to fix the dynamic linker, | ||
or the RPATH section, to fix the dynamic library search path | ||
|
@@ -816,17 +694,6 @@ def rustfmt_stamp(self): | |
""" | ||
return os.path.join(self.bin_root(True), '.rustfmt-stamp') | ||
|
||
def llvm_stamp(self): | ||
"""Return the path for .llvm-stamp | ||
>>> rb = RustBuild() | ||
>>> rb.build_dir = "build" | ||
>>> rb.llvm_stamp() == os.path.join("build", "ci-llvm", ".llvm-stamp") | ||
True | ||
""" | ||
return os.path.join(self.llvm_root(), '.llvm-stamp') | ||
|
||
|
||
def program_out_of_date(self, stamp_path, key): | ||
"""Check if the given program stamp is out of date""" | ||
if not os.path.exists(stamp_path) or self.clean: | ||
|
@@ -856,22 +723,6 @@ def bin_root(self, stage0): | |
subdir = "ci-rustc" | ||
return os.path.join(self.build_dir, self.build, subdir) | ||
|
||
def llvm_root(self): | ||
"""Return the CI LLVM root directory | ||
>>> rb = RustBuild() | ||
>>> rb.build_dir = "build" | ||
>>> rb.llvm_root() == os.path.join("build", "ci-llvm") | ||
True | ||
When the 'build' property is given should be a nested directory: | ||
>>> rb.build = "devel" | ||
>>> rb.llvm_root() == os.path.join("build", "devel", "ci-llvm") | ||
True | ||
""" | ||
return os.path.join(self.build_dir, self.build, "ci-llvm") | ||
|
||
def get_toml(self, key, section=None): | ||
"""Returns the value of the given key in config.toml, otherwise returns None | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.