rustbuild: allow overriding list of LLVM targets to build
A new option is introduced under the `[llvm]` section of `config.toml`, `targets`, for overriding the list of LLVM targets to build support for. The option is passed through to LLVM configure script. Also notes are added about the implications of (ab)using the option; since the default is not changed, and users of the option are expected to know what they're doing anyway (as every porter should), the impact should be minimal. Fixes #38200.
This commit is contained in:
parent
371f4d6bf6
commit
0f8e931475
3 changed files with 21 additions and 2 deletions
|
@ -54,6 +54,7 @@ pub struct Config {
|
||||||
pub llvm_version_check: bool,
|
pub llvm_version_check: bool,
|
||||||
pub llvm_static_stdcpp: bool,
|
pub llvm_static_stdcpp: bool,
|
||||||
pub llvm_link_shared: bool,
|
pub llvm_link_shared: bool,
|
||||||
|
pub llvm_targets: Option<String>,
|
||||||
|
|
||||||
// rust codegen options
|
// rust codegen options
|
||||||
pub rust_optimize: bool,
|
pub rust_optimize: bool,
|
||||||
|
@ -152,6 +153,7 @@ struct Llvm {
|
||||||
release_debuginfo: Option<bool>,
|
release_debuginfo: Option<bool>,
|
||||||
version_check: Option<bool>,
|
version_check: Option<bool>,
|
||||||
static_libstdcpp: Option<bool>,
|
static_libstdcpp: Option<bool>,
|
||||||
|
targets: Option<String>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(RustcDecodable)]
|
#[derive(RustcDecodable)]
|
||||||
|
@ -285,6 +287,7 @@ impl Config {
|
||||||
set(&mut config.llvm_release_debuginfo, llvm.release_debuginfo);
|
set(&mut config.llvm_release_debuginfo, llvm.release_debuginfo);
|
||||||
set(&mut config.llvm_version_check, llvm.version_check);
|
set(&mut config.llvm_version_check, llvm.version_check);
|
||||||
set(&mut config.llvm_static_stdcpp, llvm.static_libstdcpp);
|
set(&mut config.llvm_static_stdcpp, llvm.static_libstdcpp);
|
||||||
|
config.llvm_targets = llvm.targets.clone();
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(ref rust) = toml.rust {
|
if let Some(ref rust) = toml.rust {
|
||||||
|
|
|
@ -42,6 +42,17 @@
|
||||||
# example.
|
# example.
|
||||||
#ninja = false
|
#ninja = false
|
||||||
|
|
||||||
|
# LLVM targets to build support for.
|
||||||
|
# Note: this is NOT related to Rust compilation targets. However, as Rust is
|
||||||
|
# dependent on LLVM for code generation, turning targets off here WILL lead to
|
||||||
|
# the resulting rustc being unable to compile for the disabled architectures.
|
||||||
|
# Also worth pointing out is that, in case support for new targets are added to
|
||||||
|
# LLVM, enabling them here doesn't mean Rust is automatically gaining said
|
||||||
|
# support. You'll need to write a target specification at least, and most
|
||||||
|
# likely, teach rustc about the C ABI of the target. Get in touch with the
|
||||||
|
# Rust team and file an issue if you need assistance in porting!
|
||||||
|
#targets = "X86;ARM;AArch64;Mips;PowerPC;SystemZ;JSBackend;MSP430;Sparc"
|
||||||
|
|
||||||
# =============================================================================
|
# =============================================================================
|
||||||
# General build configuration options
|
# General build configuration options
|
||||||
# =============================================================================
|
# =============================================================================
|
||||||
|
|
|
@ -75,13 +75,18 @@ pub fn llvm(build: &Build, target: &str) {
|
||||||
(true, true) => "RelWithDebInfo",
|
(true, true) => "RelWithDebInfo",
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// NOTE: remember to also update `config.toml.example` when changing the defaults!
|
||||||
|
let llvm_targets = match build.config.llvm_targets {
|
||||||
|
Some(ref s) => s,
|
||||||
|
None => "X86;ARM;AArch64;Mips;PowerPC;SystemZ;JSBackend;MSP430;Sparc",
|
||||||
|
};
|
||||||
|
|
||||||
cfg.target(target)
|
cfg.target(target)
|
||||||
.host(&build.config.build)
|
.host(&build.config.build)
|
||||||
.out_dir(&dst)
|
.out_dir(&dst)
|
||||||
.profile(profile)
|
.profile(profile)
|
||||||
.define("LLVM_ENABLE_ASSERTIONS", assertions)
|
.define("LLVM_ENABLE_ASSERTIONS", assertions)
|
||||||
.define("LLVM_TARGETS_TO_BUILD",
|
.define("LLVM_TARGETS_TO_BUILD", llvm_targets)
|
||||||
"X86;ARM;AArch64;Mips;PowerPC;SystemZ;JSBackend;MSP430;Sparc")
|
|
||||||
.define("LLVM_INCLUDE_EXAMPLES", "OFF")
|
.define("LLVM_INCLUDE_EXAMPLES", "OFF")
|
||||||
.define("LLVM_INCLUDE_TESTS", "OFF")
|
.define("LLVM_INCLUDE_TESTS", "OFF")
|
||||||
.define("LLVM_INCLUDE_DOCS", "OFF")
|
.define("LLVM_INCLUDE_DOCS", "OFF")
|
||||||
|
|
Loading…
Add table
Reference in a new issue