From 5a8b3306a3a07bea60f62a43dd684d6a66781375 Mon Sep 17 00:00:00 2001 From: Josh Stone Date: Fri, 2 Sep 2016 21:12:41 -0700 Subject: [PATCH] Bootstrap armv7hl, with backported no-neon patch. --- rust-pr35814-armv7-no-neon.patch | 32 ++++++++++++++++++++++++++++++++ rust.spec | 24 +++++++++++++++++------- 2 files changed, 49 insertions(+), 7 deletions(-) create mode 100644 rust-pr35814-armv7-no-neon.patch diff --git a/rust-pr35814-armv7-no-neon.patch b/rust-pr35814-armv7-no-neon.patch new file mode 100644 index 0000000..720e5c1 --- /dev/null +++ b/rust-pr35814-armv7-no-neon.patch @@ -0,0 +1,32 @@ +commit f5499a001d9cbde6a672f9d393d9c80c63745f00 (from 0ccd5c802b94fc9206e4ce27a9fbd4bebc66a771) +Merge: 0ccd5c802b94 1cf510d1decf +Author: bors +Date: Wed Aug 24 23:05:47 2016 -0700 + + Auto merge of #35814 - alexcrichton:armv7-no-neon, r=brson + + rustc: Don't enable NEON by default on armv7 Linux + + One of the primary platforms for the `armv7-unknown-linux-gnueabihf` target, + Linux distributions, do not enable NEON extensions by default. This PR disables + that feature by defualt but enables the `d16` feature which enables VFP3D16 that + distributions do enable. + + Closes #35590 + +diff --git a/src/librustc_back/target/armv7_unknown_linux_gnueabihf.rs b/src/librustc_back/target/armv7_unknown_linux_gnueabihf.rs +index 52269f0cd4a0..7e0306a03e2f 100644 +--- a/src/librustc_back/target/armv7_unknown_linux_gnueabihf.rs ++++ b/src/librustc_back/target/armv7_unknown_linux_gnueabihf.rs +@@ -23,8 +23,9 @@ pub fn target() -> TargetResult { + target_vendor: "unknown".to_string(), + + options: TargetOptions { +- features: "+v7,+vfp3,+neon".to_string(), +- cpu: "cortex-a8".to_string(), ++ // Info about features at https://wiki.debian.org/ArmHardFloatPort ++ features: "+v7,+vfp3,+d16,+thumb2".to_string(), ++ cpu: "generic".to_string(), + max_atomic_width: 64, + .. base + } diff --git a/rust.spec b/rust.spec index 33d702e..25bddbc 100644 --- a/rust.spec +++ b/rust.spec @@ -4,14 +4,14 @@ # To bootstrap from scratch, set the channel and date from src/stage0.txt # e.g. 1.10.0 wants rustc: 1.9.0-2016-05-24 # or nightly wants some beta-YYYY-MM-DD -%bcond_with bootstrap +%bcond_without bootstrap %global bootstrap_channel 1.10.0 %global bootstrap_date 2016-07-05 # Use "rebuild" when building with a distro rustc of the same version. # Turn this off when the distro has the prior release, matching bootstrap. # Note, 1.12 will be able to autodetect this via PR34779. -%bcond_with rebuild +%bcond_without rebuild # The script for minidebuginfo copies symbols and *notes* into a "mini" # ELF object compressed into the .gnu_debugdata section. This includes our @@ -22,7 +22,7 @@ Name: rust Version: 1.11.0 -Release: 1%{?dist} +Release: 2%{?dist} Summary: The Rust Programming Language License: (ASL 2.0 or MIT) and (BSD and ISC and MIT) # ^ written as: (rust itself) and (bundled libraries) @@ -39,14 +39,13 @@ Source0: https://static.rust-lang.org/dist/%{rustc_package}-src.tar.gz %global bootstrap_base https://static.rust-lang.org/dist/%{bootstrap_date}/rustc-%{bootstrap_channel} Source1: %{bootstrap_base}-x86_64-unknown-linux-gnu.tar.gz Source2: %{bootstrap_base}-i686-unknown-linux-gnu.tar.gz -#Source3: %{bootstrap_base}-armv7-unknown-linux-gnueabihf.tar.gz +Source3: %{bootstrap_base}-armv7-unknown-linux-gnueabihf.tar.gz #Source4: %{bootstrap_base}-aarch64-unknown-linux-gnu.tar.gz %endif # Only x86_64 and i686 are Tier 1 platforms at this time. # https://doc.rust-lang.org/stable/book/getting-started.html#tier-1 -ExclusiveArch: x86_64 i686 -#ExclusiveArch: x86_64 i686 armv7hl aarch64 +ExclusiveArch: x86_64 i686 armv7hl %ifarch armv7hl %global rust_triple armv7-unknown-linux-gnueabihf %else @@ -55,6 +54,9 @@ ExclusiveArch: x86_64 i686 Patch1: rust-1.11.0-no-bootstrap-download.patch +# merged for 1.13.0 +Patch2: rust-pr35814-armv7-no-neon.patch + BuildRequires: make BuildRequires: cmake BuildRequires: gcc @@ -86,7 +88,11 @@ BuildRequires: /usr/bin/ps # eventual goal of rewriting them in Rust proper. BuildRequires: compiler-rt Provides: bundled(compiler-rt) = 3.8 +%ifarch armv7hl +%global clang_builtins %{_libdir}/clang/3.8.0/lib/libclang_rt.builtins-armhf.a +%else %global clang_builtins %{_libdir}/clang/3.8.0/lib/libclang_rt.builtins-%{_target_cpu}.a +%endif # TODO: work on unbundling these! Provides: bundled(hoedown) = 3.0.5 @@ -142,6 +148,7 @@ its standard library. %setup -q -n %{rustc_package} %patch1 -p1 -b .no-download +%patch2 -p1 -b .no-neon # unbundle rm -rf src/llvm/ src/jemalloc/ @@ -173,7 +180,7 @@ sed -i.libdir -e '/^HLIB_RELATIVE/s/lib$/$$(CFG_LIBDIR_RELATIVE)/' mk/main.mk %if %with bootstrap mkdir -p dl/ -cp -t dl/ %{SOURCE1} %{SOURCE2} # %{SOURCE3} %{SOURCE4} +cp -t dl/ %{?SOURCE1} %{?SOURCE2} %{?SOURCE3} %{?SOURCE4} %endif @@ -265,6 +272,9 @@ make check-lite VERBOSE=1 -k || echo "make check-lite exited with code $?" %changelog +* Fri Sep 02 2016 Josh Stone - 1.11.0-2 +- Bootstrap armv7hl, with backported no-neon patch. + * Wed Aug 24 2016 Josh Stone - 1.11.0-1 - Update to 1.11.0. - Drop the backported patches.