Merge pull request #291 from alexcrichton/fix-riscv

Don't compile C code on riscv targets
This commit is contained in:
Alex Crichton 2019-05-14 16:40:27 -05:00 committed by GitHub
commit ad1bcd2592
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -37,8 +37,15 @@ fn main() {
// build anything and we rely on the upstream implementation of compiler-rt // build anything and we rely on the upstream implementation of compiler-rt
// functions // functions
if !cfg!(feature = "mangled-names") && cfg!(feature = "c") { if !cfg!(feature = "mangled-names") && cfg!(feature = "c") {
// Don't use C compiler for bitcode-only wasm and nvptx // Don't use a C compiler for these targets:
if !target.contains("wasm32") && !target.contains("nvptx") { //
// * wasm32 - clang 8 for wasm is somewhat hard to come by and it's
// unlikely that the C is really that much better than our own Rust.
// * nvptx - everything is bitcode, not compatible with mixed C/Rust
// * riscv - the rust-lang/rust distribution container doesn't have a C
// compiler nor is cc-rs ready for compilation to riscv (at this
// time). This can probably be removed in the future
if !target.contains("wasm32") && !target.contains("nvptx") && !target.starts_with("riscv") {
#[cfg(feature = "c")] #[cfg(feature = "c")]
c::compile(&llvm_target); c::compile(&llvm_target);
println!("cargo:rustc-cfg=use_c"); println!("cargo:rustc-cfg=use_c");