llvm 3.7.0

upstream moved clang man pages so deal with generating them
upstream bug somewhere with HAVE_PROCESS_VM_READV, just hard define it
upstream bug with i386/i686 - sed it
upstream bug with // in an include - patch it, fix sent upstream

builds must be out of tree now.
This commit is contained in:
Dave Airlie 2015-09-16 13:11:34 +10:00
parent 82f10bfda6
commit cb91f5f879
4 changed files with 49 additions and 10 deletions

4
.gitignore vendored
View File

@ -19,3 +19,7 @@
/compiler-rt-3.6.2.src.tar.xz /compiler-rt-3.6.2.src.tar.xz
/lldb-3.6.2.src.tar.xz /lldb-3.6.2.src.tar.xz
/llvm-3.6.2.src.tar.xz /llvm-3.6.2.src.tar.xz
/llvm-3.7.0.src.tar.xz
/cfe-3.7.0.src.tar.xz
/compiler-rt-3.7.0.src.tar.xz
/lldb-3.7.0.src.tar.xz

View File

@ -0,0 +1,12 @@
diff -up llvm-3.7.0.src/include/llvm/CodeGen/CommandFlags.h.dma llvm-3.7.0.src/include/llvm/CodeGen/CommandFlags.h
--- llvm-3.7.0.src/include/llvm/CodeGen/CommandFlags.h.dma 2015-09-15 15:01:41.570871134 +1000
+++ llvm-3.7.0.src/include/llvm/CodeGen/CommandFlags.h 2015-09-15 15:01:53.642191476 +1000
@@ -21,7 +21,7 @@
#include "llvm/IR/Intrinsics.h"
#include "llvm/IR/Module.h"
#include "llvm/MC/MCTargetOptionsCommandFlags.h"
-#include "llvm//MC/SubtargetFeature.h"
+#include "llvm/MC/SubtargetFeature.h"
#include "llvm/Support/CodeGen.h"
#include "llvm/Support/CommandLine.h"
#include "llvm/Support/Host.h"

View File

@ -34,7 +34,7 @@
#global prerel rc3 #global prerel rc3
Name: llvm Name: llvm
Version: 3.6.2 Version: 3.7.0
Release: 1%{?dist} Release: 1%{?dist}
Summary: The Low Level Virtual Machine Summary: The Low Level Virtual Machine
@ -53,6 +53,9 @@ Source10: llvm-Config-config.h
Source11: llvm-Config-llvm-config.h Source11: llvm-Config-llvm-config.h
# patches # patches
# there is a double slash in an include, it breaks debugedit
Patch0: fix-broken-include-path.patch
Patch2: 0001-data-install-preserve-timestamps.patch Patch2: 0001-data-install-preserve-timestamps.patch
# the next two are various attempts to get clang to actually work on arm # the next two are various attempts to get clang to actually work on arm
@ -86,6 +89,7 @@ BuildRequires: ncurses-devel
BuildRequires: zip BuildRequires: zip
# for DejaGNU test suite # for DejaGNU test suite
BuildRequires: dejagnu tcl-devel python BuildRequires: dejagnu tcl-devel python
BuildRequires: python-sphinx
# for doxygen documentation # for doxygen documentation
%if %{with doxygen} %if %{with doxygen}
BuildRequires: doxygen graphviz BuildRequires: doxygen graphviz
@ -314,6 +318,8 @@ mv compiler-rt-*/ projects/compiler-rt
mv lldb-*/ tools/lldb mv lldb-*/ tools/lldb
%endif %endif
%patch0 -p1
%patch2 -p1 %patch2 -p1
%if %{with lldb} %if %{with lldb}
@ -329,6 +335,7 @@ popd
sed -i 's|/lib /usr/lib $lt_ld_extra|%{_libdir} $lt_ld_extra|' configure sed -i 's|/lib /usr/lib $lt_ld_extra|%{_libdir} $lt_ld_extra|' configure
sed -i 's|(PROJ_prefix)/lib|(PROJ_prefix)/%{_lib}/%{name}|g' Makefile.config.in sed -i 's|(PROJ_prefix)/lib|(PROJ_prefix)/%{_lib}/%{name}|g' Makefile.config.in
sed -i 's|/lib\>|/%{_lib}/%{name}|g' tools/llvm-config/llvm-config.cpp sed -i 's|/lib\>|/%{_lib}/%{name}|g' tools/llvm-config/llvm-config.cpp
sed -ri "/ifeq.*CompilerTargetArch/s#i386#i686#g" projects/compiler-rt/make/platform/clang_linux.mk
%build %build
%ifarch s390 %ifarch s390
@ -336,13 +343,16 @@ sed -i 's|/lib\>|/%{_lib}/%{name}|g' tools/llvm-config/llvm-config.cpp
%global optflags %(echo %{optflags} | sed 's/-g /-g1 /') %global optflags %(echo %{optflags} | sed 's/-g /-g1 /')
%endif %endif
mkdir build
cd build
ln -s ../configure .
# clang is lovely and all, but fedora builds with gcc # clang is lovely and all, but fedora builds with gcc
# -fno-devirtualize shouldn't be necessary, but gcc has scary template-related # -fno-devirtualize shouldn't be necessary, but gcc has scary template-related
# bugs that make it so. gcc 5 ought to be fixed. # bugs that make it so. gcc 5 ought to be fixed.
export CC=gcc export CC=gcc
export CXX=g++ export CXX=g++
export CFLAGS="%{optflags} -DLLDB_DISABLE_PYTHON" export CFLAGS="%{optflags} -DLLDB_DISABLE_PYTHON -DHAVE_PROCESS_VM_READV"
export CXXFLAGS="%{optflags} -DLLDB_DISABLE_PYTHON" export CXXFLAGS="%{optflags} -DLLDB_DISABLE_PYTHON -DHAVE_PROCESS_VM_READV"
%configure \ %configure \
--with-extra-options="-fno-devirtualize" \ --with-extra-options="-fno-devirtualize" \
--with-extra-ld-options=-Wl,-Bsymbolic \ --with-extra-ld-options=-Wl,-Bsymbolic \
@ -396,14 +406,15 @@ export CXXFLAGS="%{optflags} -DLLDB_DISABLE_PYTHON"
%if %{with gold} %if %{with gold}
--with-binutils-include=%{_includedir} \ --with-binutils-include=%{_includedir} \
%endif %endif
--with-c-include-dirs=%{_includedir}:$(echo %{_prefix}/lib/gcc/%{_target_cpu}*/*/include) \
--with-optimize-option=-O3 --with-optimize-option=-O3
make %{?_smp_mflags} REQUIRES_RTTI=1 VERBOSE=1 make %{?_smp_mflags} REQUIRES_RTTI=1 VERBOSE=1
#make REQUIRES_RTTI=1 VERBOSE=1 #make REQUIRES_RTTI=1 VERBOSE=1
%install %install
cd build
make install DESTDIR=%{buildroot} PROJ_docsdir=/moredocs make install DESTDIR=%{buildroot} PROJ_docsdir=/moredocs
cd -
# you have got to be kidding me # you have got to be kidding me
rm -f %{buildroot}%{_bindir}/{FileCheck,count,not,verify-uselistorder,obj2yaml,yaml2obj} rm -f %{buildroot}%{_bindir}/{FileCheck,count,not,verify-uselistorder,obj2yaml,yaml2obj}
@ -484,6 +495,11 @@ mv %{buildroot}/moredocs/ocamldoc/html %{buildroot}%{llvmdocdir %{name}-ocaml-do
# clang # clang
%if %{with clang} %if %{with clang}
cd tools/clang/docs/
make -f Makefile.sphinx man
cd -
cp tools/clang/docs/_build/man/clang.1 %{buildroot}%{_mandir}/man1/clang.1
mkdir -p %{buildroot}%{llvmdocdir clang} mkdir -p %{buildroot}%{llvmdocdir clang}
for f in LICENSE.TXT NOTES.txt README.txt CODE_OWNERS.TXT; do for f in LICENSE.TXT NOTES.txt README.txt CODE_OWNERS.TXT; do
cp tools/clang/$f %{buildroot}%{llvmdocdir clang}/ cp tools/clang/$f %{buildroot}%{llvmdocdir clang}/
@ -511,8 +527,8 @@ mkdir -p %{buildroot}%{_datadir}/llvm/cmake/
cp -p cmake/modules/*.cmake %{buildroot}%{_datadir}/llvm/cmake/ cp -p cmake/modules/*.cmake %{buildroot}%{_datadir}/llvm/cmake/
# remove RPATHs # remove RPATHs
file %{buildroot}/%{_bindir}/* | awk -F: '$2~/ELF/{print $1}' | xargs -r chrpath -d file %{buildroot}%{_bindir}/* | awk -F: '$2~/ELF/{print $1}' | xargs -r chrpath -d
file %{buildroot}/%{_libdir}/%{name}/*.so | awk -F: '$2~/ELF/{print $1}' | xargs -r chrpath -d file %{buildroot}%{_libdir}/%{name}/*.so | awk -F: '$2~/ELF/{print $1}' | xargs -r chrpath -d
%check %check
# the Koji build server does not seem to have enough RAM # the Koji build server does not seem to have enough RAM
@ -523,7 +539,9 @@ file %{buildroot}/%{_libdir}/%{name}/*.so | awk -F: '$2~/ELF/{print $1}' | xargs
# LLVM test suite failing on ARM, PPC64 and s390(x) # LLVM test suite failing on ARM, PPC64 and s390(x)
mkdir -p %{buildroot}%{llvmdocdir %{name}-devel} mkdir -p %{buildroot}%{llvmdocdir %{name}-devel}
cd build
make -k check LIT_ARGS="-v -j4" | tee %{buildroot}%{llvmdocdir %{name}-devel}/testlog-%{_arch}.txt || : make -k check LIT_ARGS="-v -j4" | tee %{buildroot}%{llvmdocdir %{name}-devel}/testlog-%{_arch}.txt || :
cd -
%if %{with clang} %if %{with clang}
# clang test suite failing on PPC and s390(x) # clang test suite failing on PPC and s390(x)
@ -531,7 +549,9 @@ make -k check LIT_ARGS="-v -j4" | tee %{buildroot}%{llvmdocdir %{name}-devel}/te
# unexpected failures on all platforms with GCC 4.7.0. # unexpected failures on all platforms with GCC 4.7.0.
# capture logs # capture logs
mkdir -p %{buildroot}%{llvmdocdir clang-devel} mkdir -p %{buildroot}%{llvmdocdir clang-devel}
cd build
make -C tools/clang/test TESTARGS="-v -j4" | tee %{buildroot}%{llvmdocdir clang-devel}/testlog-%{_arch}.txt || : make -C tools/clang/test TESTARGS="-v -j4" | tee %{buildroot}%{llvmdocdir clang-devel}/testlog-%{_arch}.txt || :
cd -
%endif %endif
@ -682,6 +702,9 @@ exit 0
%endif %endif
%changelog %changelog
* Wed Sep 16 2015 Dave Airlie <airlied@redhat.com> 3.7.0-1
- llvm 3.7.0
* Wed Jul 22 2015 Adam Jackson <ajax@redhat.com> 3.6.2-1 * Wed Jul 22 2015 Adam Jackson <ajax@redhat.com> 3.6.2-1
- llvm 3.6.2 - llvm 3.6.2

View File

@ -1,4 +1,4 @@
ff862793682f714bb7862325b9c06e20 cfe-3.6.2.src.tar.xz b98b9495e5655a672d6cb83e1a180f8e llvm-3.7.0.src.tar.xz
e3bc4eb7ba8c39a6fe90d6c988927f3c compiler-rt-3.6.2.src.tar.xz 8f9d27335e7331cf0a4711e952f21f01 cfe-3.7.0.src.tar.xz
51e5eb552f777b950bb0ff326e60d5f0 lldb-3.6.2.src.tar.xz 383c10affd513026f08936b5525523f5 compiler-rt-3.7.0.src.tar.xz
0c1ee3597d75280dee603bae9cbf5cc2 llvm-3.6.2.src.tar.xz e5931740400d1dc3e7db4c7ba2ceff68 lldb-3.7.0.src.tar.xz