rust: update to 1.53.0.
- rebase patches - fix type of 'llvm-unwind' in config.toml - move linux_musl_base stuff to a single patch which makes it behave just line linux_gnu_base - copy new version of need-ssp_nonshared.patch from alpine - temporary workaround for the new rust-llvm-dwp binary: it's copied from the llvm toolchain and shoved into /usr/lib, but they copied the binary from the build machine - fix do_check (thanks cinerea0) - preliminary ppcle patches (q66)
This commit is contained in:
parent
7e84f59fea
commit
af802e87d4
15 changed files with 937 additions and 266 deletions
|
@ -9,19 +9,19 @@ musl can't handle foreign-architecture libraries in LD_LIBRARY_PATH.
|
||||||
1 file changed, 2 insertions(+), 5 deletions(-)
|
1 file changed, 2 insertions(+), 5 deletions(-)
|
||||||
|
|
||||||
diff --git a/src/bootstrap/bin/rustdoc.rs b/src/bootstrap/bin/rustdoc.rs
|
diff --git a/src/bootstrap/bin/rustdoc.rs b/src/bootstrap/bin/rustdoc.rs
|
||||||
index 04345867..8156d5ec 100644
|
index cba17c8e6..45cbdd81b 100644
|
||||||
--- a/src/bootstrap/bin/rustdoc.rs
|
--- a/src/bootstrap/bin/rustdoc.rs
|
||||||
+++ b/src/bootstrap/bin/rustdoc.rs
|
+++ b/src/bootstrap/bin/rustdoc.rs
|
||||||
@@ -22,9 +22,6 @@ fn main() {
|
@@ -20,9 +20,6 @@ fn main() {
|
||||||
Err(_) => 0,
|
Err(_) => 0,
|
||||||
};
|
};
|
||||||
|
|
||||||
- let mut dylib_path = bootstrap::util::dylib_path();
|
- let mut dylib_path = bootstrap::util::dylib_path();
|
||||||
- dylib_path.insert(0, PathBuf::from(libdir.clone()));
|
- dylib_path.insert(0, PathBuf::from(libdir.clone()));
|
||||||
-
|
-
|
||||||
//FIXME(misdreavus): once stdsimd uses cfg(doc) instead of cfg(dox), remove the `--cfg dox`
|
|
||||||
//arguments here
|
|
||||||
let mut cmd = Command::new(rustdoc);
|
let mut cmd = Command::new(rustdoc);
|
||||||
|
cmd.args(&args)
|
||||||
|
.arg("--sysroot")
|
||||||
@@ -35,7 +32,7 @@ fn main() {
|
@@ -35,7 +32,7 @@ fn main() {
|
||||||
.arg("dox")
|
.arg("dox")
|
||||||
.arg("--sysroot")
|
.arg("--sysroot")
|
||||||
|
|
|
@ -15,21 +15,20 @@ Fixes #54243
|
||||||
src/librustc_codegen_ssa/back/link.rs | 18 ++++++++++++++----
|
src/librustc_codegen_ssa/back/link.rs | 18 ++++++++++++++----
|
||||||
1 file changed, 14 insertions(+), 4 deletions(-)
|
1 file changed, 14 insertions(+), 4 deletions(-)
|
||||||
|
|
||||||
diff --git a/src/librustc_codegen_ssa/back/link.rs b/src/librustc_codegen_ssa/back/link.rs
|
diff --git a/compiler/rustc_codegen_ssa/src/back/link.rs b/compiler/rustc_codegen_ssa/src/back/link.rs
|
||||||
index 0dd2f029..f22b4277 100644
|
index 8bc4e6442..52ff7a52e 100644
|
||||||
--- a/compiler/rustc_codegen_ssa/src/back/link.rs
|
--- a/compiler/rustc_codegen_ssa/src/back/link.rs
|
||||||
+++ b/compiler/rustc_codegen_ssa/src/back/link.rs
|
+++ b/compiler/rustc_codegen_ssa/src/back/link.rs
|
||||||
@@ -1964,9 +1964,7 @@
|
@@ -2081,8 +2081,7 @@ fn add_upstream_rust_crates<'a, B: ArchiveBuilder<'a>>(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
-// Link in all of our upstream crates' native dependencies. Remember that
|
-/// Link in all of our upstream crates' native dependencies. Remember that all of these upstream
|
||||||
-// all of these upstream native dependencies are all non-static
|
-/// native dependencies are all non-static dependencies. We've got two cases then:
|
||||||
-// dependencies. We've got two cases then:
|
+/// Link in all of our upstream crates' native dependencies. We have two cases:
|
||||||
+// Link in all of our upstream crates' native dependencies. We have two cases:
|
///
|
||||||
//
|
/// 1. The upstream crate is an rlib. In this case we *must* link in the native dependency because
|
||||||
// 1. The upstream crate is an rlib. In this case we *must* link in the
|
/// the rlib is just an archive.
|
||||||
// native dependency because the rlib is just an archive.
|
|
||||||
@@ -2015,7 +2013,19 @@
|
@@ -2015,7 +2013,19 @@
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -41,7 +40,7 @@ index 0dd2f029..f22b4277 100644
|
||||||
+ // an upstream rlib was originally linked against a native shared library.
|
+ // an upstream rlib was originally linked against a native shared library.
|
||||||
+ if crate_type == config::CrateType::Executable
|
+ if crate_type == config::CrateType::Executable
|
||||||
+ && sess.crt_static(Some(crate_type))
|
+ && sess.crt_static(Some(crate_type))
|
||||||
+ && !sess.target.target.options.crt_static_allows_dylibs
|
+ && !sess.target.options.crt_static_allows_dylibs
|
||||||
+ {
|
+ {
|
||||||
+ cmd.link_staticlib(name)
|
+ cmd.link_staticlib(name)
|
||||||
+ } else {
|
+ } else {
|
||||||
|
|
|
@ -1,42 +1,82 @@
|
||||||
From 4654172e942b5b9250aff70101d54bc880060073 Mon Sep 17 00:00:00 2001
|
diff --git a/compiler/rustc_target/src/spec/crt_objects.rs b/compiler/rustc_target/src/spec/crt_objects.rs
|
||||||
From: Samuel Holland <samuel@sholland.org>
|
index 2fc9ab29f..276736159 100644
|
||||||
Date: Sun, 3 May 2020 17:53:33 +0200
|
--- a/compiler/rustc_target/src/spec/crt_objects.rs
|
||||||
Subject: [PATCH 04/15] Remove -nostdlib and musl_root from musl targets
|
+++ b/compiler/rustc_target/src/spec/crt_objects.rs
|
||||||
|
@@ -62,28 +62,6 @@ pub(super) fn all(obj: &str) -> CrtObjects {
|
||||||
|
])
|
||||||
|
}
|
||||||
|
|
||||||
---
|
-pub(super) fn pre_musl_fallback() -> CrtObjects {
|
||||||
config.toml.example | 3 ---
|
- new(&[
|
||||||
src/bootstrap/cc_detect.rs | 25 ++----------------
|
- (LinkOutputKind::DynamicNoPicExe, &["crt1.o", "crti.o", "crtbegin.o"]),
|
||||||
src/bootstrap/compile.rs | 22 +---------------
|
- (LinkOutputKind::DynamicPicExe, &["Scrt1.o", "crti.o", "crtbeginS.o"]),
|
||||||
src/bootstrap/config.rs | 7 ------
|
- (LinkOutputKind::StaticNoPicExe, &["crt1.o", "crti.o", "crtbegin.o"]),
|
||||||
src/bootstrap/configure.py | 28 ---------------------
|
- (LinkOutputKind::StaticPicExe, &["rcrt1.o", "crti.o", "crtbeginS.o"]),
|
||||||
src/bootstrap/lib.rs | 10 --------
|
- (LinkOutputKind::DynamicDylib, &["crti.o", "crtbeginS.o"]),
|
||||||
src/bootstrap/sanity.rs | 22 ----------------
|
- (LinkOutputKind::StaticDylib, &["crti.o", "crtbeginS.o"]),
|
||||||
src/librustc_target/spec/linux_musl_base.rs | 16 ------------
|
- ])
|
||||||
8 files changed, 3 insertions(+), 130 deletions(-)
|
-}
|
||||||
|
-
|
||||||
|
-pub(super) fn post_musl_fallback() -> CrtObjects {
|
||||||
|
- new(&[
|
||||||
|
- (LinkOutputKind::DynamicNoPicExe, &["crtend.o", "crtn.o"]),
|
||||||
|
- (LinkOutputKind::DynamicPicExe, &["crtendS.o", "crtn.o"]),
|
||||||
|
- (LinkOutputKind::StaticNoPicExe, &["crtend.o", "crtn.o"]),
|
||||||
|
- (LinkOutputKind::StaticPicExe, &["crtendS.o", "crtn.o"]),
|
||||||
|
- (LinkOutputKind::DynamicDylib, &["crtendS.o", "crtn.o"]),
|
||||||
|
- (LinkOutputKind::StaticDylib, &["crtendS.o", "crtn.o"]),
|
||||||
|
- ])
|
||||||
|
-}
|
||||||
|
-
|
||||||
|
pub(super) fn pre_mingw_fallback() -> CrtObjects {
|
||||||
|
new(&[
|
||||||
|
(LinkOutputKind::DynamicNoPicExe, &["crt2.o", "rsbegin.o"]),
|
||||||
|
diff --git a/compiler/rustc_target/src/spec/linux_musl_base.rs b/compiler/rustc_target/src/spec/linux_musl_base.rs
|
||||||
|
index 5038a967d..b3c0e5bc4 100644
|
||||||
|
--- a/compiler/rustc_target/src/spec/linux_musl_base.rs
|
||||||
|
+++ b/compiler/rustc_target/src/spec/linux_musl_base.rs
|
||||||
|
@@ -1,16 +1,9 @@
|
||||||
|
-use crate::spec::crt_objects::{self, CrtObjectsFallback};
|
||||||
|
use crate::spec::TargetOptions;
|
||||||
|
|
||||||
|
pub fn opts() -> TargetOptions {
|
||||||
|
let mut base = super::linux_base::opts();
|
||||||
|
|
||||||
|
base.env = "musl".to_string();
|
||||||
|
- base.pre_link_objects_fallback = crt_objects::pre_musl_fallback();
|
||||||
|
- base.post_link_objects_fallback = crt_objects::post_musl_fallback();
|
||||||
|
- base.crt_objects_fallback = Some(CrtObjectsFallback::Musl);
|
||||||
|
-
|
||||||
|
- // These targets statically link libc by default
|
||||||
|
- base.crt_static_default = true;
|
||||||
|
|
||||||
|
base
|
||||||
|
}
|
||||||
|
diff --git a/config.toml.example b/config.toml.example
|
||||||
|
index 6e5584797..5be9882a8 100644
|
||||||
--- a/config.toml.example
|
--- a/config.toml.example
|
||||||
+++ b/config.toml.example
|
+++ b/config.toml.example
|
||||||
@@ -525,15 +525,6 @@
|
@@ -638,15 +638,6 @@ changelog-seen = 2
|
||||||
# only use static libraries. If unset, the target's default linkage is used.
|
# only use static libraries. If unset, the target's default linkage is used.
|
||||||
#crt-static = false
|
#crt-static = <platform-specific> (bool)
|
||||||
|
|
||||||
-# The root location of the musl installation directory. The library directory
|
-# The root location of the musl installation directory. The library directory
|
||||||
-# will also need to contain libunwind.a for an unwinding implementation. Note
|
-# will also need to contain libunwind.a for an unwinding implementation. Note
|
||||||
-# that this option only makes sense for musl targets that produce statically
|
-# that this option only makes sense for musl targets that produce statically
|
||||||
-# linked binaries
|
-# linked binaries.
|
||||||
-#musl-root = "..."
|
-#musl-root = build.musl-root (path)
|
||||||
-
|
-
|
||||||
-# The full path to the musl libdir.
|
-# The full path to the musl libdir.
|
||||||
-#musl-libdir = musl-root/lib
|
-#musl-libdir = musl-root/lib
|
||||||
-
|
-
|
||||||
# The root location of the `wasm32-wasi` sysroot.
|
# The root location of the `wasm32-wasi` sysroot. Only used for the
|
||||||
#wasi-root = "..."
|
# `wasm32-wasi` target. If you are building wasm32-wasi target, make sure to
|
||||||
|
# create a `[target.wasm32-wasi]` section and move this field there.
|
||||||
diff --git a/src/bootstrap/cc_detect.rs b/src/bootstrap/cc_detect.rs
|
diff --git a/src/bootstrap/cc_detect.rs b/src/bootstrap/cc_detect.rs
|
||||||
index a236edf9..54c3cc64 100644
|
index e750c2963..f6ba3032b 100644
|
||||||
--- a/src/bootstrap/cc_detect.rs
|
--- a/src/bootstrap/cc_detect.rs
|
||||||
+++ b/src/bootstrap/cc_detect.rs
|
+++ b/src/bootstrap/cc_detect.rs
|
||||||
@@ -97,7 +97,7 @@ pub fn find(build: &mut Build) {
|
@@ -98,7 +98,7 @@ pub fn find(build: &mut Build) {
|
||||||
if let Some(cc) = config.and_then(|c| c.cc.as_ref()) {
|
if let Some(cc) = config.and_then(|c| c.cc.as_ref()) {
|
||||||
cfg.compiler(cc);
|
cfg.compiler(cc);
|
||||||
} else {
|
} else {
|
||||||
|
@ -45,7 +85,7 @@ index a236edf9..54c3cc64 100644
|
||||||
}
|
}
|
||||||
|
|
||||||
let compiler = cfg.get_compiler();
|
let compiler = cfg.get_compiler();
|
||||||
@@ -125,7 +125,7 @@ pub fn find(build: &mut Build) {
|
@@ -126,7 +126,7 @@ pub fn find(build: &mut Build) {
|
||||||
cfg.compiler(cxx);
|
cfg.compiler(cxx);
|
||||||
true
|
true
|
||||||
} else if build.hosts.contains(&target) || build.build == target {
|
} else if build.hosts.contains(&target) || build.build == target {
|
||||||
|
@ -53,16 +93,16 @@ index a236edf9..54c3cc64 100644
|
||||||
+ set_compiler(&mut cfg, Language::CPlusPlus, target, config);
|
+ set_compiler(&mut cfg, Language::CPlusPlus, target, config);
|
||||||
true
|
true
|
||||||
} else {
|
} else {
|
||||||
false
|
// Use an auto-detected compiler (or one configured via `CXX_target_triple` env vars).
|
||||||
@@ -154,7 +154,6 @@ fn set_compiler(
|
@@ -157,7 +157,6 @@ fn set_compiler(
|
||||||
compiler: Language,
|
compiler: Language,
|
||||||
target: Interned<String>,
|
target: TargetSelection,
|
||||||
config: Option<&Target>,
|
config: Option<&Target>,
|
||||||
- build: &Build,
|
- build: &Build,
|
||||||
) {
|
) {
|
||||||
match &*target {
|
match &*target.triple {
|
||||||
// When compiling for android we may have the NDK configured in the
|
// When compiling for android we may have the NDK configured in the
|
||||||
@@ -196,26 +195,6 @@ fn set_compiler(
|
@@ -200,26 +199,6 @@ fn set_compiler(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -90,14 +130,13 @@ index a236edf9..54c3cc64 100644
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
diff --git a/src/bootstrap/compile.rs b/src/bootstrap/compile.rs
|
diff --git a/src/bootstrap/compile.rs b/src/bootstrap/compile.rs
|
||||||
index 65a00db3..01fd2cf3 100644
|
index ee3527b6b..0a8b78327 100644
|
||||||
--- a/src/bootstrap/compile.rs
|
--- a/src/bootstrap/compile.rs
|
||||||
+++ b/src/bootstrap/compile.rs
|
+++ b/src/bootstrap/compile.rs
|
||||||
@@ -169,26 +169,7 @@
|
@@ -179,34 +179,7 @@ fn copy_self_contained_objects(
|
||||||
t!(fs::create_dir_all(&libdir_self_contained));
|
|
||||||
let mut target_deps = vec![];
|
let mut target_deps = vec![];
|
||||||
|
|
||||||
- // Copies the CRT objects.
|
// Copies the CRT objects.
|
||||||
- //
|
- //
|
||||||
- // rustc historically provides a more self-contained installation for musl targets
|
- // rustc historically provides a more self-contained installation for musl targets
|
||||||
- // not requiring the presence of a native musl toolchain. For example, it can fall back
|
- // not requiring the presence of a native musl toolchain. For example, it can fall back
|
||||||
|
@ -105,7 +144,9 @@ index 65a00db3..01fd2cf3 100644
|
||||||
- // To do that we have to distribute musl startup objects as a part of Rust toolchain
|
- // To do that we have to distribute musl startup objects as a part of Rust toolchain
|
||||||
- // and link with them manually in the self-contained mode.
|
- // and link with them manually in the self-contained mode.
|
||||||
- if target.contains("musl") {
|
- if target.contains("musl") {
|
||||||
- let srcdir = builder.musl_libdir(target).unwrap();
|
- let srcdir = builder.musl_libdir(target).unwrap_or_else(|| {
|
||||||
|
- panic!("Target {:?} does not have a \"musl-libdir\" key", target.triple)
|
||||||
|
- });
|
||||||
- for &obj in &["crt1.o", "Scrt1.o", "rcrt1.o", "crti.o", "crtn.o"] {
|
- for &obj in &["crt1.o", "Scrt1.o", "rcrt1.o", "crti.o", "crtn.o"] {
|
||||||
- copy_and_stamp(
|
- copy_and_stamp(
|
||||||
- builder,
|
- builder,
|
||||||
|
@ -116,14 +157,21 @@ index 65a00db3..01fd2cf3 100644
|
||||||
- DependencyType::TargetSelfContained,
|
- DependencyType::TargetSelfContained,
|
||||||
- );
|
- );
|
||||||
- }
|
- }
|
||||||
|
- let crt_path = builder.ensure(native::CrtBeginEnd { target });
|
||||||
|
- for &obj in &["crtbegin.o", "crtbeginS.o", "crtend.o", "crtendS.o"] {
|
||||||
|
- let src = crt_path.join(obj);
|
||||||
|
- let target = libdir_self_contained.join(obj);
|
||||||
|
- builder.copy(&src, &target);
|
||||||
|
- target_deps.push((target, DependencyType::TargetSelfContained));
|
||||||
|
- }
|
||||||
- } else if target.ends_with("-wasi") {
|
- } else if target.ends_with("-wasi") {
|
||||||
+ if target.ends_with("-wasi") {
|
+ if target.ends_with("-wasi") {
|
||||||
let srcdir = builder.wasi_root(target).unwrap().join("lib/wasm32-wasi");
|
let srcdir = builder
|
||||||
copy_and_stamp(
|
.wasi_root(target)
|
||||||
builder,
|
.unwrap_or_else(|| {
|
||||||
@@ -263,15 +244,6 @@
|
@@ -288,15 +261,6 @@ pub fn std_cargo(builder: &Builder<'_>, target: TargetSelection, stage: u32, car
|
||||||
.arg("--manifest-path")
|
.arg("--manifest-path")
|
||||||
.arg(builder.src.join("src/libtest/Cargo.toml"));
|
.arg(builder.src.join("library/test/Cargo.toml"));
|
||||||
|
|
||||||
- // Help the libc crate compile by assisting it in finding various
|
- // Help the libc crate compile by assisting it in finding various
|
||||||
- // sysroot native libraries.
|
- // sysroot native libraries.
|
||||||
|
@ -138,45 +186,44 @@ index 65a00db3..01fd2cf3 100644
|
||||||
if let Some(p) = builder.wasi_root(target) {
|
if let Some(p) = builder.wasi_root(target) {
|
||||||
let root = format!("native={}/lib/wasm32-wasi", p.to_str().unwrap());
|
let root = format!("native={}/lib/wasm32-wasi", p.to_str().unwrap());
|
||||||
diff --git a/src/bootstrap/config.rs b/src/bootstrap/config.rs
|
diff --git a/src/bootstrap/config.rs b/src/bootstrap/config.rs
|
||||||
index 56164b74..8c46334a 100644
|
index 483816b98..7517d757c 100644
|
||||||
--- a/src/bootstrap/config.rs
|
--- a/src/bootstrap/config.rs
|
||||||
+++ b/src/bootstrap/config.rs
|
+++ b/src/bootstrap/config.rs
|
||||||
@@ -154,8 +154,6 @@
|
@@ -165,7 +165,6 @@ pub struct Config {
|
||||||
pub print_step_timings: bool,
|
|
||||||
pub missing_tools: bool,
|
pub missing_tools: bool,
|
||||||
|
|
||||||
- // Fallback musl-root for all targets
|
// Fallback musl-root for all targets
|
||||||
- pub musl_root: Option<PathBuf>,
|
- pub musl_root: Option<PathBuf>,
|
||||||
pub prefix: Option<PathBuf>,
|
pub prefix: Option<PathBuf>,
|
||||||
pub sysconfdir: Option<PathBuf>,
|
pub sysconfdir: Option<PathBuf>,
|
||||||
pub datadir: Option<PathBuf>,
|
pub datadir: Option<PathBuf>,
|
||||||
@@ -252,8 +250,6 @@
|
@@ -291,8 +290,6 @@ pub struct Target {
|
||||||
pub linker: Option<PathBuf>,
|
pub sanitizers: Option<bool>,
|
||||||
pub ndk: Option<PathBuf>,
|
pub profiler: Option<bool>,
|
||||||
pub crt_static: Option<bool>,
|
pub crt_static: Option<bool>,
|
||||||
- pub musl_root: Option<PathBuf>,
|
- pub musl_root: Option<PathBuf>,
|
||||||
- pub musl_libdir: Option<PathBuf>,
|
- pub musl_libdir: Option<PathBuf>,
|
||||||
pub wasi_root: Option<PathBuf>,
|
pub wasi_root: Option<PathBuf>,
|
||||||
pub qemu_rootfs: Option<PathBuf>,
|
pub qemu_rootfs: Option<PathBuf>,
|
||||||
pub no_std: bool,
|
pub no_std: bool,
|
||||||
@@ -438,7 +434,6 @@
|
@@ -481,7 +478,6 @@ struct Rust {
|
||||||
parallel_compiler: Option<bool>,
|
|
||||||
default_linker: Option<String>,
|
default_linker: Option<String>,
|
||||||
channel: Option<String>,
|
channel: Option<String>,
|
||||||
|
description: Option<String>,
|
||||||
- musl_root: Option<String>,
|
- musl_root: Option<String>,
|
||||||
rpath: Option<bool>,
|
rpath: Option<bool>,
|
||||||
verbose_tests: Option<bool>,
|
verbose_tests: Option<bool>,
|
||||||
optimize_tests: Option<bool>,
|
optimize_tests: Option<bool>,
|
||||||
@@ -475,8 +470,6 @@
|
@@ -524,8 +520,6 @@ struct TomlTarget {
|
||||||
llvm_filecheck: Option<String>,
|
sanitizers: Option<bool>,
|
||||||
android_ndk: Option<String>,
|
profiler: Option<bool>,
|
||||||
crt_static: Option<bool>,
|
crt_static: Option<bool>,
|
||||||
- musl_root: Option<String>,
|
- musl_root: Option<String>,
|
||||||
- musl_libdir: Option<String>,
|
- musl_libdir: Option<String>,
|
||||||
wasi_root: Option<String>,
|
wasi_root: Option<String>,
|
||||||
qemu_rootfs: Option<String>,
|
qemu_rootfs: Option<String>,
|
||||||
no_std: Option<bool>,
|
no_std: Option<bool>,
|
||||||
@@ -806,7 +799,6 @@
|
@@ -846,7 +840,6 @@ impl Config {
|
||||||
set(&mut config.llvm_tools_enabled, rust.llvm_tools);
|
set(&mut config.llvm_tools_enabled, rust.llvm_tools);
|
||||||
config.rustc_parallel = rust.parallel_compiler.unwrap_or(false);
|
config.rustc_parallel = rust.parallel_compiler.unwrap_or(false);
|
||||||
config.rustc_default_linker = rust.default_linker;
|
config.rustc_default_linker = rust.default_linker;
|
||||||
|
@ -184,7 +231,7 @@ index 56164b74..8c46334a 100644
|
||||||
config.save_toolstates = rust.save_toolstates.map(PathBuf::from);
|
config.save_toolstates = rust.save_toolstates.map(PathBuf::from);
|
||||||
set(&mut config.deny_warnings, flags.deny_warnings.or(rust.deny_warnings));
|
set(&mut config.deny_warnings, flags.deny_warnings.or(rust.deny_warnings));
|
||||||
set(&mut config.backtrace_on_ice, rust.backtrace_on_ice);
|
set(&mut config.backtrace_on_ice, rust.backtrace_on_ice);
|
||||||
@@ -846,8 +838,6 @@
|
@@ -892,8 +885,6 @@ impl Config {
|
||||||
target.ranlib = cfg.ranlib.map(PathBuf::from);
|
target.ranlib = cfg.ranlib.map(PathBuf::from);
|
||||||
target.linker = cfg.linker.map(PathBuf::from);
|
target.linker = cfg.linker.map(PathBuf::from);
|
||||||
target.crt_static = cfg.crt_static;
|
target.crt_static = cfg.crt_static;
|
||||||
|
@ -192,12 +239,12 @@ index 56164b74..8c46334a 100644
|
||||||
- target.musl_libdir = cfg.musl_libdir.map(PathBuf::from);
|
- target.musl_libdir = cfg.musl_libdir.map(PathBuf::from);
|
||||||
target.wasi_root = cfg.wasi_root.map(PathBuf::from);
|
target.wasi_root = cfg.wasi_root.map(PathBuf::from);
|
||||||
target.qemu_rootfs = cfg.qemu_rootfs.map(PathBuf::from);
|
target.qemu_rootfs = cfg.qemu_rootfs.map(PathBuf::from);
|
||||||
|
target.sanitizers = cfg.sanitizers;
|
||||||
diff --git a/src/bootstrap/configure.py b/src/bootstrap/configure.py
|
diff --git a/src/bootstrap/configure.py b/src/bootstrap/configure.py
|
||||||
index 2a46c563..025928b9 100755
|
index 999882a1c..7ccc2b73c 100755
|
||||||
--- a/src/bootstrap/configure.py
|
--- a/src/bootstrap/configure.py
|
||||||
+++ b/src/bootstrap/configure.py
|
+++ b/src/bootstrap/configure.py
|
||||||
@@ -110,34 +110,6 @@ v("aarch64-linux-android-ndk", "target.aarch64-linux-android.android-ndk",
|
@@ -109,34 +109,6 @@ v("aarch64-linux-android-ndk", "target.aarch64-linux-android.android-ndk",
|
||||||
"aarch64-linux-android NDK standalone path")
|
"aarch64-linux-android NDK standalone path")
|
||||||
v("x86_64-linux-android-ndk", "target.x86_64-linux-android.android-ndk",
|
v("x86_64-linux-android-ndk", "target.x86_64-linux-android.android-ndk",
|
||||||
"x86_64-linux-android NDK standalone path")
|
"x86_64-linux-android NDK standalone path")
|
||||||
|
@ -232,9 +279,11 @@ index 2a46c563..025928b9 100755
|
||||||
v("qemu-armhf-rootfs", "target.arm-unknown-linux-gnueabihf.qemu-rootfs",
|
v("qemu-armhf-rootfs", "target.arm-unknown-linux-gnueabihf.qemu-rootfs",
|
||||||
"rootfs in qemu testing, you probably don't want to use this")
|
"rootfs in qemu testing, you probably don't want to use this")
|
||||||
v("qemu-aarch64-rootfs", "target.aarch64-unknown-linux-gnu.qemu-rootfs",
|
v("qemu-aarch64-rootfs", "target.aarch64-unknown-linux-gnu.qemu-rootfs",
|
||||||
|
diff --git a/src/bootstrap/lib.rs b/src/bootstrap/lib.rs
|
||||||
|
index 24da44b93..c08bc6d94 100644
|
||||||
--- a/src/bootstrap/lib.rs
|
--- a/src/bootstrap/lib.rs
|
||||||
+++ b/src/bootstrap/lib.rs
|
+++ b/src/bootstrap/lib.rs
|
||||||
@@ -876,25 +876,6 @@
|
@@ -927,25 +927,6 @@ impl Build {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -261,10 +310,10 @@ index 2a46c563..025928b9 100755
|
||||||
fn wasi_root(&self, target: TargetSelection) -> Option<&Path> {
|
fn wasi_root(&self, target: TargetSelection) -> Option<&Path> {
|
||||||
self.config.target_config.get(&target).and_then(|t| t.wasi_root.as_ref()).map(|p| &**p)
|
self.config.target_config.get(&target).and_then(|t| t.wasi_root.as_ref()).map(|p| &**p)
|
||||||
diff --git a/src/bootstrap/sanity.rs b/src/bootstrap/sanity.rs
|
diff --git a/src/bootstrap/sanity.rs b/src/bootstrap/sanity.rs
|
||||||
index 530e74da..8ec9f046 100644
|
index ed0cbdf97..44937aed9 100644
|
||||||
--- a/src/bootstrap/sanity.rs
|
--- a/src/bootstrap/sanity.rs
|
||||||
+++ b/src/bootstrap/sanity.rs
|
+++ b/src/bootstrap/sanity.rs
|
||||||
@@ -191,28 +191,6 @@
|
@@ -182,28 +182,6 @@ pub fn check(build: &mut Build) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -273,7 +322,7 @@ index 530e74da..8ec9f046 100644
|
||||||
- // If this is a native target (host is also musl) and no musl-root is given,
|
- // If this is a native target (host is also musl) and no musl-root is given,
|
||||||
- // fall back to the system toolchain in /usr before giving up
|
- // fall back to the system toolchain in /usr before giving up
|
||||||
- if build.musl_root(*target).is_none() && build.config.build == *target {
|
- if build.musl_root(*target).is_none() && build.config.build == *target {
|
||||||
- let target = build.config.target_config.entry(target.clone()).or_default();
|
- let target = build.config.target_config.entry(*target).or_default();
|
||||||
- target.musl_root = Some("/usr".into());
|
- target.musl_root = Some("/usr".into());
|
||||||
- }
|
- }
|
||||||
- match build.musl_libdir(*target) {
|
- match build.musl_libdir(*target) {
|
||||||
|
@ -293,44 +342,3 @@ index 530e74da..8ec9f046 100644
|
||||||
if target.contains("msvc") {
|
if target.contains("msvc") {
|
||||||
// There are three builds of cmake on windows: MSVC, MinGW, and
|
// There are three builds of cmake on windows: MSVC, MinGW, and
|
||||||
// Cygwin. The Cygwin build does not have generators for Visual
|
// Cygwin. The Cygwin build does not have generators for Visual
|
||||||
diff --git a/src/librustc_target/spec/linux_musl_base.rs b/src/librustc_target/spec/linux_musl_base.rs
|
|
||||||
index e294e639..58ae91a9 100644
|
|
||||||
--- a/compiler/rustc_target/src/spec/linux_musl_base.rs
|
|
||||||
+++ b/compiler/rustc_target/src/spec/linux_musl_base.rs
|
|
||||||
@@ -10,10 +10,6 @@
|
|
||||||
// argument is *not* necessary for normal builds, but it can't hurt!
|
|
||||||
base.pre_link_args.get_mut(&LinkerFlavor::Gcc).unwrap().push("-Wl,--eh-frame-hdr".to_string());
|
|
||||||
|
|
||||||
- base.pre_link_objects_fallback = crt_objects::pre_musl_fallback();
|
|
||||||
- base.post_link_objects_fallback = crt_objects::post_musl_fallback();
|
|
||||||
- base.crt_objects_fallback = Some(CrtObjectsFallback::Musl);
|
|
||||||
-
|
|
||||||
// These targets statically link libc by default
|
|
||||||
base.crt_static_default = true;
|
|
||||||
// These targets allow the user to choose between static and dynamic linking.
|
|
||||||
--- a/compiler/rustc_target/src/spec/crt_objects.rs.orig 2020-08-07 01:01:58.142394507 +0200
|
|
||||||
+++ b/compiler/rustc_target/src/spec/crt_objects.rs 2020-08-07 01:02:25.030392771 +0200
|
|
||||||
@@ -61,21 +61,6 @@
|
|
||||||
])
|
|
||||||
}
|
|
||||||
|
|
||||||
-pub(super) fn pre_musl_fallback() -> CrtObjects {
|
|
||||||
- new(&[
|
|
||||||
- (LinkOutputKind::DynamicNoPicExe, &["crt1.o", "crti.o"]),
|
|
||||||
- (LinkOutputKind::DynamicPicExe, &["Scrt1.o", "crti.o"]),
|
|
||||||
- (LinkOutputKind::StaticNoPicExe, &["crt1.o", "crti.o"]),
|
|
||||||
- (LinkOutputKind::StaticPicExe, &["rcrt1.o", "crti.o"]),
|
|
||||||
- (LinkOutputKind::DynamicDylib, &["crti.o"]),
|
|
||||||
- (LinkOutputKind::StaticDylib, &["crti.o"]),
|
|
||||||
- ])
|
|
||||||
-}
|
|
||||||
-
|
|
||||||
-pub(super) fn post_musl_fallback() -> CrtObjects {
|
|
||||||
- all("crtn.o")
|
|
||||||
-}
|
|
||||||
-
|
|
||||||
pub(super) fn pre_mingw_fallback() -> CrtObjects {
|
|
||||||
new(&[
|
|
||||||
(LinkOutputKind::DynamicNoPicExe, &["crt2.o", "rsbegin.o"]),
|
|
||||||
--
|
|
||||||
2.26.2
|
|
||||||
|
|
|
@ -1,18 +1,31 @@
|
||||||
From a640bce17d908a0691d53f22e5257353f694d9b6 Mon Sep 17 00:00:00 2001
|
Additions for build.rs by q66, necessary for our musl setup.
|
||||||
From: q66 <daniel@octaforge.org>
|
|
||||||
Date: Sun, 3 May 2020 17:55:50 +0200
|
From 1eb558f246269606c6d8d73824ef6b44fa10764e Mon Sep 17 00:00:00 2001
|
||||||
Subject: [PATCH 05/15] Prefer libgcc_eh over libunwind on musl
|
From: Samuel Holland <samuel@sholland.org>
|
||||||
|
Date: Sat, 9 Sep 2017 00:14:16 -0500
|
||||||
|
Subject: [PATCH 06/16] Prefer libgcc_eh over libunwind for musl
|
||||||
|
|
||||||
---
|
---
|
||||||
src/libunwind/build.rs | 16 ++--------------
|
|
||||||
src/libunwind/lib.rs | 2 +-
|
src/libunwind/lib.rs | 2 +-
|
||||||
2 files changed, 3 insertions(+), 15 deletions(-)
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/src/libunwind/lib.rs b/src/libunwind/lib.rs
|
||||||
|
index 9182e349b19..0377fbb58fc 100644
|
||||||
|
--- a/library/unwind/src/lib.rs
|
||||||
|
+++ b/library/unwind/src/lib.rs
|
||||||
|
@@ -23,6 +23,6 @@ cfg_if::cfg_if! {
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(target_env = "musl")]
|
||||||
|
-#[link(name = "unwind", kind = "static", cfg(target_feature = "crt-static"))]
|
||||||
|
+#[link(name = "gcc_eh", cfg(target_feature = "crt-static"))]
|
||||||
|
#[link(name = "gcc_s", cfg(not(target_feature = "crt-static")))]
|
||||||
|
extern {}
|
||||||
diff --git a/src/libunwind/build.rs b/src/libunwind/build.rs
|
diff --git a/src/libunwind/build.rs b/src/libunwind/build.rs
|
||||||
index a24808b3..a1250889 100644
|
index f24d957..28828e5 100644
|
||||||
--- a/library/unwind/build.rs
|
--- a/library/unwind/build.rs
|
||||||
+++ b/library/unwind/build.rs
|
+++ b/library/unwind/build.rs
|
||||||
@@ -5,17 +5,14 @@
|
@@ -5,17 +5,12 @@
|
||||||
let target = env::var("TARGET").expect("TARGET was not set");
|
let target = env::var("TARGET").expect("TARGET was not set");
|
||||||
|
|
||||||
if cfg!(feature = "llvm-libunwind")
|
if cfg!(feature = "llvm-libunwind")
|
||||||
|
@ -23,16 +36,15 @@ index a24808b3..a1250889 100644
|
||||||
llvm_libunwind::compile();
|
llvm_libunwind::compile();
|
||||||
} else if target.contains("x86_64-fortanix-unknown-sgx") {
|
} else if target.contains("x86_64-fortanix-unknown-sgx") {
|
||||||
llvm_libunwind::compile();
|
llvm_libunwind::compile();
|
||||||
} else if target.contains("linux") {
|
- } else if target.contains("linux") {
|
||||||
|
- // linking for Linux is handled in lib.rs
|
||||||
- if target.contains("musl") {
|
- if target.contains("musl") {
|
||||||
- // linking for musl is handled in lib.rs
|
|
||||||
- llvm_libunwind::compile();
|
- llvm_libunwind::compile();
|
||||||
- } else if !target.contains("android") {
|
- }
|
||||||
+ if !target.contains("android") {
|
|
||||||
println!("cargo:rustc-link-lib=gcc_s");
|
|
||||||
}
|
|
||||||
} else if target.contains("freebsd") {
|
} else if target.contains("freebsd") {
|
||||||
@@ -145,15 +142,6 @@
|
println!("cargo:rustc-link-lib=gcc_s");
|
||||||
|
} else if target.contains("rumprun") {
|
||||||
|
@@ -143,15 +138,6 @@
|
||||||
cfg.file(root.join("src").join(src));
|
cfg.file(root.join("src").join(src));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,19 +60,4 @@ index a24808b3..a1250889 100644
|
||||||
cfg.compile("unwind");
|
cfg.compile("unwind");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
diff --git a/src/libunwind/lib.rs b/src/libunwind/lib.rs
|
|
||||||
index 18d41be7..17f73d69 100644
|
|
||||||
--- a/library/unwind/src/lib.rs
|
|
||||||
+++ b/library/unwind/src/lib.rs
|
|
||||||
@@ -19,7 +19,7 @@ cfg_if::cfg_if! {
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(target_env = "musl")]
|
|
||||||
-#[link(name = "unwind", kind = "static", cfg(target_feature = "crt-static"))]
|
|
||||||
+#[link(name = "gcc_eh", cfg(target_feature = "crt-static"))]
|
|
||||||
#[link(name = "gcc_s", cfg(not(target_feature = "crt-static")))]
|
|
||||||
extern "C" {}
|
|
||||||
|
|
||||||
--
|
|
||||||
2.26.2
|
|
||||||
|
|
||||||
|
|
|
@ -1,26 +0,0 @@
|
||||||
From d72ad9c226b4ed225c23d88ec5dbe6ba321b37ad Mon Sep 17 00:00:00 2001
|
|
||||||
From: q66 <daniel@octaforge.org>
|
|
||||||
Date: Sat, 21 Dec 2019 17:04:13 +0100
|
|
||||||
Subject: [PATCH 11/15] Dynamically link libc on musl by default
|
|
||||||
|
|
||||||
---
|
|
||||||
src/librustc_target/spec/linux_musl_base.rs | 3 +--
|
|
||||||
1 file changed, 1 insertion(+), 2 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/librustc_target/spec/linux_musl_base.rs b/src/librustc_target/spec/linux_musl_base.rs
|
|
||||||
index 58ae91a9..1fae72d6 100644
|
|
||||||
--- a/compiler/rustc_target/src/spec/linux_musl_base.rs
|
|
||||||
+++ b/compiler/rustc_target/src/spec/linux_musl_base.rs
|
|
||||||
@@ -1,11 +1,9 @@
|
|
||||||
-use crate::spec::crt_objects::{self, CrtObjectsFallback};
|
|
||||||
use crate::spec::TargetOptions;
|
|
||||||
|
|
||||||
pub fn opts() -> TargetOptions {
|
|
||||||
let mut base = super::linux_base::opts();
|
|
||||||
|
|
||||||
- // These targets statically link libc by default
|
|
||||||
- base.crt_static_default = true;
|
|
||||||
+ base.crt_static_default = false;
|
|
||||||
// These targets allow the user to choose between static and dynamic linking.
|
|
||||||
base.crt_static_respected = true;
|
|
||||||
|
|
|
@ -9,17 +9,21 @@ Subject: [PATCH 12/15] Fix dynamic linkage of musl libc for the libc crate
|
||||||
2 files changed, 4 insertions(+), 3 deletions(-)
|
2 files changed, 4 insertions(+), 3 deletions(-)
|
||||||
|
|
||||||
diff --git a/vendor/libc/src/lib.rs b/vendor/libc/src/lib.rs
|
diff --git a/vendor/libc/src/lib.rs b/vendor/libc/src/lib.rs
|
||||||
index 0b1496af..7f7e85a7 100644
|
index 6bb71c552..22060a8d7 100644
|
||||||
--- a/vendor/libc/src/lib.rs
|
--- a/vendor/libc/src/lib.rs
|
||||||
+++ b/vendor/libc/src/lib.rs
|
+++ b/vendor/libc/src/lib.rs
|
||||||
@@ -33,6 +33,7 @@
|
@@ -24,10 +24,7 @@
|
||||||
#![deny(missing_copy_implementations, safe_packed_borrows)]
|
#![deny(missing_copy_implementations, safe_packed_borrows)]
|
||||||
#![no_std]
|
#![cfg_attr(not(feature = "rustc-dep-of-std"), no_std)]
|
||||||
#![cfg_attr(feature = "rustc-dep-of-std", no_core)]
|
#![cfg_attr(feature = "rustc-dep-of-std", no_core)]
|
||||||
|
-#![cfg_attr(
|
||||||
|
- any(feature = "rustc-dep-of-std", target_os = "redox"),
|
||||||
|
- feature(static_nobundle)
|
||||||
|
-)]
|
||||||
+#![cfg_attr(feature = "rustc-dep-of-std", feature(static_nobundle))]
|
+#![cfg_attr(feature = "rustc-dep-of-std", feature(static_nobundle))]
|
||||||
#![cfg_attr(target_os = "redox", feature(static_nobundle))]
|
|
||||||
#![cfg_attr(libc_const_extern_fn, feature(const_extern_fn))]
|
#![cfg_attr(libc_const_extern_fn, feature(const_extern_fn))]
|
||||||
|
|
||||||
|
#[macro_use]
|
||||||
diff --git a/vendor/libc/src/unix/mod.rs b/vendor/libc/src/unix/mod.rs
|
diff --git a/vendor/libc/src/unix/mod.rs b/vendor/libc/src/unix/mod.rs
|
||||||
index 238da24b..ffb05ee7 100644
|
index 238da24b..ffb05ee7 100644
|
||||||
--- a/vendor/libc/src/unix/mod.rs
|
--- a/vendor/libc/src/unix/mod.rs
|
||||||
|
|
|
@ -8,24 +8,24 @@ Subject: [PATCH 14/15] Void: fix linkage against host/target LLVM in cross
|
||||||
src/librustc_llvm/build.rs | 6 ++++--
|
src/librustc_llvm/build.rs | 6 ++++--
|
||||||
1 file changed, 4 insertions(+), 2 deletions(-)
|
1 file changed, 4 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
diff --git a/src/librustc_llvm/build.rs b/src/librustc_llvm/build.rs
|
diff --git a/compiler/rustc_llvm/build.rs b/compiler/rustc_llvm/build.rs
|
||||||
index 9b4f03b3..d0167838 100644
|
index 621363bed..01322e1d2 100644
|
||||||
--- a/compiler/rustc_llvm/build.rs
|
--- a/compiler/rustc_llvm/build.rs
|
||||||
+++ b/compiler/rustc_llvm/build.rs
|
+++ b/compiler/rustc_llvm/build.rs
|
||||||
@@ -217,9 +217,11 @@ fn main() {
|
@@ -242,9 +242,11 @@ fn main() {
|
||||||
for lib in output(&mut cmd).split_whitespace() {
|
for lib in output(&mut cmd).split_whitespace() {
|
||||||
if is_crossed {
|
if is_crossed {
|
||||||
if lib.starts_with("-LIBPATH:") {
|
if let Some(stripped) = lib.strip_prefix("-LIBPATH:") {
|
||||||
- println!("cargo:rustc-link-search=native={}", lib[9..].replace(&host, &target));
|
- println!("cargo:rustc-link-search=native={}", stripped.replace(&host, &target));
|
||||||
+ println!("cargo:rustc-link-search=native={}{}",
|
+ println!("cargo:rustc-link-search=native={}{}",
|
||||||
+ env::var("XBPS_CROSS_BASE").unwrap(), &lib[9..]);
|
+ env::var("XBPS_CROSS_BASE").unwrap(), stripped);
|
||||||
} else if lib.starts_with("-L") {
|
} else if let Some(stripped) = lib.strip_prefix("-L") {
|
||||||
- println!("cargo:rustc-link-search=native={}", lib[2..].replace(&host, &target));
|
- println!("cargo:rustc-link-search=native={}", stripped.replace(&host, &target));
|
||||||
+ println!("cargo:rustc-link-search=native={}{}",
|
+ println!("cargo:rustc-link-search=native={}{}",
|
||||||
+ env::var("XBPS_CROSS_BASE").unwrap(), &lib[2..]);
|
+ env::var("XBPS_CROSS_BASE").unwrap(), stripped);
|
||||||
}
|
}
|
||||||
} else if lib.starts_with("-LIBPATH:") {
|
} else if let Some(stripped) = lib.strip_prefix("-LIBPATH:") {
|
||||||
println!("cargo:rustc-link-search=native={}", &lib[9..]);
|
println!("cargo:rustc-link-search=native={}", stripped);
|
||||||
--
|
--
|
||||||
2.26.2
|
2.26.2
|
||||||
|
|
||||||
|
|
|
@ -12,15 +12,15 @@ so at least match the environment we have.
|
||||||
src/librustc_target/spec/powerpc64_unknown_linux_gnu.rs | 6 +-----
|
src/librustc_target/spec/powerpc64_unknown_linux_gnu.rs | 6 +-----
|
||||||
2 files changed, 2 insertions(+), 13 deletions(-)
|
2 files changed, 2 insertions(+), 13 deletions(-)
|
||||||
|
|
||||||
diff --git a/src/librustc_target/abi/call/powerpc64.rs b/src/librustc_target/abi/call/powerpc64.rs
|
diff --git a/compiler/rustc_target/src/abi/call/powerpc64.rs b/compiler/rustc_target/src/abi/call/powerpc64.rs
|
||||||
index 93c4e97d..96b02486 100644
|
index 8c2a9d09a..2dcbf2c09 100644
|
||||||
--- a/compiler/rustc_target/src/abi/call/powerpc64.rs
|
--- a/compiler/rustc_target/src/abi/call/powerpc64.rs
|
||||||
+++ b/compiler/rustc_target/src/abi/call/powerpc64.rs
|
+++ b/compiler/rustc_target/src/abi/call/powerpc64.rs
|
||||||
@@ -119,14 +119,7 @@ where
|
@@ -119,14 +119,7 @@ where
|
||||||
Ty: TyLayoutMethods<'a, C> + Copy,
|
Ty: TyAndLayoutMethods<'a, C> + Copy,
|
||||||
C: LayoutOf<Ty = Ty, TyLayout = TyLayout<'a, Ty>> + HasDataLayout + HasTargetSpec,
|
C: LayoutOf<Ty = Ty, TyAndLayout = TyAndLayout<'a, Ty>> + HasDataLayout + HasTargetSpec,
|
||||||
{
|
{
|
||||||
- let abi = if cx.target_spec().target_env == "musl" {
|
- let abi = if cx.target_spec().env == "musl" {
|
||||||
- ELFv2
|
- ELFv2
|
||||||
- } else {
|
- } else {
|
||||||
- match cx.data_layout().endian {
|
- match cx.data_layout().endian {
|
||||||
|
@ -32,17 +32,18 @@ index 93c4e97d..96b02486 100644
|
||||||
|
|
||||||
if !fn_abi.ret.is_ignore() {
|
if !fn_abi.ret.is_ignore() {
|
||||||
classify_ret(cx, &mut fn_abi.ret, abi);
|
classify_ret(cx, &mut fn_abi.ret, abi);
|
||||||
diff --git a/src/librustc_target/spec/powerpc64_unknown_linux_gnu.rs b/src/librustc_target/spec/powerpc64_unknown_linux_gnu.rs
|
diff --git a/compiler/rustc_target/src/spec/powerpc64_unknown_linux_gnu.rs b/compiler/rustc_target/src/spec/powerpc64_unknown_linux_gnu.rs
|
||||||
index 5306d905..c63eed85 100644
|
index 751022c12..c4d55a62e 100644
|
||||||
--- a/compiler/rustc_target/src/spec/powerpc64_unknown_linux_gnu.rs
|
--- a/compiler/rustc_target/src/spec/powerpc64_unknown_linux_gnu.rs
|
||||||
+++ b/compiler/rustc_target/src/spec/powerpc64_unknown_linux_gnu.rs
|
+++ b/compiler/rustc_target/src/spec/powerpc64_unknown_linux_gnu.rs
|
||||||
@@ -1,4 +1,4 @@
|
@@ -1,5 +1,5 @@
|
||||||
-use crate::spec::{LinkerFlavor, RelroLevel, Target, TargetOptions, TargetResult};
|
use crate::abi::Endian;
|
||||||
+use crate::spec::{LinkerFlavor, Target, TargetOptions, TargetResult};
|
-use crate::spec::{LinkerFlavor, RelroLevel, Target, TargetOptions};
|
||||||
|
+use crate::spec::{LinkerFlavor, Target, TargetOptions};
|
||||||
|
|
||||||
pub fn target() -> TargetResult {
|
pub fn target() -> Target {
|
||||||
let mut base = super::linux_base::opts();
|
let mut base = super::linux_gnu_base::opts();
|
||||||
@@ -6,10 +6,6 @@ pub fn target() -> TargetResult {
|
@@ -7,10 +7,6 @@ pub fn target() -> Target {
|
||||||
base.pre_link_args.get_mut(&LinkerFlavor::Gcc).unwrap().push("-m64".to_string());
|
base.pre_link_args.get_mut(&LinkerFlavor::Gcc).unwrap().push("-m64".to_string());
|
||||||
base.max_atomic_width = Some(64);
|
base.max_atomic_width = Some(64);
|
||||||
|
|
||||||
|
@ -50,9 +51,9 @@ index 5306d905..c63eed85 100644
|
||||||
- // for now. https://github.com/rust-lang/rust/pull/43170#issuecomment-315411474
|
- // for now. https://github.com/rust-lang/rust/pull/43170#issuecomment-315411474
|
||||||
- base.relro_level = RelroLevel::Partial;
|
- base.relro_level = RelroLevel::Partial;
|
||||||
-
|
-
|
||||||
Ok(Target {
|
Target {
|
||||||
llvm_target: "powerpc64-unknown-linux-gnu".to_string(),
|
llvm_target: "powerpc64-unknown-linux-gnu".to_string(),
|
||||||
target_endian: "big".to_string(),
|
pointer_width: 64,
|
||||||
--
|
--
|
||||||
2.26.2
|
2.26.2
|
||||||
|
|
||||||
|
|
23
srcpkgs/rust/patches/fix-ppc32.patch
Normal file
23
srcpkgs/rust/patches/fix-ppc32.patch
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
From 283619cf5ca25272b294525273ec42e9c7820edb Mon Sep 17 00:00:00 2001
|
||||||
|
From: John Paul Adrian Glaubitz <glaubitz@physik.fu-berlin.de>
|
||||||
|
Date: Sat, 29 May 2021 12:38:46 +0000
|
||||||
|
Subject: [PATCH] bootstrap: Disable initial-exec TLS model on powerpc
|
||||||
|
|
||||||
|
Fixes #81334.
|
||||||
|
---
|
||||||
|
src/bootstrap/builder.rs | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/src/bootstrap/builder.rs b/src/bootstrap/builder.rs
|
||||||
|
index f39e89a9d01f7..061d7ed5ee08b 100644
|
||||||
|
--- a/src/bootstrap/builder.rs
|
||||||
|
+++ b/src/bootstrap/builder.rs
|
||||||
|
@@ -1237,7 +1237,7 @@ impl<'a> Builder<'a> {
|
||||||
|
// efficient initial-exec TLS model. This doesn't work with `dlopen`,
|
||||||
|
// so we can't use it by default in general, but we can use it for tools
|
||||||
|
// and our own internal libraries.
|
||||||
|
- if !mode.must_support_dlopen() {
|
||||||
|
+ if !mode.must_support_dlopen() && !target.triple.starts_with("powerpc-") && !target.triple.starts_with("powerpcle-") {
|
||||||
|
rustflags.arg("-Ztls-model=initial-exec");
|
||||||
|
}
|
||||||
|
|
13
srcpkgs/rust/patches/need-ssp-nonshared-and-execinfo.patch
Normal file
13
srcpkgs/rust/patches/need-ssp-nonshared-and-execinfo.patch
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
--- a/library/std/src/sys/unix/mod.rs
|
||||||
|
+++ b/library/std/src/sys/unix/mod.rs
|
||||||
|
@@ -212,6 +212,10 @@ cfg_if::cfg_if! {
|
||||||
|
#[link(name = "log")]
|
||||||
|
#[link(name = "gcc")]
|
||||||
|
extern "C" {}
|
||||||
|
+ } else if #[cfg(all(target_os = "linux", target_env = "musl"))] {
|
||||||
|
+ #[link(name = "ssp_nonshared")]
|
||||||
|
+ #[link(name = "execinfo")]
|
||||||
|
+ extern "C" {}
|
||||||
|
} else if #[cfg(target_os = "freebsd")] {
|
||||||
|
#[link(name = "execinfo")]
|
||||||
|
#[link(name = "pthread")]
|
|
@ -1,23 +0,0 @@
|
||||||
--- rustc-1.47.0-src/library/std/build.rs.orig
|
|
||||||
+++ rustc-1.47.0-src/library/std/build.rs
|
|
||||||
@@ -8,6 +8,8 @@
|
|
||||||
println!("cargo:rustc-link-lib=dl");
|
|
||||||
println!("cargo:rustc-link-lib=log");
|
|
||||||
println!("cargo:rustc-link-lib=gcc");
|
|
||||||
+ } else if target.contains("musl") {
|
|
||||||
+ println!("cargo:rustc-link-lib=ssp_nonshared");
|
|
||||||
}
|
|
||||||
} else if target.contains("freebsd") {
|
|
||||||
println!("cargo:rustc-link-lib=execinfo");
|
|
||||||
--- rustc-1.44.0-src/library/unwind/build.rs.orig
|
|
||||||
+++ rustc-1.44.0-src/library/unwind/build.rs
|
|
||||||
@@ -12,6 +12,9 @@ fn main() {
|
|
||||||
} else if target.contains("linux") {
|
|
||||||
if !target.contains("android") {
|
|
||||||
println!("cargo:rustc-link-lib=gcc_s");
|
|
||||||
+ if target.contains("musl") {
|
|
||||||
+ println!("cargo:rustc-link-lib=ssp_nonshared");
|
|
||||||
+ }
|
|
||||||
}
|
|
||||||
} else if target.contains("freebsd") {
|
|
||||||
println!("cargo:rustc-link-lib=gcc_s");
|
|
29
srcpkgs/rust/patches/xxx-ppcle-ccrs.patch
Normal file
29
srcpkgs/rust/patches/xxx-ppcle-ccrs.patch
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
From dc1de5be2b7908adb493b36f5079064083ed9507 Mon Sep 17 00:00:00 2001
|
||||||
|
From: q66 <daniel@octaforge.org>
|
||||||
|
Date: Sat, 3 Jul 2021 19:00:46 +0200
|
||||||
|
Subject: [PATCH 1/2] cc-1.0.60: fix powerpcle being matched as as msvc
|
||||||
|
|
||||||
|
---
|
||||||
|
vendor/cc-1.0.60/src/lib.rs | 6 +-----
|
||||||
|
1 file changed, 1 insertion(+), 5 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/vendor/cc-1.0.60/src/lib.rs b/vendor/cc-1.0.60/src/lib.rs
|
||||||
|
index aff6be86..f428ecbb 100644
|
||||||
|
--- a/vendor/cc-1.0.60/src/lib.rs
|
||||||
|
+++ b/vendor/cc-1.0.60/src/lib.rs
|
||||||
|
@@ -2556,11 +2556,7 @@ impl Tool {
|
||||||
|
let family = if let Some(fname) = path.file_name().and_then(|p| p.to_str()) {
|
||||||
|
if fname.contains("clang-cl") {
|
||||||
|
ToolFamily::Msvc { clang_cl: true }
|
||||||
|
- } else if fname.contains("cl")
|
||||||
|
- && !fname.contains("cloudabi")
|
||||||
|
- && !fname.contains("uclibc")
|
||||||
|
- && !fname.contains("clang")
|
||||||
|
- {
|
||||||
|
+ } else if fname.ends_with("cl") || fname == "cl.exe" {
|
||||||
|
ToolFamily::Msvc { clang_cl: false }
|
||||||
|
} else if fname.contains("clang") {
|
||||||
|
match clang_driver {
|
||||||
|
--
|
||||||
|
2.31.1
|
||||||
|
|
25
srcpkgs/rust/patches/xxx-ppcle-gcc.patch
Normal file
25
srcpkgs/rust/patches/xxx-ppcle-gcc.patch
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
From bf983e79364d2d1c4a22857fadae8fcdc6646ef3 Mon Sep 17 00:00:00 2001
|
||||||
|
From: q66 <daniel@octaforge.org>
|
||||||
|
Date: Sun, 4 Jul 2021 02:17:26 +0200
|
||||||
|
Subject: [PATCH] gcc: fix powerpcle being matched as msvc
|
||||||
|
|
||||||
|
---
|
||||||
|
vendor/gcc/src/lib.rs | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/vendor/gcc/src/lib.rs b/vendor/gcc/src/lib.rs
|
||||||
|
index 7980281f..05787ceb 100644
|
||||||
|
--- a/vendor/gcc/src/lib.rs
|
||||||
|
+++ b/vendor/gcc/src/lib.rs
|
||||||
|
@@ -1549,7 +1549,7 @@ impl Tool {
|
||||||
|
let family = if let Some(fname) = path.file_name().and_then(|p| p.to_str()) {
|
||||||
|
if fname.contains("clang") {
|
||||||
|
ToolFamily::Clang
|
||||||
|
- } else if fname.contains("cl") && !fname.contains("uclibc") {
|
||||||
|
+ } else if fname.ends_with("cl") || fname == "cl.exe" {
|
||||||
|
ToolFamily::Msvc
|
||||||
|
} else {
|
||||||
|
ToolFamily::Gnu
|
||||||
|
--
|
||||||
|
2.31.1
|
||||||
|
|
601
srcpkgs/rust/patches/xxx-ppcle.patch
Normal file
601
srcpkgs/rust/patches/xxx-ppcle.patch
Normal file
|
@ -0,0 +1,601 @@
|
||||||
|
From b92ce1ed0ac8d95831a43f4395544c17a0816c9b Mon Sep 17 00:00:00 2001
|
||||||
|
From: Daniel Kolesa <daniel@octaforge.org>
|
||||||
|
Date: Sat, 3 Jul 2021 21:02:03 +0200
|
||||||
|
Subject: [PATCH] initial ppcle port
|
||||||
|
|
||||||
|
---
|
||||||
|
compiler/rustc_middle/src/ty/layout.rs | 5 ++++-
|
||||||
|
compiler/rustc_target/src/spec/mod.rs | 2 ++
|
||||||
|
.../src/spec/powerpcle_unknown_linux_gnu.rs | 15 +++++++++++++++
|
||||||
|
.../src/spec/powerpcle_unknown_linux_musl.rs | 15 +++++++++++++++
|
||||||
|
src/bootstrap/bootstrap.py | 2 ++
|
||||||
|
.../codegen/abi-main-signature-16bit-c-int.rs | 1 +
|
||||||
|
src/test/codegen/fastcall-inreg.rs | 1 +
|
||||||
|
src/test/codegen/global_asm.rs | 1 +
|
||||||
|
src/test/codegen/global_asm_include.rs | 1 +
|
||||||
|
src/test/codegen/global_asm_x2.rs | 1 +
|
||||||
|
src/test/codegen/repr-transparent-aggregates-1.rs | 1 +
|
||||||
|
src/test/codegen/repr-transparent-aggregates-2.rs | 1 +
|
||||||
|
src/test/codegen/stack-probes.rs | 1 +
|
||||||
|
.../run-make-fulldeps/atomic-lock-free/Makefile | 2 ++
|
||||||
|
src/test/ui/abi/stack-probes-lto.rs | 1 +
|
||||||
|
src/test/ui/abi/stack-probes.rs | 1 +
|
||||||
|
src/test/ui/borrowck/borrowck-asm.rs | 1 +
|
||||||
|
src/test/ui/llvm-asm/llvm-asm-bad-clobber.rs | 1 +
|
||||||
|
src/test/ui/llvm-asm/llvm-asm-in-bad-modifier.rs | 1 +
|
||||||
|
src/test/ui/llvm-asm/llvm-asm-misplaced-option.rs | 1 +
|
||||||
|
src/test/ui/llvm-asm/llvm-asm-out-assign-imm.rs | 1 +
|
||||||
|
src/test/ui/llvm-asm/llvm-asm-out-no-modifier.rs | 1 +
|
||||||
|
src/test/ui/llvm-asm/llvm-asm-out-read-uninit.rs | 1 +
|
||||||
|
src/test/ui/target-feature/gate.rs | 1 +
|
||||||
|
src/test/ui/target-feature/invalid-attribute.rs | 1 +
|
||||||
|
src/tools/compiletest/src/util.rs | 1 +
|
||||||
|
vendor/cc-1.0.60/src/lib.rs | 1 +
|
||||||
|
vendor/cc/src/lib.rs | 1 +
|
||||||
|
vendor/gcc/src/lib.rs | 3 ++-
|
||||||
|
vendor/jemallocator/benches/roundtrip.rs | 3 ++-
|
||||||
|
vendor/jemallocator/src/lib.rs | 3 ++-
|
||||||
|
vendor/rustc-ap-rustc_target/src/spec/mod.rs | 2 ++
|
||||||
|
.../src/spec/powerpcle_unknown_linux_gnu.rs | 15 +++++++++++++++
|
||||||
|
.../src/spec/powerpcle_unknown_linux_musl.rs | 15 +++++++++++++++
|
||||||
|
vendor/target-lexicon/src/targets.rs | 7 +++++++
|
||||||
|
vendor/tikv-jemallocator/benches/roundtrip.rs | 3 ++-
|
||||||
|
vendor/tikv-jemallocator/src/lib.rs | 3 ++-
|
||||||
|
37 files changed, 111 insertions(+), 6 deletions(-)
|
||||||
|
create mode 100644 compiler/rustc_target/src/spec/powerpcle_unknown_linux_gnu.rs
|
||||||
|
create mode 100644 compiler/rustc_target/src/spec/powerpcle_unknown_linux_musl.rs
|
||||||
|
create mode 100644 vendor/rustc-ap-rustc_target/src/spec/powerpcle_unknown_linux_gnu.rs
|
||||||
|
create mode 100644 vendor/rustc-ap-rustc_target/src/spec/powerpcle_unknown_linux_musl.rs
|
||||||
|
|
||||||
|
diff --git a/compiler/rustc_middle/src/ty/layout.rs b/compiler/rustc_middle/src/ty/layout.rs
|
||||||
|
index c2e9dba6..8147a3c3 100644
|
||||||
|
--- a/compiler/rustc_middle/src/ty/layout.rs
|
||||||
|
+++ b/compiler/rustc_middle/src/ty/layout.rs
|
||||||
|
@@ -2753,6 +2753,8 @@ where
|
||||||
|
target.os == "linux" && target.arch == "sparc64" && target_env_gnu_like;
|
||||||
|
let linux_powerpc_gnu_like =
|
||||||
|
target.os == "linux" && target.arch == "powerpc" && target_env_gnu_like;
|
||||||
|
+ let linux_powerpcle_gnu_like =
|
||||||
|
+ target.os == "linux" && target.arch == "powerpcle" && target_env_gnu_like;
|
||||||
|
let rust_abi = matches!(sig.abi, RustIntrinsic | PlatformIntrinsic | Rust | RustCall);
|
||||||
|
|
||||||
|
// Handle safe Rust thin and fat pointers.
|
||||||
|
@@ -2850,7 +2852,8 @@ where
|
||||||
|
|| (!win_x64_gnu
|
||||||
|
&& !linux_s390x_gnu_like
|
||||||
|
&& !linux_sparc64_gnu_like
|
||||||
|
- && !linux_powerpc_gnu_like)
|
||||||
|
+ && !linux_powerpc_gnu_like
|
||||||
|
+ && !linux_powerpcle_gnu_like)
|
||||||
|
{
|
||||||
|
arg.mode = PassMode::Ignore;
|
||||||
|
}
|
||||||
|
diff --git a/compiler/rustc_target/src/spec/mod.rs b/compiler/rustc_target/src/spec/mod.rs
|
||||||
|
index 2af46693..986d84e0 100644
|
||||||
|
--- a/compiler/rustc_target/src/spec/mod.rs
|
||||||
|
+++ b/compiler/rustc_target/src/spec/mod.rs
|
||||||
|
@@ -716,6 +716,8 @@ supported_targets! {
|
||||||
|
("powerpc-unknown-linux-gnu", powerpc_unknown_linux_gnu),
|
||||||
|
("powerpc-unknown-linux-gnuspe", powerpc_unknown_linux_gnuspe),
|
||||||
|
("powerpc-unknown-linux-musl", powerpc_unknown_linux_musl),
|
||||||
|
+ ("powerpcle-unknown-linux-gnu", powerpcle_unknown_linux_gnu),
|
||||||
|
+ ("powerpcle-unknown-linux-musl", powerpcle_unknown_linux_musl),
|
||||||
|
("powerpc64-unknown-linux-gnu", powerpc64_unknown_linux_gnu),
|
||||||
|
("powerpc64-unknown-linux-musl", powerpc64_unknown_linux_musl),
|
||||||
|
("powerpc64le-unknown-linux-gnu", powerpc64le_unknown_linux_gnu),
|
||||||
|
diff --git a/compiler/rustc_target/src/spec/powerpcle_unknown_linux_gnu.rs b/compiler/rustc_target/src/spec/powerpcle_unknown_linux_gnu.rs
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..780c20a3
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/compiler/rustc_target/src/spec/powerpcle_unknown_linux_gnu.rs
|
||||||
|
@@ -0,0 +1,15 @@
|
||||||
|
+use crate::spec::{LinkerFlavor, Target, TargetOptions};
|
||||||
|
+
|
||||||
|
+pub fn target() -> Target {
|
||||||
|
+ let mut base = super::linux_gnu_base::opts();
|
||||||
|
+ base.pre_link_args.entry(LinkerFlavor::Gcc).or_default().push("-m32".to_string());
|
||||||
|
+ base.max_atomic_width = Some(32);
|
||||||
|
+
|
||||||
|
+ Target {
|
||||||
|
+ llvm_target: "powerpcle-unknown-linux-gnu".to_string(),
|
||||||
|
+ pointer_width: 32,
|
||||||
|
+ data_layout: "e-m:e-p:32:32-i64:64-n32".to_string(),
|
||||||
|
+ arch: "powerpc".to_string(),
|
||||||
|
+ options: TargetOptions { mcount: "_mcount".to_string(), ..base },
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
diff --git a/compiler/rustc_target/src/spec/powerpcle_unknown_linux_musl.rs b/compiler/rustc_target/src/spec/powerpcle_unknown_linux_musl.rs
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..9b848ccf
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/compiler/rustc_target/src/spec/powerpcle_unknown_linux_musl.rs
|
||||||
|
@@ -0,0 +1,15 @@
|
||||||
|
+use crate::spec::{LinkerFlavor, Target, TargetOptions};
|
||||||
|
+
|
||||||
|
+pub fn target() -> Target {
|
||||||
|
+ let mut base = super::linux_musl_base::opts();
|
||||||
|
+ base.pre_link_args.entry(LinkerFlavor::Gcc).or_default().push("-m32".to_string());
|
||||||
|
+ base.max_atomic_width = Some(32);
|
||||||
|
+
|
||||||
|
+ Target {
|
||||||
|
+ llvm_target: "powerpcle-unknown-linux-musl".to_string(),
|
||||||
|
+ pointer_width: 32,
|
||||||
|
+ data_layout: "e-m:e-p:32:32-i64:64-n32".to_string(),
|
||||||
|
+ arch: "powerpc".to_string(),
|
||||||
|
+ options: TargetOptions { mcount: "_mcount".to_string(), ..base },
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
diff --git a/src/bootstrap/bootstrap.py b/src/bootstrap/bootstrap.py
|
||||||
|
index 4111420e..cd69a8ec 100644
|
||||||
|
--- a/src/bootstrap/bootstrap.py
|
||||||
|
+++ b/src/bootstrap/bootstrap.py
|
||||||
|
@@ -289,9 +289,11 @@ def default_build_triple(verbose):
|
||||||
|
'i686': 'i686',
|
||||||
|
'i786': 'i686',
|
||||||
|
'powerpc': 'powerpc',
|
||||||
|
+ 'powerpcle': 'powerpcle',
|
||||||
|
'powerpc64': 'powerpc64',
|
||||||
|
'powerpc64le': 'powerpc64le',
|
||||||
|
'ppc': 'powerpc',
|
||||||
|
+ 'ppcle': 'powerpcle',
|
||||||
|
'ppc64': 'powerpc64',
|
||||||
|
'ppc64le': 'powerpc64le',
|
||||||
|
's390x': 's390x',
|
||||||
|
diff --git a/src/test/codegen/abi-main-signature-16bit-c-int.rs b/src/test/codegen/abi-main-signature-16bit-c-int.rs
|
||||||
|
index 4ed491df..82ec7755 100644
|
||||||
|
--- a/src/test/codegen/abi-main-signature-16bit-c-int.rs
|
||||||
|
+++ b/src/test/codegen/abi-main-signature-16bit-c-int.rs
|
||||||
|
@@ -9,6 +9,7 @@
|
||||||
|
// ignore-mips
|
||||||
|
// ignore-mips64
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-riscv64
|
||||||
|
// ignore-s390x
|
||||||
|
diff --git a/src/test/codegen/fastcall-inreg.rs b/src/test/codegen/fastcall-inreg.rs
|
||||||
|
index adbeae45..0fd0a9e6 100644
|
||||||
|
--- a/src/test/codegen/fastcall-inreg.rs
|
||||||
|
+++ b/src/test/codegen/fastcall-inreg.rs
|
||||||
|
@@ -16,6 +16,7 @@
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-r600
|
||||||
|
// ignore-riscv64
|
||||||
|
// ignore-amdgcn
|
||||||
|
diff --git a/src/test/codegen/global_asm.rs b/src/test/codegen/global_asm.rs
|
||||||
|
index 57d8aeb1..e0b1b692 100644
|
||||||
|
--- a/src/test/codegen/global_asm.rs
|
||||||
|
+++ b/src/test/codegen/global_asm.rs
|
||||||
|
@@ -12,6 +12,7 @@
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-r600
|
||||||
|
// ignore-amdgcn
|
||||||
|
// ignore-sparc
|
||||||
|
diff --git a/src/test/codegen/global_asm_include.rs b/src/test/codegen/global_asm_include.rs
|
||||||
|
index 44402619..62ecfa6d 100644
|
||||||
|
--- a/src/test/codegen/global_asm_include.rs
|
||||||
|
+++ b/src/test/codegen/global_asm_include.rs
|
||||||
|
@@ -12,6 +12,7 @@
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-r600
|
||||||
|
// ignore-amdgcn
|
||||||
|
// ignore-sparc
|
||||||
|
diff --git a/src/test/codegen/global_asm_x2.rs b/src/test/codegen/global_asm_x2.rs
|
||||||
|
index d632d0dd..29f97775 100644
|
||||||
|
--- a/src/test/codegen/global_asm_x2.rs
|
||||||
|
+++ b/src/test/codegen/global_asm_x2.rs
|
||||||
|
@@ -12,6 +12,7 @@
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-r600
|
||||||
|
// ignore-amdgcn
|
||||||
|
// ignore-sparc
|
||||||
|
diff --git a/src/test/codegen/repr-transparent-aggregates-1.rs b/src/test/codegen/repr-transparent-aggregates-1.rs
|
||||||
|
index 3017adb4..632565bb 100644
|
||||||
|
--- a/src/test/codegen/repr-transparent-aggregates-1.rs
|
||||||
|
+++ b/src/test/codegen/repr-transparent-aggregates-1.rs
|
||||||
|
@@ -7,6 +7,7 @@
|
||||||
|
// ignore-mips
|
||||||
|
// ignore-mips64
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-riscv64 see codegen/riscv-abi
|
||||||
|
// ignore-windows
|
||||||
|
diff --git a/src/test/codegen/repr-transparent-aggregates-2.rs b/src/test/codegen/repr-transparent-aggregates-2.rs
|
||||||
|
index 429d760b..57e75f95 100644
|
||||||
|
--- a/src/test/codegen/repr-transparent-aggregates-2.rs
|
||||||
|
+++ b/src/test/codegen/repr-transparent-aggregates-2.rs
|
||||||
|
@@ -6,6 +6,7 @@
|
||||||
|
// ignore-emscripten
|
||||||
|
// ignore-mips64
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-riscv64 see codegen/riscv-abi
|
||||||
|
diff --git a/src/test/codegen/stack-probes.rs b/src/test/codegen/stack-probes.rs
|
||||||
|
index 9bd351df..29073eb5 100644
|
||||||
|
--- a/src/test/codegen/stack-probes.rs
|
||||||
|
+++ b/src/test/codegen/stack-probes.rs
|
||||||
|
@@ -3,6 +3,7 @@
|
||||||
|
// ignore-mips
|
||||||
|
// ignore-mips64
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-riscv64
|
||||||
|
diff --git a/src/test/run-make-fulldeps/atomic-lock-free/Makefile b/src/test/run-make-fulldeps/atomic-lock-free/Makefile
|
||||||
|
index 9e8b4fab..402d37a4 100644
|
||||||
|
--- a/src/test/run-make-fulldeps/atomic-lock-free/Makefile
|
||||||
|
+++ b/src/test/run-make-fulldeps/atomic-lock-free/Makefile
|
||||||
|
@@ -36,6 +36,8 @@ ifeq ($(filter powerpc,$(LLVM_COMPONENTS)),powerpc)
|
||||||
|
nm "$(TMPDIR)/libatomic_lock_free.rlib" | $(CGREP) -v __atomic_fetch_add
|
||||||
|
$(RUSTC) --target=powerpc-unknown-linux-gnuspe atomic_lock_free.rs
|
||||||
|
nm "$(TMPDIR)/libatomic_lock_free.rlib" | $(CGREP) -v __atomic_fetch_add
|
||||||
|
+ $(RUSTC) --target=powerpcle-unknown-linux-gnu atomic_lock_free.rs
|
||||||
|
+ nm "$(TMPDIR)/libatomic_lock_free.rlib" | $(CGREP) -v __atomic_fetch_add
|
||||||
|
$(RUSTC) --target=powerpc64-unknown-linux-gnu atomic_lock_free.rs
|
||||||
|
nm "$(TMPDIR)/libatomic_lock_free.rlib" | $(CGREP) -v __atomic_fetch_add
|
||||||
|
$(RUSTC) --target=powerpc64le-unknown-linux-gnu atomic_lock_free.rs
|
||||||
|
diff --git a/src/test/ui/abi/stack-probes-lto.rs b/src/test/ui/abi/stack-probes-lto.rs
|
||||||
|
index 90df1f3f..8c6dda8b 100644
|
||||||
|
--- a/src/test/ui/abi/stack-probes-lto.rs
|
||||||
|
+++ b/src/test/ui/abi/stack-probes-lto.rs
|
||||||
|
@@ -4,6 +4,7 @@
|
||||||
|
// ignore-mips
|
||||||
|
// ignore-mips64
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-s390x
|
||||||
|
// ignore-sparc
|
||||||
|
// ignore-sparc64
|
||||||
|
diff --git a/src/test/ui/abi/stack-probes.rs b/src/test/ui/abi/stack-probes.rs
|
||||||
|
index e998dd0f..9472e538 100644
|
||||||
|
--- a/src/test/ui/abi/stack-probes.rs
|
||||||
|
+++ b/src/test/ui/abi/stack-probes.rs
|
||||||
|
@@ -4,6 +4,7 @@
|
||||||
|
// ignore-mips
|
||||||
|
// ignore-mips64
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-s390x
|
||||||
|
// ignore-sparc
|
||||||
|
// ignore-sparc64
|
||||||
|
diff --git a/src/test/ui/borrowck/borrowck-asm.rs b/src/test/ui/borrowck/borrowck-asm.rs
|
||||||
|
index a3f64524..faf9adb4 100644
|
||||||
|
--- a/src/test/ui/borrowck/borrowck-asm.rs
|
||||||
|
+++ b/src/test/ui/borrowck/borrowck-asm.rs
|
||||||
|
@@ -1,6 +1,7 @@
|
||||||
|
// ignore-s390x
|
||||||
|
// ignore-emscripten
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-riscv64
|
||||||
|
diff --git a/src/test/ui/llvm-asm/llvm-asm-bad-clobber.rs b/src/test/ui/llvm-asm/llvm-asm-bad-clobber.rs
|
||||||
|
index 2868d3d3..5c6e325b 100644
|
||||||
|
--- a/src/test/ui/llvm-asm/llvm-asm-bad-clobber.rs
|
||||||
|
+++ b/src/test/ui/llvm-asm/llvm-asm-bad-clobber.rs
|
||||||
|
@@ -4,6 +4,7 @@
|
||||||
|
// ignore-s390x
|
||||||
|
// ignore-emscripten
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-riscv64
|
||||||
|
diff --git a/src/test/ui/llvm-asm/llvm-asm-in-bad-modifier.rs b/src/test/ui/llvm-asm/llvm-asm-in-bad-modifier.rs
|
||||||
|
index e3bc7d29..49f53f67 100644
|
||||||
|
--- a/src/test/ui/llvm-asm/llvm-asm-in-bad-modifier.rs
|
||||||
|
+++ b/src/test/ui/llvm-asm/llvm-asm-in-bad-modifier.rs
|
||||||
|
@@ -1,6 +1,7 @@
|
||||||
|
// ignore-s390x
|
||||||
|
// ignore-emscripten
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-riscv64
|
||||||
|
diff --git a/src/test/ui/llvm-asm/llvm-asm-misplaced-option.rs b/src/test/ui/llvm-asm/llvm-asm-misplaced-option.rs
|
||||||
|
index daae0c81..fd505c86 100644
|
||||||
|
--- a/src/test/ui/llvm-asm/llvm-asm-misplaced-option.rs
|
||||||
|
+++ b/src/test/ui/llvm-asm/llvm-asm-misplaced-option.rs
|
||||||
|
@@ -5,6 +5,7 @@
|
||||||
|
// ignore-s390x
|
||||||
|
// ignore-emscripten
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-riscv64
|
||||||
|
diff --git a/src/test/ui/llvm-asm/llvm-asm-out-assign-imm.rs b/src/test/ui/llvm-asm/llvm-asm-out-assign-imm.rs
|
||||||
|
index 9c62532c..baa1c1ba 100644
|
||||||
|
--- a/src/test/ui/llvm-asm/llvm-asm-out-assign-imm.rs
|
||||||
|
+++ b/src/test/ui/llvm-asm/llvm-asm-out-assign-imm.rs
|
||||||
|
@@ -1,6 +1,7 @@
|
||||||
|
// ignore-s390x
|
||||||
|
// ignore-emscripten
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-riscv64
|
||||||
|
diff --git a/src/test/ui/llvm-asm/llvm-asm-out-no-modifier.rs b/src/test/ui/llvm-asm/llvm-asm-out-no-modifier.rs
|
||||||
|
index 72edb339..2fec991d 100644
|
||||||
|
--- a/src/test/ui/llvm-asm/llvm-asm-out-no-modifier.rs
|
||||||
|
+++ b/src/test/ui/llvm-asm/llvm-asm-out-no-modifier.rs
|
||||||
|
@@ -1,6 +1,7 @@
|
||||||
|
// ignore-s390x
|
||||||
|
// ignore-emscripten
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-riscv64
|
||||||
|
diff --git a/src/test/ui/llvm-asm/llvm-asm-out-read-uninit.rs b/src/test/ui/llvm-asm/llvm-asm-out-read-uninit.rs
|
||||||
|
index acf4cf9f..dfad0775 100644
|
||||||
|
--- a/src/test/ui/llvm-asm/llvm-asm-out-read-uninit.rs
|
||||||
|
+++ b/src/test/ui/llvm-asm/llvm-asm-out-read-uninit.rs
|
||||||
|
@@ -1,6 +1,7 @@
|
||||||
|
// ignore-s390x
|
||||||
|
// ignore-emscripten
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-riscv64
|
||||||
|
diff --git a/src/test/ui/target-feature/gate.rs b/src/test/ui/target-feature/gate.rs
|
||||||
|
index 164830fe..531a4b45 100644
|
||||||
|
--- a/src/test/ui/target-feature/gate.rs
|
||||||
|
+++ b/src/test/ui/target-feature/gate.rs
|
||||||
|
@@ -5,6 +5,7 @@
|
||||||
|
// ignore-mips
|
||||||
|
// ignore-mips64
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-riscv64
|
||||||
|
diff --git a/src/test/ui/target-feature/invalid-attribute.rs b/src/test/ui/target-feature/invalid-attribute.rs
|
||||||
|
index 5ea78215..47e7887a 100644
|
||||||
|
--- a/src/test/ui/target-feature/invalid-attribute.rs
|
||||||
|
+++ b/src/test/ui/target-feature/invalid-attribute.rs
|
||||||
|
@@ -5,6 +5,7 @@
|
||||||
|
// ignore-mips
|
||||||
|
// ignore-mips64
|
||||||
|
// ignore-powerpc
|
||||||
|
+// ignore-powerpcle
|
||||||
|
// ignore-powerpc64
|
||||||
|
// ignore-powerpc64le
|
||||||
|
// ignore-riscv64
|
||||||
|
diff --git a/src/tools/compiletest/src/util.rs b/src/tools/compiletest/src/util.rs
|
||||||
|
index 7dbd7094..08c9de3c 100644
|
||||||
|
--- a/src/tools/compiletest/src/util.rs
|
||||||
|
+++ b/src/tools/compiletest/src/util.rs
|
||||||
|
@@ -67,6 +67,7 @@ const ARCH_TABLE: &[(&str, &str)] = &[
|
||||||
|
("msp430", "msp430"),
|
||||||
|
("nvptx64", "nvptx64"),
|
||||||
|
("powerpc", "powerpc"),
|
||||||
|
+ ("powerpcle", "powerpc"),
|
||||||
|
("powerpc64", "powerpc64"),
|
||||||
|
("powerpc64le", "powerpc64"),
|
||||||
|
("riscv64gc", "riscv64"),
|
||||||
|
diff --git a/vendor/cc-1.0.60/src/lib.rs b/vendor/cc-1.0.60/src/lib.rs
|
||||||
|
index f428ecbb..841e459a 100644
|
||||||
|
--- a/vendor/cc-1.0.60/src/lib.rs
|
||||||
|
+++ b/vendor/cc-1.0.60/src/lib.rs
|
||||||
|
@@ -2302,6 +2302,7 @@ impl Build {
|
||||||
|
"mipsisa64r6-unknown-linux-gnuabi64" => Some("mipsisa64r6-linux-gnuabi64"),
|
||||||
|
"mipsisa64r6el-unknown-linux-gnuabi64" => Some("mipsisa64r6el-linux-gnuabi64"),
|
||||||
|
"powerpc-unknown-linux-gnu" => Some("powerpc-linux-gnu"),
|
||||||
|
+ "powerpcle-unknown-linux-gnu" => Some("powerpcle-linux-gnu"),
|
||||||
|
"powerpc-unknown-linux-gnuspe" => Some("powerpc-linux-gnuspe"),
|
||||||
|
"powerpc-unknown-netbsd" => Some("powerpc--netbsd"),
|
||||||
|
"powerpc64-unknown-linux-gnu" => Some("powerpc-linux-gnu"),
|
||||||
|
diff --git a/vendor/cc/src/lib.rs b/vendor/cc/src/lib.rs
|
||||||
|
index 5051b296..286c2fb7 100644
|
||||||
|
--- a/vendor/cc/src/lib.rs
|
||||||
|
+++ b/vendor/cc/src/lib.rs
|
||||||
|
@@ -2409,6 +2409,7 @@ impl Build {
|
||||||
|
"powerpc-unknown-linux-gnu" => Some("powerpc-linux-gnu"),
|
||||||
|
"powerpc-unknown-linux-gnuspe" => Some("powerpc-linux-gnuspe"),
|
||||||
|
"powerpc-unknown-netbsd" => Some("powerpc--netbsd"),
|
||||||
|
+ "powerpcle-unknown-linux-gnu" => Some("powerpcle-linux-gnu"),
|
||||||
|
"powerpc64-unknown-linux-gnu" => Some("powerpc-linux-gnu"),
|
||||||
|
"powerpc64le-unknown-linux-gnu" => Some("powerpc64le-linux-gnu"),
|
||||||
|
"riscv32i-unknown-none-elf" => self.find_working_gnu_prefix(&[
|
||||||
|
diff --git a/vendor/gcc/src/lib.rs b/vendor/gcc/src/lib.rs
|
||||||
|
index 1fe73012..7980281f 100644
|
||||||
|
--- a/vendor/gcc/src/lib.rs
|
||||||
|
+++ b/vendor/gcc/src/lib.rs
|
||||||
|
@@ -1367,7 +1367,8 @@ impl Build {
|
||||||
|
"mips64el-unknown-linux-gnuabi64" => Some("mips64el-linux-gnuabi64"),
|
||||||
|
"powerpc-unknown-linux-gnu" => Some("powerpc-linux-gnu"),
|
||||||
|
"powerpc-unknown-netbsd" => Some("powerpc--netbsd"),
|
||||||
|
- "powerpc64-unknown-linux-gnu" => Some("powerpc-linux-gnu"),
|
||||||
|
+ "powerpcle-unknown-linux-gnu" => Some("powerpcle-linux-gnu"),
|
||||||
|
+ "powerpc64-unknown-linux-gnu" => Some("powerpc64-linux-gnu"),
|
||||||
|
"powerpc64le-unknown-linux-gnu" => Some("powerpc64le-linux-gnu"),
|
||||||
|
"s390x-unknown-linux-gnu" => Some("s390x-linux-gnu"),
|
||||||
|
"sparc64-unknown-netbsd" => Some("sparc64--netbsd"),
|
||||||
|
diff --git a/vendor/jemallocator/benches/roundtrip.rs b/vendor/jemallocator/benches/roundtrip.rs
|
||||||
|
index eddbb6bb..db81596b 100644
|
||||||
|
--- a/vendor/jemallocator/benches/roundtrip.rs
|
||||||
|
+++ b/vendor/jemallocator/benches/roundtrip.rs
|
||||||
|
@@ -26,7 +26,8 @@ static A: Jemalloc = Jemalloc;
|
||||||
|
target_arch = "arm",
|
||||||
|
target_arch = "mips",
|
||||||
|
target_arch = "mipsel",
|
||||||
|
- target_arch = "powerpc"
|
||||||
|
+ target_arch = "powerpc",
|
||||||
|
+ target_arch = "powerpcle"
|
||||||
|
)))]
|
||||||
|
const MIN_ALIGN: usize = 8;
|
||||||
|
#[cfg(all(any(
|
||||||
|
diff --git a/vendor/jemallocator/src/lib.rs b/vendor/jemallocator/src/lib.rs
|
||||||
|
index f0a3692d..43889c55 100644
|
||||||
|
--- a/vendor/jemallocator/src/lib.rs
|
||||||
|
+++ b/vendor/jemallocator/src/lib.rs
|
||||||
|
@@ -37,7 +37,8 @@ use libc::{c_int, c_void};
|
||||||
|
target_arch = "arm",
|
||||||
|
target_arch = "mips",
|
||||||
|
target_arch = "mipsel",
|
||||||
|
- target_arch = "powerpc"
|
||||||
|
+ target_arch = "powerpc",
|
||||||
|
+ target_arch = "powerpcle"
|
||||||
|
)))]
|
||||||
|
const MIN_ALIGN: usize = 8;
|
||||||
|
#[cfg(all(any(
|
||||||
|
diff --git a/vendor/rustc-ap-rustc_target/src/spec/mod.rs b/vendor/rustc-ap-rustc_target/src/spec/mod.rs
|
||||||
|
index 2af46693..986d84e0 100644
|
||||||
|
--- a/vendor/rustc-ap-rustc_target/src/spec/mod.rs
|
||||||
|
+++ b/vendor/rustc-ap-rustc_target/src/spec/mod.rs
|
||||||
|
@@ -716,6 +716,8 @@ supported_targets! {
|
||||||
|
("powerpc-unknown-linux-gnu", powerpc_unknown_linux_gnu),
|
||||||
|
("powerpc-unknown-linux-gnuspe", powerpc_unknown_linux_gnuspe),
|
||||||
|
("powerpc-unknown-linux-musl", powerpc_unknown_linux_musl),
|
||||||
|
+ ("powerpcle-unknown-linux-gnu", powerpcle_unknown_linux_gnu),
|
||||||
|
+ ("powerpcle-unknown-linux-musl", powerpcle_unknown_linux_musl),
|
||||||
|
("powerpc64-unknown-linux-gnu", powerpc64_unknown_linux_gnu),
|
||||||
|
("powerpc64-unknown-linux-musl", powerpc64_unknown_linux_musl),
|
||||||
|
("powerpc64le-unknown-linux-gnu", powerpc64le_unknown_linux_gnu),
|
||||||
|
diff --git a/vendor/rustc-ap-rustc_target/src/spec/powerpcle_unknown_linux_gnu.rs b/vendor/rustc-ap-rustc_target/src/spec/powerpcle_unknown_linux_gnu.rs
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..780c20a3
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/vendor/rustc-ap-rustc_target/src/spec/powerpcle_unknown_linux_gnu.rs
|
||||||
|
@@ -0,0 +1,15 @@
|
||||||
|
+use crate::spec::{LinkerFlavor, Target, TargetOptions};
|
||||||
|
+
|
||||||
|
+pub fn target() -> Target {
|
||||||
|
+ let mut base = super::linux_gnu_base::opts();
|
||||||
|
+ base.pre_link_args.entry(LinkerFlavor::Gcc).or_default().push("-m32".to_string());
|
||||||
|
+ base.max_atomic_width = Some(32);
|
||||||
|
+
|
||||||
|
+ Target {
|
||||||
|
+ llvm_target: "powerpcle-unknown-linux-gnu".to_string(),
|
||||||
|
+ pointer_width: 32,
|
||||||
|
+ data_layout: "e-m:e-p:32:32-i64:64-n32".to_string(),
|
||||||
|
+ arch: "powerpc".to_string(),
|
||||||
|
+ options: TargetOptions { mcount: "_mcount".to_string(), ..base },
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
diff --git a/vendor/rustc-ap-rustc_target/src/spec/powerpcle_unknown_linux_musl.rs b/vendor/rustc-ap-rustc_target/src/spec/powerpcle_unknown_linux_musl.rs
|
||||||
|
new file mode 100644
|
||||||
|
index 00000000..9b848ccf
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/vendor/rustc-ap-rustc_target/src/spec/powerpcle_unknown_linux_musl.rs
|
||||||
|
@@ -0,0 +1,15 @@
|
||||||
|
+use crate::spec::{LinkerFlavor, Target, TargetOptions};
|
||||||
|
+
|
||||||
|
+pub fn target() -> Target {
|
||||||
|
+ let mut base = super::linux_musl_base::opts();
|
||||||
|
+ base.pre_link_args.entry(LinkerFlavor::Gcc).or_default().push("-m32".to_string());
|
||||||
|
+ base.max_atomic_width = Some(32);
|
||||||
|
+
|
||||||
|
+ Target {
|
||||||
|
+ llvm_target: "powerpcle-unknown-linux-musl".to_string(),
|
||||||
|
+ pointer_width: 32,
|
||||||
|
+ data_layout: "e-m:e-p:32:32-i64:64-n32".to_string(),
|
||||||
|
+ arch: "powerpc".to_string(),
|
||||||
|
+ options: TargetOptions { mcount: "_mcount".to_string(), ..base },
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
diff --git a/vendor/target-lexicon/src/targets.rs b/vendor/target-lexicon/src/targets.rs
|
||||||
|
index 87c237aa..dc694010 100644
|
||||||
|
--- a/vendor/target-lexicon/src/targets.rs
|
||||||
|
+++ b/vendor/target-lexicon/src/targets.rs
|
||||||
|
@@ -26,6 +26,7 @@ pub enum Architecture {
|
||||||
|
Msp430,
|
||||||
|
Nvptx64,
|
||||||
|
Powerpc,
|
||||||
|
+ Powerpcle,
|
||||||
|
Powerpc64,
|
||||||
|
Powerpc64le,
|
||||||
|
Riscv32(Riscv32Architecture),
|
||||||
|
@@ -517,6 +518,7 @@ impl Architecture {
|
||||||
|
| Mips64(Mips64Architecture::Mipsisa64r6el)
|
||||||
|
| Msp430
|
||||||
|
| Nvptx64
|
||||||
|
+ | Powerpcle
|
||||||
|
| Powerpc64le
|
||||||
|
| Riscv32(_)
|
||||||
|
| Riscv64(_)
|
||||||
|
@@ -553,6 +555,7 @@ impl Architecture {
|
||||||
|
| Sparc
|
||||||
|
| Wasm32
|
||||||
|
| Mips32(_)
|
||||||
|
+ | Powerpcle
|
||||||
|
| Powerpc => Ok(PointerWidth::U32),
|
||||||
|
AmdGcn
|
||||||
|
| Powerpc64le
|
||||||
|
@@ -737,6 +740,7 @@ impl fmt::Display for Architecture {
|
||||||
|
Msp430 => f.write_str("msp430"),
|
||||||
|
Nvptx64 => f.write_str("nvptx64"),
|
||||||
|
Powerpc => f.write_str("powerpc"),
|
||||||
|
+ Powerpcle => f.write_str("powerpcle"),
|
||||||
|
Powerpc64 => f.write_str("powerpc64"),
|
||||||
|
Powerpc64le => f.write_str("powerpc64le"),
|
||||||
|
Riscv32(riscv32) => riscv32.fmt(f),
|
||||||
|
@@ -913,6 +917,7 @@ impl FromStr for Architecture {
|
||||||
|
"msp430" => Msp430,
|
||||||
|
"nvptx64" => Nvptx64,
|
||||||
|
"powerpc" => Powerpc,
|
||||||
|
+ "powerpcle" => Powerpcle,
|
||||||
|
"powerpc64" => Powerpc64,
|
||||||
|
"powerpc64le" => Powerpc64le,
|
||||||
|
"s390x" => S390x,
|
||||||
|
@@ -1380,6 +1385,8 @@ mod tests {
|
||||||
|
"powerpc-unknown-netbsd",
|
||||||
|
"powerpc-wrs-vxworks",
|
||||||
|
"powerpc-wrs-vxworks-spe",
|
||||||
|
+ "powerpcle-unknown-linux-gnu",
|
||||||
|
+ "powerpcle-unknown-linux-musl",
|
||||||
|
"powerpc64-unknown-freebsd",
|
||||||
|
"powerpc64-unknown-linux-gnu",
|
||||||
|
"powerpc64-unknown-linux-musl",
|
||||||
|
diff --git a/vendor/tikv-jemallocator/benches/roundtrip.rs b/vendor/tikv-jemallocator/benches/roundtrip.rs
|
||||||
|
index 40b8005f..bc4df023 100644
|
||||||
|
--- a/vendor/tikv-jemallocator/benches/roundtrip.rs
|
||||||
|
+++ b/vendor/tikv-jemallocator/benches/roundtrip.rs
|
||||||
|
@@ -22,7 +22,8 @@ static A: Jemalloc = Jemalloc;
|
||||||
|
target_arch = "arm",
|
||||||
|
target_arch = "mips",
|
||||||
|
target_arch = "mipsel",
|
||||||
|
- target_arch = "powerpc"
|
||||||
|
+ target_arch = "powerpc",
|
||||||
|
+ target_arch = "powerpcle",
|
||||||
|
)))]
|
||||||
|
const MIN_ALIGN: usize = 8;
|
||||||
|
#[cfg(all(any(
|
||||||
|
diff --git a/vendor/tikv-jemallocator/src/lib.rs b/vendor/tikv-jemallocator/src/lib.rs
|
||||||
|
index 9a489b62..1ed12b26 100644
|
||||||
|
--- a/vendor/tikv-jemallocator/src/lib.rs
|
||||||
|
+++ b/vendor/tikv-jemallocator/src/lib.rs
|
||||||
|
@@ -44,7 +44,8 @@ use libc::{c_int, c_void};
|
||||||
|
target_arch = "arm",
|
||||||
|
target_arch = "mips",
|
||||||
|
target_arch = "mipsel",
|
||||||
|
- target_arch = "powerpc"
|
||||||
|
+ target_arch = "powerpc",
|
||||||
|
+ target_arch = "powerpcle"
|
||||||
|
)))]
|
||||||
|
const ALIGNOF_MAX_ALIGN_T: usize = 8;
|
||||||
|
#[cfg(all(any(
|
||||||
|
--
|
||||||
|
2.32.0
|
||||||
|
|
|
@ -8,24 +8,31 @@
|
||||||
# uploaded to https://alpha.de.repo.voidlinux.org/distfiles/
|
# uploaded to https://alpha.de.repo.voidlinux.org/distfiles/
|
||||||
#
|
#
|
||||||
pkgname=rust
|
pkgname=rust
|
||||||
version=1.48.0
|
version=1.53.0
|
||||||
revision=1
|
revision=1
|
||||||
_rust_dist_version=1.48.0
|
_rust_dist_version=1.53.0
|
||||||
wrksrc="rustc-${version}-src"
|
wrksrc="rustc-${version}-src"
|
||||||
hostmakedepends="cmake curl pkg-config python3 tar"
|
hostmakedepends="cmake curl pkg-config python3 tar"
|
||||||
makedepends="libffi-devel ncurses-devel libxml2-devel zlib-devel llvm11"
|
makedepends="libffi-devel ncurses-devel libxml2-devel zlib-devel llvm12"
|
||||||
depends="rust-std"
|
depends="rust-std"
|
||||||
short_desc="Safe, concurrent, practical systems language"
|
short_desc="Safe, concurrent, practical systems language"
|
||||||
maintainer="Enno Boland <gottox@voidlinux.org>"
|
maintainer="Enno Boland <gottox@voidlinux.org>"
|
||||||
license="MIT, Apache-2.0"
|
license="MIT, Apache-2.0"
|
||||||
homepage="https://www.rust-lang.org/"
|
homepage="https://www.rust-lang.org/"
|
||||||
distfiles="https://static.rust-lang.org/dist/rustc-${version}-src.tar.gz"
|
distfiles="https://static.rust-lang.org/dist/rustc-${version}-src.tar.gz"
|
||||||
checksum="0e763e6db47d5d6f91583284d2f989eacc49b84794d1443355b85c58d67ae43b"
|
checksum=5cf7ca39a10f6bf4e0b0bd15e3b9a61ce721f301e12d148262e5ba968ab825b9
|
||||||
lib32disabled=yes
|
lib32disabled=yes
|
||||||
|
|
||||||
build_options="bindist"
|
build_options="bindist"
|
||||||
desc_option_bindist="Generate tarballs for bootstrap"
|
desc_option_bindist="Generate tarballs for bootstrap"
|
||||||
|
|
||||||
|
if [ "$XBPS_LIBC" = "musl" ]; then
|
||||||
|
hostmakedepends+=" libexecinfo-devel"
|
||||||
|
fi
|
||||||
|
if [ "$XBPS_TARGET_LIBC" = "musl" ]; then
|
||||||
|
makedepends+=" libexecinfo-devel"
|
||||||
|
fi
|
||||||
|
|
||||||
# rust upstream no longer ships cargo-versioned tarballs
|
# rust upstream no longer ships cargo-versioned tarballs
|
||||||
# need to use the corresponding rust version instead
|
# need to use the corresponding rust version instead
|
||||||
_bootstrap_url="https://static.rust-lang.org/dist"
|
_bootstrap_url="https://static.rust-lang.org/dist"
|
||||||
|
@ -37,7 +44,7 @@ case "$XBPS_MACHINE" in
|
||||||
ppc*)
|
ppc*)
|
||||||
# custom bootstrap tarballs still use cargo versioning, so override
|
# custom bootstrap tarballs still use cargo versioning, so override
|
||||||
_bootstrap_url="https://alpha.de.repo.voidlinux.org/distfiles"
|
_bootstrap_url="https://alpha.de.repo.voidlinux.org/distfiles"
|
||||||
_cargo_dist_version="0.49.0"
|
_cargo_dist_version="0.54.0"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
@ -48,39 +55,39 @@ distfiles+=" ${_bootstrap_url}/cargo-${_cargo_dist_version}-${RUST_BUILD}.tar.xz
|
||||||
case "$XBPS_MACHINE" in
|
case "$XBPS_MACHINE" in
|
||||||
i686)
|
i686)
|
||||||
checksum+="
|
checksum+="
|
||||||
1eab76df91e87198632605752d0dd66f3d84b502cbd1f982f6db3d0d8d943cdb"
|
deebb4a4de22a60f0dec5d5b84e8dfe6ce039835935dae96477a79468aefd927"
|
||||||
;;
|
;;
|
||||||
x86_64)
|
x86_64)
|
||||||
checksum+="
|
checksum+="
|
||||||
b11d595581e2580c069b5039214e1031a0e4f87ff6490ac39f92f77857e37055"
|
e4437f6c83574fc60e183f4df439190f7610e4a669476802795645da66fbb83b"
|
||||||
;;
|
;;
|
||||||
x86_64-musl)
|
x86_64-musl)
|
||||||
checksum+="
|
checksum+="
|
||||||
8728cb7515e593f6fcf3c7afba826a92cd227a35b8e936bae892b95482d4fb90"
|
ca236408cb2c35b8c3f7c2b4e9f1e69422ed24153f445192eafb6462351e5c2b"
|
||||||
;;
|
;;
|
||||||
ppc64le)
|
ppc64le)
|
||||||
checksum+="
|
checksum+="
|
||||||
675321cf812a132ce707261d03aab2f5ff64788ae66b45d03bc281514f5d53ec"
|
ca1d94161c3a4021bca170ba4ca059b5606fcd70934aca89d8cea43746880ba7"
|
||||||
;;
|
;;
|
||||||
ppc64le-musl)
|
ppc64le-musl)
|
||||||
checksum+="
|
checksum+="
|
||||||
cf02e057f04e40458b63326e443c48924c78fc33dcb6b892643d47feb1496b09"
|
1181b721addeb2aa471bf71549a7fb09f27167c382b480cefba272f770b9f039"
|
||||||
;;
|
;;
|
||||||
ppc64)
|
ppc64)
|
||||||
checksum+="
|
checksum+="
|
||||||
1e7612ea1900b76924429fa04fa2c194f4213167933b481001290dd4fef27939"
|
7d9b0428d4cd8cdd76582b3113476228013ec0b674802f18b4b5e8bbefcd3ab2"
|
||||||
;;
|
;;
|
||||||
ppc64-musl)
|
ppc64-musl)
|
||||||
checksum+="
|
checksum+="
|
||||||
88ffadd53e79055ba266f1303d502bcf1ef863783b121aa017930cadcd0e398d"
|
695d687c19a729504ac8b57a42e395258a8b801753baf1b0b17755d7f38f7eaa"
|
||||||
;;
|
;;
|
||||||
ppc)
|
ppc)
|
||||||
checksum+="
|
checksum+="
|
||||||
cacacdec7bfd24345804efdd1bd1682084880c3c6a086bcab85cd1186b6cd230"
|
176f178b9e55f399311edb4888d931e5f696766f655cc9648ae4b6ef1bdc8369"
|
||||||
;;
|
;;
|
||||||
ppc-musl)
|
ppc-musl)
|
||||||
checksum+="
|
checksum+="
|
||||||
bad4a5d22da3c7548fd440d0d5a0b98e4de9894dedb35bfb58aaa5f141c23adb"
|
234cf0792407065f4c5c4276886846cee2ecfb37eea1171c2c6e4a0fba7d324c"
|
||||||
;;
|
;;
|
||||||
*) broken="cargo bootstrap binary unavailable for ${XBPS_MACHINE}";;
|
*) broken="cargo bootstrap binary unavailable for ${XBPS_MACHINE}";;
|
||||||
esac
|
esac
|
||||||
|
@ -92,7 +99,7 @@ _bootstrap_dir="stage0-bootstrap"
|
||||||
# cut down the build time (the local-rebuild property is enabled for cross)
|
# cut down the build time (the local-rebuild property is enabled for cross)
|
||||||
|
|
||||||
if [ "$CROSS_BUILD" ]; then
|
if [ "$CROSS_BUILD" ]; then
|
||||||
hostmakedepends+=" rust llvm11"
|
hostmakedepends+=" rust llvm12"
|
||||||
# These are required for building the buildhost's stage0/1
|
# These are required for building the buildhost's stage0/1
|
||||||
hostmakedepends+=" libffi-devel libxml2-devel ncurses-devel zlib-devel"
|
hostmakedepends+=" libffi-devel libxml2-devel ncurses-devel zlib-devel"
|
||||||
else
|
else
|
||||||
|
@ -103,48 +110,48 @@ else
|
||||||
case "$XBPS_MACHINE" in
|
case "$XBPS_MACHINE" in
|
||||||
i686)
|
i686)
|
||||||
checksum+="
|
checksum+="
|
||||||
c241405350bf6f88224db7040012ce25351b332d6deffec07a9b5a958ab19a28
|
93b05456ea8500864e020cfbb1dfbe0a93651406432b6950013f87b91ea6ff47
|
||||||
d4ea5ca6f9c8f9092b50c879f1d9a2620486f08020fa4cac227743a19f6e8cdf"
|
d63690da8adb531bb92e76e211b37d3cf941fa841eaaaa210cce4cd6301ca64a"
|
||||||
;;
|
;;
|
||||||
x86_64)
|
x86_64)
|
||||||
checksum+="
|
checksum+="
|
||||||
fc4d292a52cbb6b84fb9f065d0d7596064a9b957381d639d5a750d6e2bf02483
|
9c2f0443a546dd18f1f020c7711a7b9864432545ceb812e79315c1e76508b193
|
||||||
1c00a6a0dabbf6290728b09f9307d9fa6cc985487f727075c68acd4a600ef3f8"
|
66d5257bbd194db08e67ca63a74cc80cdc4a36eaa30bf7dfe65861d9deaff7f7"
|
||||||
;;
|
;;
|
||||||
x86_64-musl)
|
x86_64-musl)
|
||||||
checksum+="
|
checksum+="
|
||||||
50c2904db7794400987487ea364392714830f287f3e596a9f8ea9df748dfa8a3
|
50de8b4bcb0819ec0ca363e0aa53fc1c55bc85f53bc82da8dce20a132da7e7d9
|
||||||
4f485d8800f90898705686b873765a4c0fe909d1127d5b091a01979bc32f01c0"
|
413449866616b1cd048da1356a41d977bf4e037cce114f07c3afbb0497b3e4c6"
|
||||||
;;
|
;;
|
||||||
ppc64le)
|
ppc64le)
|
||||||
checksum+="
|
checksum+="
|
||||||
bf06c20e09c66391c19de4319de64621c82787e5e44a40ec25fb565a4c6caf28
|
7624a5bf09bcaddc90851928d604e78ad9896b041ad1124b064a716b7250b42b
|
||||||
e42b64c5710d3982f22ed744ea21ef2f0196df908c6a673b6df550904583b1c3"
|
d29a9c16a52f3a5767733597efdb9cc1e3cb390961b11cf1d1792b48939de5ed"
|
||||||
;;
|
;;
|
||||||
ppc64le-musl)
|
ppc64le-musl)
|
||||||
checksum+="
|
checksum+="
|
||||||
f6967f8afe25f6beff65f2e139babc253de2c40edf556f615e380f50b4a31da8
|
09cd44fed6bf2d7ac0d180fc1374022deeb08be1d245ee26d1cfccc62658d22f
|
||||||
96311452bb46a855b7afe5883f619d4b768f14c7a5d5de01e15e146fb05d6d59"
|
c283d604807f1c00e95a5122352941a64a26c3031ff41b80d395ac01ab55aa80"
|
||||||
;;
|
;;
|
||||||
ppc64)
|
ppc64)
|
||||||
checksum+="
|
checksum+="
|
||||||
13764a670b15480d1d850cc8ae3576536265e1fcac869c1a8fa72a8ebd059193
|
3136af38b2413524f02bbf1377c32c82f5f3791c5f78b926d7d74ef667349a69
|
||||||
5ce4b14e8895d995c24d3f8706ea9bb6a3ee153bd8d8cec8d808ad66e62162bc"
|
a01e07e15e151f5c6fdd7f3f167fa96326ea8fffdce402a3dbb9687f33ae5ccc"
|
||||||
;;
|
;;
|
||||||
ppc64-musl)
|
ppc64-musl)
|
||||||
checksum+="
|
checksum+="
|
||||||
6b2485c27be4a3d390e8dd4153381304ec3883eb0d9543835b29e0a471e9d4f0
|
5dbcb8ca33874d7a82543b4f9d9f1c51e5680a998b0b572119e8be6b8ae4f566
|
||||||
e5e513fe1e660856b4a7b133c99c23468bf781b93c69e7a098f600bcb91ce9bb"
|
5f03e215507313d14fc5275ba6951d3d7590634909def352504f52ad57c24dc3"
|
||||||
;;
|
;;
|
||||||
ppc)
|
ppc)
|
||||||
checksum+="
|
checksum+="
|
||||||
4ea76c15c7225ab113c391fb7640786decf706e256fb9338e5b0c2763286777c
|
be6ca5e02c04329b082eaf717ba2ea370d676a93e520cd5988883ea2ed8cb750
|
||||||
5682d27ffc6f6c1655987e154f5425f9114516e22b7797c9e81bf038ffffad21"
|
6006f7f78e30810e8b929ab5ab97cf5e4488a25f7fe6a49a1a548dd4745281e0"
|
||||||
;;
|
;;
|
||||||
ppc-musl)
|
ppc-musl)
|
||||||
checksum+="
|
checksum+="
|
||||||
4147cae868df4e936409331ee9e2d81d47529d05a7a2e045d7f566e09eb4f302
|
6ecf74e3718bfc03a09ece82a246c9fe268bbb9a7d96cb7d65b579a824e5e1d9
|
||||||
20132e5c67a67399e7945ba17d698a6aa1833f87b89bfc8a5a1678d75cfc637d"
|
17d14e51263e253ba082fc0b05f887dad7d16c705304514aa3268904ac472d29"
|
||||||
;;
|
;;
|
||||||
*) broken="rust bootstrap binaries unavailable for ${XBPS_MACHINE}";;
|
*) broken="rust bootstrap binaries unavailable for ${XBPS_MACHINE}";;
|
||||||
esac
|
esac
|
||||||
|
@ -182,6 +189,13 @@ post_patch() {
|
||||||
# clear out all the checksum nonsense of patched vendor crates
|
# clear out all the checksum nonsense of patched vendor crates
|
||||||
_clear_vendor_checksums libc
|
_clear_vendor_checksums libc
|
||||||
_clear_vendor_checksums typenum
|
_clear_vendor_checksums typenum
|
||||||
|
_clear_vendor_checksums cc-1.0.60
|
||||||
|
_clear_vendor_checksums gcc
|
||||||
|
_clear_vendor_checksums cc
|
||||||
|
_clear_vendor_checksums jemallocator
|
||||||
|
_clear_vendor_checksums rustc-ap-rustc_target
|
||||||
|
_clear_vendor_checksums target-lexicon
|
||||||
|
_clear_vendor_checksums tikv-jemallocator
|
||||||
}
|
}
|
||||||
|
|
||||||
do_configure() {
|
do_configure() {
|
||||||
|
@ -253,7 +267,7 @@ do_configure() {
|
||||||
verbose-tests = true
|
verbose-tests = true
|
||||||
dist-src = false
|
dist-src = false
|
||||||
jemalloc = false
|
jemalloc = false
|
||||||
llvm-libunwind = false
|
llvm-libunwind = "no"
|
||||||
codegen-tests = false
|
codegen-tests = false
|
||||||
[dist]
|
[dist]
|
||||||
src-tarball = false
|
src-tarball = false
|
||||||
|
@ -302,12 +316,9 @@ do_check() {
|
||||||
python3 x.py test ${makejobs} --no-doc --no-fail-fast \
|
python3 x.py test ${makejobs} --no-doc --no-fail-fast \
|
||||||
src/test/codegen \
|
src/test/codegen \
|
||||||
src/test/codegen-units \
|
src/test/codegen-units \
|
||||||
src/test/compile-fail \
|
|
||||||
src/test/incremental \
|
src/test/incremental \
|
||||||
src/test/mir-opt \
|
src/test/mir-opt \
|
||||||
src/test/pretty \
|
src/test/pretty \
|
||||||
src/test/run-fail \
|
|
||||||
src/test/run-fail/pretty \
|
|
||||||
src/test/run-make \
|
src/test/run-make \
|
||||||
src/test/run-make-fulldeps \
|
src/test/run-make-fulldeps \
|
||||||
src/test/ui \
|
src/test/ui \
|
||||||
|
@ -342,6 +353,12 @@ do_install() {
|
||||||
# symlinks instead of copies
|
# symlinks instead of copies
|
||||||
mv *.so rustlib/${RUST_TARGET}/lib
|
mv *.so rustlib/${RUST_TARGET}/lib
|
||||||
ln -sf rustlib/${RUST_TARGET}/lib/*.so .
|
ln -sf rustlib/${RUST_TARGET}/lib/*.so .
|
||||||
|
|
||||||
|
# executable used for split dwarf, currently unstable on linux.
|
||||||
|
# it's copied directly from the local llvm package, but
|
||||||
|
# FIXME: cross builds are installing the version from the build machine,
|
||||||
|
# it shouldn't be necessary to remove it
|
||||||
|
rm rustlib/${RUST_TARGET}/bin/rust-llvm-dwp
|
||||||
}
|
}
|
||||||
|
|
||||||
rust-doc_package() {
|
rust-doc_package() {
|
||||||
|
@ -353,6 +370,9 @@ rust-doc_package() {
|
||||||
|
|
||||||
rust-std_package() {
|
rust-std_package() {
|
||||||
short_desc+=" - standard library"
|
short_desc+=" - standard library"
|
||||||
|
if [ "$XBPS_TARGET_LIBC" = "musl" ]; then
|
||||||
|
depends="libexecinfo-devel"
|
||||||
|
fi
|
||||||
pkg_install() {
|
pkg_install() {
|
||||||
vmove usr/lib/rustlib
|
vmove usr/lib/rustlib
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue