gcc: Fix error 'size of array is negative' (#16969)
gcc 9.3.0 and glibc 2.31 (found in the base install of Ubuntu 20.04) cause the gcc package to error during build with the error: "size of array 'assertion_failed__####' is negative" Previous to this fix, the error was resolved for v8.1.0 <= gcc <= v9.2.0 via two patches. This fix backports those patches for v5.3.0 <= gcc <= v7.4.0 Potentially these patches need to be backported to versions of gcc before v5.3.0, but other compile issues need to be resolved for earlier versions of gcc first. Fixes #16968
This commit is contained in:
parent
885808cc13
commit
46a751081d
@ -0,0 +1,39 @@
|
|||||||
|
From ce9568e9e9cf6094be30e748821421e703754ffc Mon Sep 17 00:00:00 2001
|
||||||
|
From: Jakub Jelinek <jakub@redhat.com>
|
||||||
|
Date: Fri, 8 Nov 2019 19:53:18 +0100
|
||||||
|
Subject: [PATCH] backport: re PR sanitizer/92154 (new glibc breaks arm
|
||||||
|
bootstrap due to libsanitizer)
|
||||||
|
|
||||||
|
Backported from mainline
|
||||||
|
2019-10-22 Tamar Christina <tamar.christina@arm.com>
|
||||||
|
Backported for version 5.3.0 <= gcc <= 6.5.0
|
||||||
|
2020-06-05 John L. Jolly <john.jolly@gmail.com>
|
||||||
|
|
||||||
|
PR sanitizer/92154
|
||||||
|
* sanitizer_common/sanitizer_platform_limits_posix.cc:
|
||||||
|
Cherry-pick compiler-rt revision r375220.
|
||||||
|
|
||||||
|
From-SVN: r277981
|
||||||
|
---
|
||||||
|
libsanitizer/ChangeLog | 9 +++++++++
|
||||||
|
.../sanitizer_common/sanitizer_platform_limits_posix.cc | 6 +++++-
|
||||||
|
2 files changed, 14 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc b/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc
|
||||||
|
index 6cd4a5bac8b0..06a605ff4670 100644
|
||||||
|
--- a/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc
|
||||||
|
+++ b/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc
|
||||||
|
@@ -1130,8 +1130,12 @@ CHECK_SIZE_AND_OFFSET(ipc_perm, uid);
|
||||||
|
#ifndef __GLIBC_PREREQ
|
||||||
|
#define __GLIBC_PREREQ(x, y) 0
|
||||||
|
#endif
|
||||||
|
-#if !defined(__aarch64__) || !SANITIZER_LINUX || __GLIBC_PREREQ (2, 21)
|
||||||
|
+#if (!defined(__aarch64__) || !SANITIZER_LINUX || __GLIBC_PREREQ (2, 21)) && \
|
||||||
|
+ !defined(__arm__)
|
||||||
|
/* On aarch64 glibc 2.20 and earlier provided incorrect mode field. */
|
||||||
|
+/* On Arm glibc 2.31 and later provide a different mode field, this field is
|
||||||
|
+ never used by libsanitizer so we can simply ignore this assert for all glibc
|
||||||
|
+ versions. */
|
||||||
|
CHECK_SIZE_AND_OFFSET(ipc_perm, mode);
|
||||||
|
#endif
|
||||||
|
|
@ -0,0 +1,69 @@
|
|||||||
|
From 75003cdd23c310ec385344e8040d490e8dd6d2be Mon Sep 17 00:00:00 2001
|
||||||
|
From: Jakub Jelinek <jakub@redhat.com>
|
||||||
|
Date: Fri, 20 Dec 2019 17:58:35 +0100
|
||||||
|
Subject: [PATCH] backport: re PR sanitizer/92154 (new glibc breaks arm
|
||||||
|
bootstrap due to libsanitizer)
|
||||||
|
|
||||||
|
Backported from mainline
|
||||||
|
2019-11-26 Jakub Jelinek <jakub@redhat.com>
|
||||||
|
Backported for version 5.3.0 <= gcc <= 6.5.0
|
||||||
|
2020-06-05 John L. Jolly <john.jolly@gmail.com>
|
||||||
|
|
||||||
|
PR sanitizer/92154
|
||||||
|
* sanitizer_common/sanitizer_platform_limits_posix.h: Cherry-pick
|
||||||
|
llvm-project revision 947f9692440836dcb8d88b74b69dd379d85974ce.
|
||||||
|
* sanitizer_common/sanitizer_platform_limits_posix.cc: Likewise.
|
||||||
|
|
||||||
|
From-SVN: r279653
|
||||||
|
---
|
||||||
|
libsanitizer/ChangeLog | 10 ++++++++++
|
||||||
|
.../sanitizer_platform_limits_posix.cc | 9 +++------
|
||||||
|
.../sanitizer_platform_limits_posix.h | 15 +--------------
|
||||||
|
3 files changed, 14 insertions(+), 20 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc b/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc
|
||||||
|
index 06a605ff4670..d823a12190c0 100644
|
||||||
|
--- a/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc
|
||||||
|
+++ b/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc
|
||||||
|
@@ -1130,12 +1130,9 @@ CHECK_SIZE_AND_OFFSET(ipc_perm, uid);
|
||||||
|
#ifndef __GLIBC_PREREQ
|
||||||
|
#define __GLIBC_PREREQ(x, y) 0
|
||||||
|
#endif
|
||||||
|
-#if (!defined(__aarch64__) || !SANITIZER_LINUX || __GLIBC_PREREQ (2, 21)) && \
|
||||||
|
- !defined(__arm__)
|
||||||
|
-/* On aarch64 glibc 2.20 and earlier provided incorrect mode field. */
|
||||||
|
-/* On Arm glibc 2.31 and later provide a different mode field, this field is
|
||||||
|
- never used by libsanitizer so we can simply ignore this assert for all glibc
|
||||||
|
- versions. */
|
||||||
|
+#if !SANITIZER_LINUX || __GLIBC_PREREQ (2, 31)
|
||||||
|
+/* glibc 2.30 and earlier provided 16-bit mode field instead of 32-bit
|
||||||
|
+ on many architectures. */
|
||||||
|
CHECK_SIZE_AND_OFFSET(ipc_perm, mode);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
diff --git a/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.h b/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.h
|
||||||
|
index 73af92af1e8f..6a673a7c9959 100644
|
||||||
|
--- a/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.h
|
||||||
|
+++ b/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.h
|
||||||
|
@@ -211,20 +211,13 @@ namespace __sanitizer {
|
||||||
|
unsigned long __unused1;
|
||||||
|
unsigned long __unused2;
|
||||||
|
#elif defined(__sparc__)
|
||||||
|
-# if defined(__arch64__)
|
||||||
|
unsigned mode;
|
||||||
|
- unsigned short __pad1;
|
||||||
|
-# else
|
||||||
|
- unsigned short __pad1;
|
||||||
|
- unsigned short mode;
|
||||||
|
unsigned short __pad2;
|
||||||
|
-# endif
|
||||||
|
unsigned short __seq;
|
||||||
|
unsigned long long __unused1;
|
||||||
|
unsigned long long __unused2;
|
||||||
|
#else
|
||||||
|
- unsigned short mode;
|
||||||
|
- unsigned short __pad1;
|
||||||
|
+ unsigned int mode;
|
||||||
|
unsigned short __seq;
|
||||||
|
unsigned short __pad2;
|
||||||
|
#if defined(__x86_64__) && !defined(_LP64)
|
@ -0,0 +1,69 @@
|
|||||||
|
From 75003cdd23c310ec385344e8040d490e8dd6d2be Mon Sep 17 00:00:00 2001
|
||||||
|
From: Jakub Jelinek <jakub@redhat.com>
|
||||||
|
Date: Fri, 20 Dec 2019 17:58:35 +0100
|
||||||
|
Subject: [PATCH] backport: re PR sanitizer/92154 (new glibc breaks arm
|
||||||
|
bootstrap due to libsanitizer)
|
||||||
|
|
||||||
|
Backported from mainline
|
||||||
|
2019-11-26 Jakub Jelinek <jakub@redhat.com>
|
||||||
|
Backported for version 7.1.0 <= gcc <= 7.4.0
|
||||||
|
2020-06-05 John L. Jolly <john.jolly@gmail.com>
|
||||||
|
|
||||||
|
PR sanitizer/92154
|
||||||
|
* sanitizer_common/sanitizer_platform_limits_posix.h: Cherry-pick
|
||||||
|
llvm-project revision 947f9692440836dcb8d88b74b69dd379d85974ce.
|
||||||
|
* sanitizer_common/sanitizer_platform_limits_posix.cc: Likewise.
|
||||||
|
|
||||||
|
From-SVN: r279653
|
||||||
|
---
|
||||||
|
libsanitizer/ChangeLog | 10 ++++++++++
|
||||||
|
.../sanitizer_platform_limits_posix.cc | 9 +++------
|
||||||
|
.../sanitizer_platform_limits_posix.h | 15 +--------------
|
||||||
|
3 files changed, 14 insertions(+), 20 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc b/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc
|
||||||
|
index 06a605ff4670..d823a12190c0 100644
|
||||||
|
--- a/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc
|
||||||
|
+++ b/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc
|
||||||
|
@@ -1156,12 +1156,9 @@ CHECK_SIZE_AND_OFFSET(ipc_perm, uid);
|
||||||
|
CHECK_SIZE_AND_OFFSET(ipc_perm, gid);
|
||||||
|
CHECK_SIZE_AND_OFFSET(ipc_perm, cuid);
|
||||||
|
CHECK_SIZE_AND_OFFSET(ipc_perm, cgid);
|
||||||
|
-#if (!defined(__aarch64__) || !SANITIZER_LINUX || __GLIBC_PREREQ (2, 21)) && \
|
||||||
|
- !defined(__arm__)
|
||||||
|
-/* On aarch64 glibc 2.20 and earlier provided incorrect mode field. */
|
||||||
|
-/* On Arm glibc 2.31 and later provide a different mode field, this field is
|
||||||
|
- never used by libsanitizer so we can simply ignore this assert for all glibc
|
||||||
|
- versions. */
|
||||||
|
+#if !SANITIZER_LINUX || __GLIBC_PREREQ (2, 31)
|
||||||
|
+/* glibc 2.30 and earlier provided 16-bit mode field instead of 32-bit
|
||||||
|
+ on many architectures. */
|
||||||
|
CHECK_SIZE_AND_OFFSET(ipc_perm, mode);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
diff --git a/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.h b/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.h
|
||||||
|
index 73af92af1e8f..6a673a7c9959 100644
|
||||||
|
--- a/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.h
|
||||||
|
+++ b/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.h
|
||||||
|
@@ -211,20 +211,13 @@ namespace __sanitizer {
|
||||||
|
unsigned long __unused1;
|
||||||
|
unsigned long __unused2;
|
||||||
|
#elif defined(__sparc__)
|
||||||
|
-# if defined(__arch64__)
|
||||||
|
unsigned mode;
|
||||||
|
- unsigned short __pad1;
|
||||||
|
-# else
|
||||||
|
- unsigned short __pad1;
|
||||||
|
- unsigned short mode;
|
||||||
|
unsigned short __pad2;
|
||||||
|
-# endif
|
||||||
|
unsigned short __seq;
|
||||||
|
unsigned long long __unused1;
|
||||||
|
unsigned long long __unused2;
|
||||||
|
#else
|
||||||
|
- unsigned short mode;
|
||||||
|
- unsigned short __pad1;
|
||||||
|
+ unsigned int mode;
|
||||||
|
unsigned short __seq;
|
||||||
|
unsigned short __pad2;
|
||||||
|
#if defined(__x86_64__) && !defined(_LP64)
|
@ -242,10 +242,13 @@ class Gcc(AutotoolsPackage, GNUMirrorPackage):
|
|||||||
patch('piclibs.patch', when='+piclibs')
|
patch('piclibs.patch', when='+piclibs')
|
||||||
patch('gcc-backport.patch', when='@4.7:4.9.2,5:5.3')
|
patch('gcc-backport.patch', when='@4.7:4.9.2,5:5.3')
|
||||||
|
|
||||||
# Backport libsanitizer patch for glibc >= 2.31 and 8.1.0 <= gcc <= 9.2.0
|
# Backport libsanitizer patch for glibc >= 2.31 and 5.3.0 <= gcc <= 9.2.0
|
||||||
# https://bugs.gentoo.org/708346
|
# https://bugs.gentoo.org/708346
|
||||||
patch('glibc-2.31-libsanitizer-1.patch', when='@8.1.0:8.3.99,9.0.0:9.2.0')
|
patch('glibc-2.31-libsanitizer-1.patch', when='@7.1.0:7.4.0,8.1.0:8.3.0,9.0.0:9.2.0')
|
||||||
patch('glibc-2.31-libsanitizer-2.patch', when='@8.1.0:8.3.99,9.0.0:9.2.0')
|
patch('glibc-2.31-libsanitizer-1-gcc-6.patch', when='@5.3.0:5.5.0,6.1.0:6.5.0')
|
||||||
|
patch('glibc-2.31-libsanitizer-2.patch', when='@8.1.0:8.3.0,9.0.0:9.2.0')
|
||||||
|
patch('glibc-2.31-libsanitizer-2-gcc-6.patch', when='@5.3.0:5.5.0,6.1.0:6.5.0')
|
||||||
|
patch('glibc-2.31-libsanitizer-2-gcc-7.patch', when='@7.1.0:7.4.0')
|
||||||
# Older versions do not compile with newer versions of glibc
|
# Older versions do not compile with newer versions of glibc
|
||||||
# https://gcc.gnu.org/bugzilla/show_bug.cgi?id=81712
|
# https://gcc.gnu.org/bugzilla/show_bug.cgi?id=81712
|
||||||
patch('ucontext_t.patch', when='@4.9,5.1:5.4,6.1:6.4,7.1')
|
patch('ucontext_t.patch', when='@4.9,5.1:5.4,6.1:6.4,7.1')
|
||||||
|
Loading…
Reference in New Issue
Block a user