4d8ee4456a
Starting from 5.13 Cyclades async mux support is dropped from linux kernel: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=f76edd8f7ce06cdff2fe5b6b39a49644c684a161 But gcc's libsanitizer uses <linux/cyclades.h> header. This issue is fixed by: https://gcc.gnu.org/git/?p=gcc.git;a=commit;h=745dae5923aba02982563481d75a21595df22ff8 gcc 9.4.0 has already been released with the fix, so we only patch gcc 8.x, 10.x, 11.x, the ARC and C-SKY versions Fixes: http://autobuild.buildroot.net/results/7f2056d05f4e05fcb95e2606583e95fac8bf3aef/ (gcc 10.x) http://autobuild.buildroot.net/results/116f40c22946952a8190ccba85d26913d9786e52/ (gcc 11.x) Signed-off-by: Maxim Kochetkov <fido_max@inbox.ru> Signed-off-by: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
122 lines
5.2 KiB
Diff
122 lines
5.2 KiB
Diff
From 0d2ee4f3a8cd3516f2c5c2f06373f8a32fd77b9d Mon Sep 17 00:00:00 2001
|
|
From: Tamar Christina <tamar.christina@arm.com>
|
|
Date: Fri, 21 May 2021 12:16:56 +0100
|
|
Subject: [PATCH] libsanitizer: Remove cyclades from libsanitizer
|
|
|
|
The Linux kernel has removed the interface to cyclades from
|
|
the latest kernel headers[1] due to them being orphaned for the
|
|
past 13 years.
|
|
|
|
libsanitizer uses this header when compiling against glibc, but
|
|
glibcs itself doesn't seem to have any references to cyclades.
|
|
|
|
Further more it seems that the driver is broken in the kernel and
|
|
the firmware doesn't seem to be available anymore.
|
|
|
|
As such since this is breaking the build of libsanitizer (and so the
|
|
GCC bootstrap[2]) I propose to remove this.
|
|
|
|
[1] https://lkml.org/lkml/2021/3/2/153
|
|
[2] https://gcc.gnu.org/bugzilla/show_bug.cgi?id=100379
|
|
|
|
libsanitizer/ChangeLog:
|
|
|
|
PR sanitizer/100379
|
|
* sanitizer_common/sanitizer_common_interceptors_ioctl.inc: Cherry-pick
|
|
llvm-project revision f7c5351552387bd43f6ca3631016d7f0dfe0f135.
|
|
* sanitizer_common/sanitizer_platform_limits_posix.cc: Likewise.
|
|
* sanitizer_common/sanitizer_platform_limits_posix.h: Likewise.
|
|
---
|
|
.../sanitizer_common_interceptors_ioctl.inc | 9 ---------
|
|
.../sanitizer_platform_limits_posix.cc | 11 -----------
|
|
.../sanitizer_platform_limits_posix.h | 10 ----------
|
|
3 files changed, 30 deletions(-)
|
|
|
|
diff --git a/libsanitizer/sanitizer_common/sanitizer_common_interceptors_ioctl.inc b/libsanitizer/sanitizer_common/sanitizer_common_interceptors_ioctl.inc
|
|
index 6c5fda09fbf..8f9314142b6 100755
|
|
--- a/libsanitizer/sanitizer_common/sanitizer_common_interceptors_ioctl.inc
|
|
+++ b/libsanitizer/sanitizer_common/sanitizer_common_interceptors_ioctl.inc
|
|
@@ -358,15 +358,6 @@ static void ioctl_table_fill() {
|
|
|
|
#if SANITIZER_LINUX && !SANITIZER_ANDROID
|
|
// _(SIOCDEVPLIP, WRITE, struct_ifreq_sz); // the same as EQL_ENSLAVE
|
|
- _(CYGETDEFTHRESH, WRITE, sizeof(int));
|
|
- _(CYGETDEFTIMEOUT, WRITE, sizeof(int));
|
|
- _(CYGETMON, WRITE, struct_cyclades_monitor_sz);
|
|
- _(CYGETTHRESH, WRITE, sizeof(int));
|
|
- _(CYGETTIMEOUT, WRITE, sizeof(int));
|
|
- _(CYSETDEFTHRESH, NONE, 0);
|
|
- _(CYSETDEFTIMEOUT, NONE, 0);
|
|
- _(CYSETTHRESH, NONE, 0);
|
|
- _(CYSETTIMEOUT, NONE, 0);
|
|
_(EQL_EMANCIPATE, WRITE, struct_ifreq_sz);
|
|
_(EQL_ENSLAVE, WRITE, struct_ifreq_sz);
|
|
_(EQL_GETMASTRCFG, WRITE, struct_ifreq_sz);
|
|
diff --git a/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc b/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc
|
|
index 9866cc9e17a..5277407aec7 100644
|
|
--- a/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc
|
|
+++ b/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.cc
|
|
@@ -156,7 +156,6 @@ typedef struct user_fpregs elf_fpregset_t;
|
|
#endif
|
|
#include <sys/user.h>
|
|
#include <sys/ustat.h>
|
|
-#include <linux/cyclades.h>
|
|
#include <linux/if_eql.h>
|
|
#include <linux/if_plip.h>
|
|
#include <linux/lp.h>
|
|
@@ -439,7 +438,6 @@ unsigned struct_ElfW_Phdr_sz = sizeof(Elf_Phdr);
|
|
|
|
#if SANITIZER_LINUX && !SANITIZER_ANDROID
|
|
unsigned struct_ax25_parms_struct_sz = sizeof(struct ax25_parms_struct);
|
|
- unsigned struct_cyclades_monitor_sz = sizeof(struct cyclades_monitor);
|
|
#if EV_VERSION > (0x010000)
|
|
unsigned struct_input_keymap_entry_sz = sizeof(struct input_keymap_entry);
|
|
#else
|
|
@@ -806,15 +804,6 @@ unsigned struct_ElfW_Phdr_sz = sizeof(Elf_Phdr);
|
|
#endif // SANITIZER_LINUX || SANITIZER_FREEBSD
|
|
|
|
#if SANITIZER_LINUX && !SANITIZER_ANDROID
|
|
- unsigned IOCTL_CYGETDEFTHRESH = CYGETDEFTHRESH;
|
|
- unsigned IOCTL_CYGETDEFTIMEOUT = CYGETDEFTIMEOUT;
|
|
- unsigned IOCTL_CYGETMON = CYGETMON;
|
|
- unsigned IOCTL_CYGETTHRESH = CYGETTHRESH;
|
|
- unsigned IOCTL_CYGETTIMEOUT = CYGETTIMEOUT;
|
|
- unsigned IOCTL_CYSETDEFTHRESH = CYSETDEFTHRESH;
|
|
- unsigned IOCTL_CYSETDEFTIMEOUT = CYSETDEFTIMEOUT;
|
|
- unsigned IOCTL_CYSETTHRESH = CYSETTHRESH;
|
|
- unsigned IOCTL_CYSETTIMEOUT = CYSETTIMEOUT;
|
|
unsigned IOCTL_EQL_EMANCIPATE = EQL_EMANCIPATE;
|
|
unsigned IOCTL_EQL_ENSLAVE = EQL_ENSLAVE;
|
|
unsigned IOCTL_EQL_GETMASTRCFG = EQL_GETMASTRCFG;
|
|
diff --git a/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.h b/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.h
|
|
index b6f90eb3a74..ae3a938344d 100644
|
|
--- a/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.h
|
|
+++ b/libsanitizer/sanitizer_common/sanitizer_platform_limits_posix.h
|
|
@@ -949,7 +949,6 @@ struct __sanitizer_cookie_io_functions_t {
|
|
|
|
#if SANITIZER_LINUX && !SANITIZER_ANDROID
|
|
extern unsigned struct_ax25_parms_struct_sz;
|
|
- extern unsigned struct_cyclades_monitor_sz;
|
|
extern unsigned struct_input_keymap_entry_sz;
|
|
extern unsigned struct_ipx_config_data_sz;
|
|
extern unsigned struct_kbdiacrs_sz;
|
|
@@ -1294,15 +1293,6 @@ struct __sanitizer_cookie_io_functions_t {
|
|
#endif // SANITIZER_LINUX || SANITIZER_FREEBSD
|
|
|
|
#if SANITIZER_LINUX && !SANITIZER_ANDROID
|
|
- extern unsigned IOCTL_CYGETDEFTHRESH;
|
|
- extern unsigned IOCTL_CYGETDEFTIMEOUT;
|
|
- extern unsigned IOCTL_CYGETMON;
|
|
- extern unsigned IOCTL_CYGETTHRESH;
|
|
- extern unsigned IOCTL_CYGETTIMEOUT;
|
|
- extern unsigned IOCTL_CYSETDEFTHRESH;
|
|
- extern unsigned IOCTL_CYSETDEFTIMEOUT;
|
|
- extern unsigned IOCTL_CYSETTHRESH;
|
|
- extern unsigned IOCTL_CYSETTIMEOUT;
|
|
extern unsigned IOCTL_EQL_EMANCIPATE;
|
|
extern unsigned IOCTL_EQL_ENSLAVE;
|
|
extern unsigned IOCTL_EQL_GETMASTRCFG;
|
|
--
|
|
2.31.1
|
|
|