Merge branch 'master' into epel7
This commit is contained in:
commit
51be00a780
|
@ -5,3 +5,9 @@
|
|||
/rustc-1.10.0-i686-unknown-linux-gnu.tar.gz
|
||||
/rustc-1.10.0-x86_64-unknown-linux-gnu.tar.gz
|
||||
/rustc-1.10.0-armv7-unknown-linux-gnueabihf.tar.gz
|
||||
/rustc-1.11.0-aarch64-unknown-linux-gnu.tar.gz
|
||||
/rustc-1.11.0-armv7-unknown-linux-gnueabihf.tar.gz
|
||||
/rustc-1.11.0-i686-unknown-linux-gnu.tar.gz
|
||||
/rustc-1.11.0-x86_64-unknown-linux-gnu.tar.gz
|
||||
/rustc-1.12.0-src.tar.gz
|
||||
/rustc-1.12.1-src.tar.gz
|
||||
|
|
|
@ -1,14 +0,0 @@
|
|||
--- rustc-1.11.0/src/etc/get-stage0.py.no-download 2016-08-24 00:34:03.561598809 -0700
|
||||
+++ rustc-1.11.0/src/etc/get-stage0.py 2016-08-24 00:34:08.636555684 -0700
|
||||
@@ -31,9 +31,8 @@ def main(triple):
|
||||
filename = 'rustc-{}-{}.tar.gz'.format(channel, triple)
|
||||
url = 'https://static.rust-lang.org/dist/{}/{}'.format(date, filename)
|
||||
dst = dl_dir + '/' + filename
|
||||
- if os.path.exists(dst):
|
||||
- os.unlink(dst)
|
||||
- bootstrap.get(url, dst)
|
||||
+ if not os.path.exists(dst):
|
||||
+ bootstrap.get(url, dst)
|
||||
|
||||
stage0_dst = triple + '/stage0'
|
||||
if os.path.exists(stage0_dst):
|
|
@ -0,0 +1,30 @@
|
|||
commit 1a4192804518199623fb88bf43bde69d6b0203cb (from a5dac7a2af3ee444817eb7bfbba3539be8c06cf1)
|
||||
Merge: a5dac7a2af3e 4625642211b9
|
||||
Author: bors <bors@rust-lang.org>
|
||||
Date: Tue Oct 4 13:23:09 2016 -0700
|
||||
|
||||
Auto merge of #36933 - alexcrichton:less-neon-again, r=eddyb
|
||||
|
||||
rustc: Try again to disable NEON on armv7 linux
|
||||
|
||||
This is a follow-up to #35814 which apparently didn't disable it hard enough. It
|
||||
looks like LLVM's default armv7 target enables NEON so we'd otherwise have to
|
||||
pass `-neon`, but we're already enabling armv7 with `+v7` supposedly, so let's
|
||||
try just telling LLVM that the armv7 target is arm and then enable features
|
||||
selectively.
|
||||
|
||||
Closes #36913
|
||||
|
||||
diff --git a/src/librustc_back/target/armv7_unknown_linux_gnueabihf.rs b/src/librustc_back/target/armv7_unknown_linux_gnueabihf.rs
|
||||
index 1abf8b0b69a2..a6d73ddb1835 100644
|
||||
--- a/src/librustc_back/target/armv7_unknown_linux_gnueabihf.rs
|
||||
+++ b/src/librustc_back/target/armv7_unknown_linux_gnueabihf.rs
|
||||
@@ -24,7 +24,7 @@ pub fn target() -> TargetResult {
|
||||
|
||||
options: TargetOptions {
|
||||
// Info about features at https://wiki.debian.org/ArmHardFloatPort
|
||||
- features: "+v7,+vfp3,+d16,+thumb2".to_string(),
|
||||
+ features: "+v7,+vfp3,+d16,+thumb2,-neon".to_string(),
|
||||
cpu: "generic".to_string(),
|
||||
max_atomic_width: 64,
|
||||
.. base
|
128
rust.spec
128
rust.spec
|
@ -5,29 +5,32 @@
|
|||
# e.g. 1.10.0 wants rustc: 1.9.0-2016-05-24
|
||||
# or nightly wants some beta-YYYY-MM-DD
|
||||
%bcond_with bootstrap
|
||||
%global bootstrap_channel 1.10.0
|
||||
%global bootstrap_date 2016-07-05
|
||||
%global bootstrap_channel 1.11.0
|
||||
%global bootstrap_date 2016-08-16
|
||||
|
||||
# We generally don't want llvm-static present at all, since llvm-config will
|
||||
# make us link statically. But we can opt in, e.g. to aid LLVM rebases.
|
||||
%bcond_with llvm_static
|
||||
|
||||
%if 0%{?rhel}
|
||||
%global _with_bundled_llvm 1
|
||||
%endif
|
||||
%bcond_with bundled_llvm
|
||||
|
||||
# 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_without rebuild
|
||||
|
||||
# The script for minidebuginfo copies symbols and *notes* into a "mini"
|
||||
# ELF object compressed into the .gnu_debugdata section. This includes our
|
||||
# relatively large .note.rustc metadata, bloating every library. Eventually
|
||||
# that metadata should be stripped beforehand -- see rust #23366 and #26764.
|
||||
# Note, 1.12 will move to unallocated data via PR35409, then can be stripped.
|
||||
# Rust 1.12 metadata is now unallocated data (.rustc), and in theory it should
|
||||
# be fine to strip this entirely, since we don't want to expose Rust's unstable
|
||||
# ABI for linking. However, eu-strip was then clobbering .dynsym when it tried
|
||||
# to remove the rust_metadata symbol referencing .rustc (rhbz1380961).
|
||||
# So for unfixed elfutils, we'll leave .rustc alone and only strip debuginfo.
|
||||
%if 0%{?fedora} < 25
|
||||
%global _find_debuginfo_opts -g
|
||||
%undefine _include_minidebuginfo
|
||||
%endif
|
||||
|
||||
Name: rust
|
||||
Version: 1.11.0
|
||||
Release: 3%{?dist}.2
|
||||
Version: 1.12.1
|
||||
Release: 1%{?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)
|
||||
|
@ -45,22 +48,23 @@ Source0: https://static.rust-lang.org/dist/%{rustc_package}-src.tar.gz
|
|||
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
|
||||
#Source4: %{bootstrap_base}-aarch64-unknown-linux-gnu.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 armv7hl
|
||||
ExclusiveArch: x86_64 i686 armv7hl aarch64
|
||||
%ifarch armv7hl
|
||||
%global rust_triple armv7-unknown-linux-gnueabihf
|
||||
%else
|
||||
%global rust_triple %{_target_cpu}-unknown-linux-gnu
|
||||
%endif
|
||||
|
||||
Patch1: rust-1.11.0-no-bootstrap-download.patch
|
||||
|
||||
# merged for 1.13.0
|
||||
Patch2: rust-pr35814-armv7-no-neon.patch
|
||||
Patch1: rust-pr35814-armv7-no-neon.patch
|
||||
|
||||
# merged for 1.14.0
|
||||
Patch2: rust-pr36933-less-neon-again.patch
|
||||
|
||||
%if 0%{?rhel}
|
||||
BuildRequires: cmake3
|
||||
|
@ -71,45 +75,37 @@ BuildRequires: cmake
|
|||
BuildRequires: make
|
||||
BuildRequires: gcc
|
||||
BuildRequires: gcc-c++
|
||||
BuildRequires: ncurses-devel
|
||||
BuildRequires: zlib-devel
|
||||
BuildRequires: python2
|
||||
BuildRequires: curl
|
||||
|
||||
%if %without bootstrap
|
||||
%if %with rebuild
|
||||
BuildRequires: %{name} < %{version}-%{release}
|
||||
BuildRequires: %{name} >= %{version}
|
||||
%if %with llvm_static
|
||||
BuildRequires: llvm-static
|
||||
BuildRequires: libffi-devel
|
||||
%else
|
||||
BuildRequires: %{name} < %{version}
|
||||
BuildRequires: %{name} >= %{bootstrap_channel}
|
||||
# Make sure llvm-config doesn't see it.
|
||||
BuildConflicts: llvm-static
|
||||
%endif
|
||||
%endif
|
||||
|
||||
# make check: src/test/run-pass/wait-forked-but-failed-child.rs
|
||||
BuildRequires: /usr/bin/ps
|
||||
|
||||
%if %with bundled_llvm
|
||||
Provides: bundled(llvm) = 3.8
|
||||
Provides: bundled(compiler-rt) = 3.8
|
||||
%else
|
||||
BuildRequires: llvm-devel
|
||||
%endif
|
||||
|
||||
# Rust started using cmake for its bundled compiler-rt, but this requires
|
||||
# llvm-static to be installed. But then llvm-config starts printing flags
|
||||
# for static linkage, with no way to force it shared.
|
||||
#
|
||||
# For now, we'll bypass all that and just use the distro build. Then in the
|
||||
# next release, Rust is moving toward a true fork of these builtins, with the
|
||||
# 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
|
||||
|
||||
%if %without bootstrap
|
||||
BuildRequires: %{name} <= %{version}
|
||||
BuildRequires: %{name} >= %{bootstrap_channel}
|
||||
%global local_rust_root %{_prefix}
|
||||
%else
|
||||
%global clang_builtins %{_libdir}/clang/3.8.0/lib/libclang_rt.builtins-%{_target_cpu}.a
|
||||
%global bootstrap_root rustc-%{bootstrap_channel}-%{rust_triple}
|
||||
%global local_rust_root %{_builddir}/%{rustc_package}/%{bootstrap_root}/rustc
|
||||
%endif
|
||||
|
||||
%endif
|
||||
# make check needs "ps" for src/test/run-pass/wait-forked-but-failed-child.rs
|
||||
BuildRequires: procps-ng
|
||||
|
||||
# TODO: work on unbundling these!
|
||||
Provides: bundled(hoedown) = 3.0.5
|
||||
|
@ -164,14 +160,18 @@ its standard library.
|
|||
%prep
|
||||
%setup -q -n %{rustc_package}
|
||||
|
||||
%patch1 -p1 -b .no-download
|
||||
%patch2 -p1 -b .no-neon
|
||||
%if %with bootstrap
|
||||
find %{sources} -name '%{bootstrap_root}.tar.gz' -exec tar -xvzf '{}' ';'
|
||||
test -f '%{local_rust_root}/bin/rustc'
|
||||
%endif
|
||||
|
||||
%patch1 -p1 -b .no-neon
|
||||
%patch2 -p1 -b .less-neon
|
||||
|
||||
# unbundle
|
||||
rm -rf src/jemalloc/
|
||||
%if %without bundled_llvm
|
||||
rm -rf src/llvm/
|
||||
rm -rf src/compiler-rt/
|
||||
%endif
|
||||
|
||||
# extract bundled licenses for packaging
|
||||
|
@ -203,27 +203,33 @@ sed -i.libdir -e '/^HLIB_RELATIVE/s/lib$/$$(CFG_LIBDIR_RELATIVE)/' mk/main.mk
|
|||
sed -i.cmake -e 's/CFG_CMAKE cmake/&3/' configure
|
||||
%endif
|
||||
|
||||
%if %with bootstrap
|
||||
mkdir -p dl/
|
||||
cp -t dl/ %{?SOURCE1} %{?SOURCE2} %{?SOURCE3} %{?SOURCE4}
|
||||
%if %with llvm_static
|
||||
# Static linking to distro LLVM needs to add -lffi
|
||||
# https://github.com/rust-lang/rust/issues/34486
|
||||
sed -i.ffi -e '$a #[link(name = "ffi")] extern {}' \
|
||||
src/librustc_llvm/lib.rs
|
||||
%endif
|
||||
|
||||
|
||||
%build
|
||||
|
||||
%ifarch aarch64
|
||||
%if %with bootstrap
|
||||
# Upstream binaries have a 4k-paged jemalloc, which breaks with Fedora 64k pages.
|
||||
# https://github.com/rust-lang/rust/issues/36994
|
||||
export MALLOC_CONF=lg_dirty_mult:-1
|
||||
%endif
|
||||
%endif
|
||||
|
||||
%configure --disable-option-checking \
|
||||
--build=%{rust_triple} --host=%{rust_triple} --target=%{rust_triple} \
|
||||
%{!?with_bootstrap:--enable-local-rust --local-rust-root=%{_prefix} %{?with_rebuild:--enable-local-rebuild}} \
|
||||
--enable-local-rust --local-rust-root=%{local_rust_root} \
|
||||
%{!?with_bundled_llvm:--llvm-root=%{_prefix} --disable-codegen-tests} \
|
||||
--disable-jemalloc \
|
||||
--disable-rpath \
|
||||
--enable-debuginfo \
|
||||
--release-channel=%{channel}
|
||||
|
||||
%if %without bundled_llvm
|
||||
# Bypass the compiler-rt build -- see above.
|
||||
cp %{clang_builtins} ./%{rust_triple}/rt/libcompiler-rt.a
|
||||
%endif
|
||||
|
||||
%make_build VERBOSE=1
|
||||
|
||||
|
||||
|
@ -239,6 +245,12 @@ find %{buildroot}/%{_libdir}/rustlib/ -type f -name '*.so' -exec rm -v '{}' '+'
|
|||
# The remaining shared libraries should be executable for debuginfo extraction.
|
||||
find %{buildroot}/%{_libdir}/ -type f -name '*.so' -exec chmod -v +x '{}' '+'
|
||||
|
||||
# They also don't need the .rustc metadata anymore, so they won't support linking.
|
||||
# (but this needs the rhbz1380961 fix, or else eu-strip will clobber .dynsym)
|
||||
%if 0%{?fedora} >= 25
|
||||
find %{buildroot}/%{_libdir}/ -type f -name '*.so' -exec objcopy -R .rustc '{}' ';'
|
||||
%endif
|
||||
|
||||
# FIXME: __os_install_post will strip the rlibs
|
||||
# -- should we find a way to preserve debuginfo?
|
||||
|
||||
|
@ -250,7 +262,7 @@ rm -f %{buildroot}/%{_docdir}/%{name}/LICENSE-MIT
|
|||
|
||||
# Sanitize the HTML documentation
|
||||
find %{buildroot}/%{_docdir}/%{name}/html -empty -delete
|
||||
find %{buildroot}/%{_docdir}/%{name}/html -type f -exec chmod -v -x '{}' '+'
|
||||
find %{buildroot}/%{_docdir}/%{name}/html -type f -exec chmod -x '{}' '+'
|
||||
|
||||
# Move rust-gdb's python scripts so they're noarch
|
||||
mkdir -p %{buildroot}/%{_datadir}/%{name}
|
||||
|
@ -261,7 +273,7 @@ mv -v %{buildroot}/%{_libdir}/rustlib/etc %{buildroot}/%{_datadir}/%{name}/
|
|||
# Note, many of the tests execute in parallel threads,
|
||||
# so it's better not to use a parallel make here.
|
||||
# The results are not stable on koji, so mask errors and just log it.
|
||||
make check-lite VERBOSE=1 -k || echo "make check-lite exited with code $?"
|
||||
make check-lite VERBOSE=1 -k || python2 src/etc/check-summary.py tmp/*.log || :
|
||||
|
||||
|
||||
%post -p /sbin/ldconfig
|
||||
|
@ -299,6 +311,10 @@ make check-lite VERBOSE=1 -k || echo "make check-lite exited with code $?"
|
|||
|
||||
|
||||
%changelog
|
||||
* Thu Oct 20 2016 Josh Stone <jistone@redhat.com> - 1.12.1-1
|
||||
- Update to 1.12.1.
|
||||
- Merge package changes from rawhide.
|
||||
|
||||
* Tue Sep 20 2016 Josh Stone <jistone@redhat.com> - 1.11.0-3.2
|
||||
- Rebuild without bootstrap binaries.
|
||||
|
||||
|
|
9
sources
9
sources
|
@ -1,4 +1,5 @@
|
|||
bdbd8fa629208c94496adf40c68746a9 rustc-1.11.0-src.tar.gz
|
||||
059dbecdf8a7360f04450487a19be863 rustc-1.10.0-i686-unknown-linux-gnu.tar.gz
|
||||
eb49a590e9c30f77bb15741488ef2c2f rustc-1.10.0-x86_64-unknown-linux-gnu.tar.gz
|
||||
9a7a0bb568cfd3f3d5618e2cac5804ce rustc-1.10.0-armv7-unknown-linux-gnueabihf.tar.gz
|
||||
2beae9a9bd441553e979e10464829a97 rustc-1.11.0-aarch64-unknown-linux-gnu.tar.gz
|
||||
7386f1fae4b9e9ef95e281ea27f1446a rustc-1.11.0-armv7-unknown-linux-gnueabihf.tar.gz
|
||||
932c698c242238a68530c2c15fd0b810 rustc-1.11.0-i686-unknown-linux-gnu.tar.gz
|
||||
b83d7a1a90c2d80bef97a518022948c8 rustc-1.11.0-x86_64-unknown-linux-gnu.tar.gz
|
||||
82db5a9cb9a051bf8ece2f5174cb273b rustc-1.12.1-src.tar.gz
|
||||
|
|
Loading…
Reference in New Issue