Hello community, here is the log from the commit of package llvm7 for openSUSE:Factory checked in at 2019-04-01 12:33:55 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Comparing /work/SRC/openSUSE:Factory/llvm7 (Old) and /work/SRC/openSUSE:Factory/.llvm7.new.25356 (New) ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "llvm7" Mon Apr 1 12:33:55 2019 rev:12 rq:689737 version:7.0.1 Changes: -------- --- /work/SRC/openSUSE:Factory/llvm7/llvm7.changes 2019-03-22 14:53:36.758087877 +0100 +++ /work/SRC/openSUSE:Factory/.llvm7.new.25356/llvm7.changes 2019-04-01 12:34:02.781808563 +0200 @@ -1,0 +2,19 @@ +Thu Mar 28 15:15:46 UTC 2019 - Bernhard Wiedemann <bwiedem...@suse.com> + +- Add clang-deterministic-selector-order.patch to make build of + gnustep-libobjc2 package reproducible (boo#1067478) + +------------------------------------------------------------------- +Sat Mar 23 23:29:21 UTC 2019 - aaronpuch...@alice-dsl.net + +- Fix packaging on ppc: the sanitizers aren't available there, so + the directories /usr/lib/clang/*/{lib,share} are missing. +- Package LLVMgold even when we don't use gold for linking. + It's promised in /usr/lib/cmake/llvm/LLVMExports.cmake. +- Unignore test failures on PowerPC64 architectures. The failures + in ppc are unrelated to AMDGPU, so we remove that remark. +- Fix dependencies: the gold plugin shouldn't depend on llvm-devel. + libc++abi-devel should depend on libc++abi. +- Fix typo. + +------------------------------------------------------------------- New: ---- clang-deterministic-selector-order.patch ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Other differences: ------------------ ++++++ llvm7.spec ++++++ --- /var/tmp/diff_new_pack.JOxltZ/_old 2019-04-01 12:34:05.165809174 +0200 +++ /var/tmp/diff_new_pack.JOxltZ/_new 2019-04-01 12:34:05.169809175 +0200 @@ -111,6 +111,7 @@ Patch27: llvm-D51108.patch Patch28: llvm-Ensure-that-variant-part-discriminator-is-read-by-Me.patch Patch29: llvm-test-Fix-Assembler-debug-info.ll.patch +Patch30: clang-deterministic-selector-order.patch BuildRequires: binutils-devel >= 2.21.90 %if %{with gold} BuildRequires: binutils-gold @@ -172,9 +173,7 @@ Requires: libstdc++-devel Requires: libtool Requires: llvm%{_sonum}-LTO-devel -%if %{with gold} Requires: llvm%{_sonum}-gold -%endif Requires: llvm%{_sonum}-polly-devel Requires: ncurses-devel Requires: pkgconfig @@ -205,9 +204,7 @@ Recommends: clang%{_sonum}-checker Recommends: libc++-devel Recommends: libomp%{_sonum}-devel -%if %{with gold} Recommends: llvm-gold-devel -%endif Recommends: scan-build Recommends: scan-view %if %{with cxx} @@ -300,19 +297,16 @@ This package contains the link-time optimizer for LLVM. (development files) -%if %{with gold} %package gold Summary: Gold linker plugin for LLVM # Avoid multiple provider errors Group: Development/Languages/Other -Requires: %{name}-devel = %{_relver} Requires: libLLVM%{_sonum} Conflicts: llvm-gold-provider Provides: llvm-gold-provider %description gold This package contains the Gold linker plugin for LLVM. -%endif %package -n libomp%{_sonum}-devel Summary: MPI plugin for LLVM @@ -360,6 +354,7 @@ Summary: C++ standard library ABI (devel package) Group: Development/Languages/C and C++ Requires: libc++-devel +Requires: libc++abi%{_socxx} = %{_relver} Conflicts: libc++abi.so Provides: libc++abi.so @@ -555,6 +550,7 @@ %patch8 -p1 %patch16 -p2 %patch26 -p1 +%patch30 -p1 popd %if %{with lldb} @@ -810,9 +806,7 @@ # Note that bfd-plugins is always in /usr/lib/bfd-plugins, no matter what _libdir is. mkdir -p %{buildroot}/usr/lib/bfd-plugins -%if %{with gold} ln -s %{_libdir}/LLVMgold.so %{buildroot}/usr/lib/bfd-plugins/ -%endif install -m 755 -d %{buildroot}%{_datadir}/vim/site/ for i in ftdetect ftplugin indent syntax; do @@ -967,8 +961,8 @@ %if !0%{?qemu_user_space_build:1} # we just do not have enough memory with qemu emulation -%ifarch ppc ppc64 ppc64le -ninja -v %{?_smp_mflags} check || { echo "Ignore PowerPC failures https://bugs.llvm.org/show_bug.cgi?id=35871"; } +%ifarch ppc +ninja -v %{?_smp_mflags} check || { echo "Ignore PowerPC failures"; } %else ninja -v %{?_smp_mflags} check %endif @@ -1004,10 +998,8 @@ %postun -n liblldb%{_sonum} -p /sbin/ldconfig %endif -%if %{with gold} %post gold -p /sbin/ldconfig %postun gold -p /sbin/ldconfig -%endif %post devel -p /sbin/ldconfig %postun devel -p /sbin/ldconfig %post LTO-devel -p /sbin/ldconfig @@ -1439,7 +1431,7 @@ %ghost %{_sysconfdir}/alternatives/llvm-link.1%{ext_man} %ghost %{_sysconfdir}/alternatives/llvm-mca.1%{ext_man} %ghost %{_sysconfdir}/alternatives/llvm-nm.1%{ext_man} -%ghost %{_sysconfdir}/alternatives/llvm-pdbuti.1%{ext_man} +%ghost %{_sysconfdir}/alternatives/llvm-pdbutil.1%{ext_man} %ghost %{_sysconfdir}/alternatives/llvm-profdata.1%{ext_man} %ghost %{_sysconfdir}/alternatives/llvm-readobj.1%{ext_man} %ghost %{_sysconfdir}/alternatives/llvm-stress.1%{ext_man} @@ -1532,8 +1524,11 @@ %dir %{_libdir}/clang/ %dir %{_libdir}/clang/%{_relver}/ %{_libdir}/clang/%{_relver}/bash-autocomplete.sh +# The sanitizer runtime is not available for ppc. +%ifnarch ppc %{_libdir}/clang/%{_relver}/lib %{_libdir}/clang/%{_relver}/share +%endif %{_sysconfdir}/bash_completion.d/clang.sh %files -n clang%{_sonum}-checker @@ -1571,16 +1566,12 @@ %license CREDITS.TXT LICENSE.TXT %{_libdir}/libLTO.so.* -%if %{with gold} %files gold %license CREDITS.TXT LICENSE.TXT %{_libdir}/LLVMgold.so # Note that bfd-plugins is always in /usr/lib/bfd-plugins, no matter what _libdir is. %dir /usr/lib/bfd-plugins/ /usr/lib/bfd-plugins/LLVMgold.so -%else -%exclude %{_libdir}/LLVMgold.so -%endif %if %{with openmp} %files -n libomp%{_sonum}-devel ++++++ clang-deterministic-selector-order.patch ++++++ commit 6c4fb3c5356d1a4fb031292c3a56458dd6e041b2 Author: David Chisnall <csda...@swan.ac.uk> Date: Tue Aug 14 10:05:25 2018 +0000 [gnu-objc] Make selector order deterministic. Summary: This probably fixes PR35277, though there may be other sources of nondeterminism (this was the only case of iterating over a DenseMap). It's difficult to provide a test case for this, because it shows up only on systems with ASLR enabled. Reviewers: rjmccall Reviewed By: rjmccall Subscribers: bmwiedemann, mgrang, cfe-commits Differential Revision: https://reviews.llvm.org/D50559 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@339668 91177308-0d34-0410-b5e6-96231b3b80d8 diff --git a/lib/CodeGen/CGObjCGNU.cpp b/lib/CodeGen/CGObjCGNU.cpp index 622c8bfb50..b509187b4c 100644 --- a/lib/CodeGen/CGObjCGNU.cpp +++ b/lib/CodeGen/CGObjCGNU.cpp @@ -3541,12 +3541,16 @@ llvm::Function *CGObjCGNU::ModuleInitFunction() { ConstantInitBuilder builder(CGM); auto selectors = builder.beginArray(selStructTy); auto &table = SelectorTable; // MSVC workaround - for (auto &entry : table) { + std::vector<Selector> allSelectors; + for (auto &entry : table) + allSelectors.push_back(entry.first); + llvm::sort(allSelectors.begin(), allSelectors.end()); - std::string selNameStr = entry.first.getAsString(); + for (auto &untypedSel : allSelectors) { + std::string selNameStr = untypedSel.getAsString(); llvm::Constant *selName = ExportUniqueString(selNameStr, ".objc_sel_name"); - for (TypedSelector &sel : entry.second) { + for (TypedSelector &sel : table[untypedSel]) { llvm::Constant *selectorTypeEncoding = NULLPtr; if (!sel.first.empty()) selectorTypeEncoding = diff --git a/test/CodeGenObjC/gnu-deterministic-selectors.m b/test/CodeGenObjC/gnu-deterministic-selectors.m new file mode 100644 index 0000000000..5f8d2e5378 --- /dev/null +++ b/test/CodeGenObjC/gnu-deterministic-selectors.m @@ -0,0 +1,16 @@ +// RUN: %clang_cc1 -triple x86_64-unknown-freebsd -fobjc-runtime=gnustep-1.5 %s -emit-llvm -o - | FileCheck %s +// RUN: %clang_cc1 -triple x86_64-unknown-freebsd -fobjc-runtime=gcc %s -emit-llvm -o - | FileCheck %s + +// Check that these selectors are emitted in alphabetical order. +// The order doesn't actually matter, only that it doesn't vary across runs. +// Clang sorts them when targeting a GCC-like ABI to guarantee determinism. +// CHECK: @.objc_selector_list = internal global [6 x { i8*, i8* }] [{ i8*, i8* } { i8* getelementptr inbounds ([2 x i8], [2 x i8]* @.objc_sel_namea, i64 0, i64 0), i8* null }, { i8*, i8* } { i8* getelementptr inbounds ([2 x i8], [2 x i8]* @.objc_sel_nameg, i64 0, i64 0), i8* null }, { i8*, i8* } { i8* getelementptr inbounds ([2 x i8], [2 x i8]* @.objc_sel_namej, i64 0, i64 0), i8* null }, { i8*, i8* } { i8* getelementptr inbounds ([2 x i8], [2 x i8]* @.objc_sel_namel, i64 0, i64 0), i8* null }, { i8*, i8* } { i8* getelementptr inbounds ([2 x i8], [2 x i8]* @.objc_sel_namez, i64 0, i64 0), i8* null }, { i8*, i8* } zeroinitializer], align 8 + + +void f() { + SEL a = @selector(z); + SEL b = @selector(a); + SEL c = @selector(g); + SEL d = @selector(l); + SEL e = @selector(j); +}