wok-current rev 25586

Fix linux build with gcc > 6 again
author Stanislas Leduc <shann@slitaz.org>
date Mon May 29 12:23:26 2023 +0000 (20 months ago)
parents a58264a81dff
children 9a8523e9619e
files linux/receipt linux/stuff/linux-fix-format-overflow-gcc8.patch linux/stuff/linux-fix-noreturn-attributes-gcc8.patch linux/stuff/linux-usbip-fix-format-overflow-gcc8.patch linux/stuff/linux-usbip-fix-implicit-fallthrough-gcc8.patch linux/stuff/linux-with-gcc8.patch ncursesw-dev/receipt
line diff
     1.1 --- a/linux/receipt	Thu May 25 15:49:26 2023 +0000
     1.2 +++ b/linux/receipt	Mon May 29 12:23:26 2023 +0000
     1.3 @@ -235,8 +235,13 @@
     1.4  aufs3-mmap.patch
     1.5  EOT
     1.6  
     1.7 -	# Patch for GCC > 6.x
     1.8 -	patch -p1 < $stuff/linux-with-gcc8.patch
     1.9 +	# Patch for GCC > 6.x 
    1.10 +	# usbip (format overflow / implicit-fallthrough)
    1.11 +	# kernel (format overflow)
    1.12 +	patch -p1 < $stuff/linux-usbip-fix-format-overflow-gcc8.patch
    1.13 +	patch -p1 < $stuff/linux-usbip-fix-implicit-fallthrough-gcc8.patch
    1.14 +	patch -p1 < $stuff/linux-fix-format-overflow-gcc8.patch
    1.15 +	patch -p1 < $stuff/linux-fix-noreturn-attributes-gcc8.patch
    1.16  
    1.17  	# Mrproper and lguest
    1.18  	echo "Make kernel proper and then build lguest..."
     2.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     2.2 +++ b/linux/stuff/linux-fix-format-overflow-gcc8.patch	Mon May 29 12:23:26 2023 +0000
     2.3 @@ -0,0 +1,13 @@
     2.4 +diff --git a/scripts/kconfig/confdata.c b/scripts/kconfig/confdata.c
     2.5 +index 5f87ad561b08..39e20974f4a3 100644
     2.6 +--- a/scripts/kconfig/confdata.c
     2.7 ++++ b/scripts/kconfig/confdata.c
     2.8 +@@ -720,7 +720,7 @@  int conf_write(const char *name)
     2.9 + 	struct menu *menu;
    2.10 + 	const char *basename;
    2.11 + 	const char *str;
    2.12 +-	char dirname[PATH_MAX+1], tmpname[PATH_MAX+1], newname[PATH_MAX+1];
    2.13 ++	char dirname[PATH_MAX+1], tmpname[PATH_MAX+22], newname[PATH_MAX+8];
    2.14 + 	char *env;
    2.15 + 
    2.16 + 	dirname[0] = 0;
     3.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     3.2 +++ b/linux/stuff/linux-fix-noreturn-attributes-gcc8.patch	Mon May 29 12:23:26 2023 +0000
     3.3 @@ -0,0 +1,77 @@
     3.4 +gcc-7 has an "optimization" pass that completely screws up, and
     3.5 +generates the code expansion for the (impossible) case of calling
     3.6 +ilog2() with a zero constant, even when the code gcc compiles does not
     3.7 +actually have a zero constant.
     3.8 +
     3.9 +And we try to generate a compile-time error for anybody doing ilog2() on
    3.10 +a constant where that doesn't make sense (be it zero or negative).  So
    3.11 +now gcc7 will fail the build due to our sanity checking, because it
    3.12 +created that constant-zero case that didn't actually exist in the source
    3.13 +code.
    3.14 +
    3.15 +There's a whole long discussion on the kernel mailing about how to work
    3.16 +around this gcc bug.  The gcc people themselevs have discussed their
    3.17 +"feature" in
    3.18 +
    3.19 +   https://gcc.gnu.org/bugzilla/show_bug.cgi?id=72785
    3.20 +
    3.21 +but it's all water under the bridge, because while it looked at one
    3.22 +point like it would be solved by the time gcc7 was released, that was
    3.23 +not to be.
    3.24 +
    3.25 +So now we have to deal with this compiler braindamage.
    3.26 +
    3.27 +And the only simple approach seems to be to just delete the code that
    3.28 +tries to warn about bad uses of ilog2().
    3.29 +
    3.30 +So now "ilog2()" will just return 0 not just for the value 1, but for
    3.31 +any non-positive value too.
    3.32 +
    3.33 +It's not like I can recall anybody having ever actually tried to use
    3.34 +this function on any invalid value, but maybe the sanity check just
    3.35 +meant that such code never made it out in public.
    3.36 +
    3.37 +Reported-by: Laura Abbott <labbott@redhat.com>
    3.38 +Cc: John Stultz <john.stultz@linaro.org>,
    3.39 +Cc: Thomas Gleixner <tglx@linutronix.de>
    3.40 +Cc: Ard Biesheuvel <ard.biesheuvel@linaro.org>
    3.41 +Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
    3.42 +
    3.43 +diff --git a/include/linux/log2.h b/include/linux/log2.h
    3.44 +index ef3d4f67118ce..c373295f359fa 100644
    3.45 +--- a/include/linux/log2.h
    3.46 ++++ b/include/linux/log2.h
    3.47 +@@ -16,12 +16,6 @@
    3.48 + #include <linux/bitops.h>
    3.49 + 
    3.50 + /*
    3.51 +- * deal with unrepresentable constant logarithms
    3.52 +- */
    3.53 +-extern __attribute__((const, noreturn))
    3.54 +-int ____ilog2_NaN(void);
    3.55 +-
    3.56 +-/*
    3.57 +  * non-constant log of base 2 calculators
    3.58 +  * - the arch may override these in asm/bitops.h if they can be implemented
    3.59 +  *   more efficiently than using fls() and fls64()
    3.60 +@@ -85,7 +79,7 @@ unsigned long __rounddown_pow_of_two(unsigned long n)
    3.61 + #define ilog2(n)				\
    3.62 + (						\
    3.63 + 	__builtin_constant_p(n) ? (		\
    3.64 +-		(n) < 1 ? ____ilog2_NaN() :	\
    3.65 ++		(n) < 2 ? 0 :			\
    3.66 + 		(n) & (1ULL << 63) ? 63 :	\
    3.67 + 		(n) & (1ULL << 62) ? 62 :	\
    3.68 + 		(n) & (1ULL << 61) ? 61 :	\
    3.69 +@@ -148,10 +142,7 @@ unsigned long __rounddown_pow_of_two(unsigned long n)
    3.70 + 		(n) & (1ULL <<  4) ?  4 :	\
    3.71 + 		(n) & (1ULL <<  3) ?  3 :	\
    3.72 + 		(n) & (1ULL <<  2) ?  2 :	\
    3.73 +-		(n) & (1ULL <<  1) ?  1 :	\
    3.74 +-		(n) & (1ULL <<  0) ?  0 :	\
    3.75 +-		____ilog2_NaN()			\
    3.76 +-				   ) :		\
    3.77 ++		1 ) :				\
    3.78 + 	(sizeof(n) <= 4) ?			\
    3.79 + 	__ilog2_u32(n) :			\
    3.80 + 	__ilog2_u64(n)				\
     4.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     4.2 +++ b/linux/stuff/linux-usbip-fix-format-overflow-gcc8.patch	Mon May 29 12:23:26 2023 +0000
     4.3 @@ -0,0 +1,103 @@
     4.4 +Upstream commit e5dfa3f902b9 ("usbip: Fix potential format overflow in
     4.5 +userspace tools")
     4.6 +
     4.7 +
     4.8 +The usbip userspace tools call sprintf()/snprintf() and don't check for
     4.9 +the return value which can lead the paths to overflow, truncating the
    4.10 +final file in the path.
    4.11 +
    4.12 +More urgently, GCC 7 now warns that these aren't checked with
    4.13 +-Wformat-overflow, and with -Werror enabled in configure.ac, that makes
    4.14 +these tools unbuildable.
    4.15 +
    4.16 +This patch fixes these problems by replacing sprintf() with snprintf() in
    4.17 +one place and adding checks for the return value of snprintf().
    4.18 +
    4.19 +Reviewed-by: Peter Senna Tschudin <peter.se...@gmail.com>
    4.20 +Signed-off-by: Jonathan Dieter <jdie...@lesbg.com>
    4.21 +Acked-by: Shuah Khan <shua...@osg.samsung.com>
    4.22 +Signed-off-by: Greg Kroah-Hartman <gre...@linuxfoundation.org>
    4.23 +Signed-off-by: Shuah Khan <shua...@osg.samsung.com>
    4.24 +
    4.25 +diff --git a/tools/usb/usbip/libsrc/usbip_common.c b/tools/usb/usbip/libsrc/usbip_common.c
    4.26 +index ac73710..01dd4b2 100644
    4.27 +--- a/drivers/staging/usbip/userspace/libsrc/usbip_common.c
    4.28 ++++ b/drivers/staging/usbip/userspace/libsrc/usbip_common.c
    4.29 +@@ -215,9 +215,16 @@
    4.30 + 		       struct usbip_usb_interface *uinf)
    4.31 + {
    4.32 + 	char busid[SYSFS_BUS_ID_SIZE];
    4.33 ++	int size;
    4.34 + 	struct udev_device *sif;
    4.35 + 
    4.36 +-	sprintf(busid, "%s:%d.%d", udev->busid, udev->bConfigurationValue, i);
    4.37 ++	size = snprintf(busid, sizeof(busid), "%s:%d.%d",
    4.38 ++	udev->busid, udev->bConfigurationValue, i);
    4.39 ++	if (size < 0 || (unsigned int)size >= sizeof(busid)) {
    4.40 ++		err("busid length %i >= %lu or < 0", size,
    4.41 ++		(unsigned long)sizeof(busid));
    4.42 ++		return -1;
    4.43 ++	}
    4.44 + 
    4.45 + 	sif = udev_device_new_from_subsystem_sysname(udev_context, "usb", busid);
    4.46 + 	if (!sif) {
    4.47 +diff --git a/drivers/staging/usbip/userspace/libsrc/usbip_host_driver.c 
    4.48 +b/drivers/staging/usbip/userspace/libsrc/usbip_host_driver.c
    4.49 +index 9d415228883d..c10379439668 100644
    4.50 +--- a/drivers/staging/usbip/userspace/libsrc/usbip_host_driver.c
    4.51 ++++ b/drivers/staging/usbip/userspace/libsrc/usbip_host_driver.c
    4.52 +@@ -39,13 +39,19 @@
    4.53 + static int32_t read_attr_usbip_status(struct usbip_usb_device *udev)
    4.54 + {
    4.55 + 	char status_attr_path[SYSFS_PATH_MAX];
    4.56 ++	int size;
    4.57 + 	int fd;
    4.58 + 	int length;
    4.59 + 	char status;
    4.60 + 	int value = 0;
    4.61 + 
    4.62 +-	snprintf(status_attr_path, SYSFS_PATH_MAX, "%s/usbip_status",
    4.63 +-		 udev->path);
    4.64 ++	size = snprintf(status_attr_path, sizeof(status_attr_path),
    4.65 ++		"%s/usbip_status", udev->path);
    4.66 ++	if (size < 0 || (unsigned int)size >= sizeof(status_attr_path)) {
    4.67 ++		err("usbip_status path length %i >= %lu or < 0", size,
    4.68 ++		(unsigned long)sizeof(status_attr_path));
    4.69 ++		return -1;
    4.70 ++	}
    4.71 + 
    4.72 + 	if ((fd = open(status_attr_path, O_RDONLY)) < 0) {
    4.73 + 		err("error opening attribute %s", status_attr_path);
    4.74 +@@ -224,6 +230,7 @@
    4.75 + {
    4.76 + 	char attr_name[] = "usbip_sockfd";
    4.77 + 	char sockfd_attr_path[SYSFS_PATH_MAX];
    4.78 ++	int size;
    4.79 + 	char sockfd_buff[30];
    4.80 + 	int ret;
    4.81 + 
    4.82 +@@ -244,10 +251,20 @@
    4.83 + 	}
    4.84 + 
    4.85 + 	/* only the first interface is true */
    4.86 +-	snprintf(sockfd_attr_path, sizeof(sockfd_attr_path), "%s/%s",
    4.87 ++	size = snprintf(sockfd_attr_path, sizeof(sockfd_attr_path), "%s/%s",
    4.88 + 		 edev->udev.path, attr_name);
    4.89 ++	if (size < 0 || (unsigned int)size >= sizeof(sockfd_attr_path)) {
    4.90 ++		err("exported device path length %i >= %lu or < 0", size,
    4.91 ++		(unsigned long)sizeof(sockfd_attr_path));
    4.92 ++		return -1;
    4.93 ++	}
    4.94 + 
    4.95 +-	snprintf(sockfd_buff, sizeof(sockfd_buff), "%d\n", sockfd);
    4.96 ++	size = snprintf(sockfd_buff, sizeof(sockfd_buff), "%d\n", sockfd);
    4.97 ++	if (size < 0 || (unsigned int)size >= sizeof(sockfd_buff)) {
    4.98 ++		err("socket length %i >= %lu or < 0", size,
    4.99 ++		(unsigned long)sizeof(sockfd_buff));
   4.100 ++		return -1;
   4.101 ++	}
   4.102 + 
   4.103 + 	ret = write_sysfs_attribute(sockfd_attr_path, sockfd_buff,
   4.104 + 				    strlen(sockfd_buff));
   4.105 +-- 
   4.106 +2.14.1
     5.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     5.2 +++ b/linux/stuff/linux-usbip-fix-implicit-fallthrough-gcc8.patch	Mon May 29 12:23:26 2023 +0000
     5.3 @@ -0,0 +1,25 @@
     5.4 +GCC 7 now warns when switch statements fall through implicitly, and with
     5.5 +-Werror enabled in configure.ac, that makes these tools unbuildable.
     5.6 +
     5.7 +We fix this by notifying the compiler that this particular case statement
     5.8 +is meant to fall through.
     5.9 +
    5.10 +Reviewed-by: Peter Senna Tschudin <peter.senna@xxxxxxxxx>
    5.11 +Signed-off-by: Jonathan Dieter <jdieter@xxxxxxxxx>
    5.12 +---
    5.13 + tools/usb/usbip/src/usbip.c | 2 ++
    5.14 + 1 file changed, 2 insertions(+)
    5.15 +
    5.16 +diff --git a/tools/usb/usbip/src/usbip.c b/tools/usb/usbip/src/usbip.c
    5.17 +index d7599d9..73d8eee 100644
    5.18 +--- a/drivers/staging/usbip/userspace/src/usbip.c
    5.19 ++++ b/drivers/staging/usbip/userspace/src/usbip.c
    5.20 +@@ -176,6 +176,8 @@ int main(int argc, char *argv[])
    5.21 + 			break;
    5.22 + 		case '?':
    5.23 + 			printf("usbip: invalid option\n");
    5.24 ++			/* Terminate after printing error */
    5.25 ++			/* FALLTHRU */
    5.26 + 		default:
    5.27 + 			usbip_usage();
    5.28 + 			goto out;
     6.1 --- a/linux/stuff/linux-with-gcc8.patch	Thu May 25 15:49:26 2023 +0000
     6.2 +++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
     6.3 @@ -1,101 +0,0 @@
     6.4 -Upstream commit e5dfa3f902b9 ("usbip: Fix potential format overflow in
     6.5 -userspace tools")
     6.6 -
     6.7 -
     6.8 -The usbip userspace tools call sprintf()/snprintf() and don't check for
     6.9 -the return value which can lead the paths to overflow, truncating the
    6.10 -final file in the path.
    6.11 -
    6.12 -More urgently, GCC 7 now warns that these aren't checked with
    6.13 --Wformat-overflow, and with -Werror enabled in configure.ac, that makes
    6.14 -these tools unbuildable.
    6.15 -
    6.16 -This patch fixes these problems by replacing sprintf() with snprintf() in
    6.17 -one place and adding checks for the return value of snprintf().
    6.18 -
    6.19 -Reviewed-by: Peter Senna Tschudin <peter.se...@gmail.com>
    6.20 -Signed-off-by: Jonathan Dieter <jdie...@lesbg.com>
    6.21 -Acked-by: Shuah Khan <shua...@osg.samsung.com>
    6.22 -Signed-off-by: Greg Kroah-Hartman <gre...@linuxfoundation.org>
    6.23 -Signed-off-by: Shuah Khan <shua...@osg.samsung.com>
    6.24 -
    6.25 -diff --git a/tools/usb/usbip/libsrc/usbip_common.c b/tools/usb/usbip/libsrc/usbip_common.c
    6.26 -index ac73710..01dd4b2 100644
    6.27 ---- a/drivers/staging/usbip/userspace/libsrc/usbip_common.c
    6.28 -+++ b/drivers/staging/usbip/userspace/libsrc/usbip_common.c
    6.29 -@@ -215,9 +215,15 @@
    6.30 - 		       struct usbip_usb_interface *uinf)
    6.31 - {
    6.32 - 	char busid[SYSFS_BUS_ID_SIZE];
    6.33 -+	unsigned int size;
    6.34 - 	struct udev_device *sif;
    6.35 - 
    6.36 --	sprintf(busid, "%s:%d.%d", udev->busid, udev->bConfigurationValue, i);
    6.37 -+	size = snprintf(busid, sizeof(busid), "%s:%d.%d",
    6.38 -+	udev->busid, udev->bConfigurationValue, i);
    6.39 -+	if (size >= sizeof(busid)) {
    6.40 -+		err("busid length %u >= %lu", size, sizeof(busid));
    6.41 -+		return -1;
    6.42 -+	}
    6.43 - 
    6.44 - 	sif = udev_device_new_from_subsystem_sysname(udev_context, "usb", busid);
    6.45 - 	if (!sif) {
    6.46 -diff --git a/drivers/staging/usbip/userspace/libsrc/usbip_host_driver.c 
    6.47 -b/drivers/staging/usbip/userspace/libsrc/usbip_host_driver.c
    6.48 -index 9d415228883d..c10379439668 100644
    6.49 ---- a/drivers/staging/usbip/userspace/libsrc/usbip_host_driver.c
    6.50 -+++ b/drivers/staging/usbip/userspace/libsrc/usbip_host_driver.c
    6.51 -@@ -39,13 +39,19 @@
    6.52 - static int32_t read_attr_usbip_status(struct usbip_usb_device *udev)
    6.53 - {
    6.54 - 	char status_attr_path[SYSFS_PATH_MAX];
    6.55 -+	unsigned int size;
    6.56 - 	int fd;
    6.57 - 	int length;
    6.58 - 	char status;
    6.59 - 	int value = 0;
    6.60 - 
    6.61 --	snprintf(status_attr_path, SYSFS_PATH_MAX, "%s/usbip_status",
    6.62 --		 udev->path);
    6.63 -+	size = snprintf(status_attr_path, sizeof(status_attr_path),
    6.64 -+		"%s/usbip_status", udev->path);
    6.65 -+	if (size >= sizeof(status_attr_path)) {
    6.66 -+		err("usbip_status path length %u >= %lu", size,
    6.67 -+		sizeof(status_attr_path));
    6.68 -+		return -1;
    6.69 -+	}
    6.70 - 
    6.71 - 	if ((fd = open(status_attr_path, O_RDONLY)) < 0) {
    6.72 - 		err("error opening attribute %s", status_attr_path);
    6.73 -@@ -224,6 +230,7 @@
    6.74 - {
    6.75 - 	char attr_name[] = "usbip_sockfd";
    6.76 - 	char sockfd_attr_path[SYSFS_PATH_MAX];
    6.77 -+	unsigned int size;
    6.78 - 	char sockfd_buff[30];
    6.79 - 	int ret;
    6.80 - 
    6.81 -@@ -243,10 +250,19 @@
    6.82 - 	}
    6.83 - 
    6.84 - 	/* only the first interface is true */
    6.85 --	snprintf(sockfd_attr_path, sizeof(sockfd_attr_path), "%s/%s",
    6.86 -+	size = snprintf(sockfd_attr_path, sizeof(sockfd_attr_path), "%s/%s",
    6.87 - 		 edev->udev.path, attr_name);
    6.88 -+	if (size >= sizeof(sockfd_attr_path)) {
    6.89 -+		err("exported device path length %u >= %lu", size,
    6.90 -+		sizeof(sockfd_attr_path));
    6.91 -+		return -1;
    6.92 -+	}
    6.93 - 
    6.94 --	snprintf(sockfd_buff, sizeof(sockfd_buff), "%d\n", sockfd);
    6.95 -+	size = snprintf(sockfd_buff, sizeof(sockfd_buff), "%d\n", sockfd);
    6.96 -+	if (size >= sizeof(sockfd_buff)) {
    6.97 -+		err("socket length %u >= %lu", size, sizeof(sockfd_buff));
    6.98 -+		return -1;
    6.99 -+	}
   6.100 - 
   6.101 - 	ret = write_sysfs_attribute(sockfd_attr_path, sockfd_buff,
   6.102 - 				    strlen(sockfd_buff));
   6.103 --- 
   6.104 -2.14.1
     7.1 --- a/ncursesw-dev/receipt	Thu May 25 15:49:26 2023 +0000
     7.2 +++ b/ncursesw-dev/receipt	Mon May 29 12:23:26 2023 +0000
     7.3 @@ -25,5 +25,5 @@
     7.4  	# nicely for both.
     7.5  	cp -a $install/usr/include		$fs/usr
     7.6  	cp $install/usr/bin/ncursesw6-config	$fs/usr/bin
     7.7 -	cp -a $install/usr/share/pkgconfig	$fs/usr/lib
     7.8 +	cp -a $install/usr/lib/pkgconfig	$fs/usr/lib
     7.9  }