]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
Fixes for 5.8
authorSasha Levin <sashal@kernel.org>
Wed, 16 Sep 2020 00:21:43 +0000 (20:21 -0400)
committerSasha Levin <sashal@kernel.org>
Wed, 16 Sep 2020 00:21:43 +0000 (20:21 -0400)
Signed-off-by: Sasha Levin <sashal@kernel.org>
queue-5.8/gcov-add-support-for-gcc-10.1.patch [new file with mode: 0644]
queue-5.8/series

diff --git a/queue-5.8/gcov-add-support-for-gcc-10.1.patch b/queue-5.8/gcov-add-support-for-gcc-10.1.patch
new file mode 100644 (file)
index 0000000..ece131e
--- /dev/null
@@ -0,0 +1,60 @@
+From 71efab14c529601e84710e6c8bf73ae89d18faf6 Mon Sep 17 00:00:00 2001
+From: Sasha Levin <sashal@kernel.org>
+Date: Thu, 10 Sep 2020 14:52:01 +0200
+Subject: gcov: add support for GCC 10.1
+
+From: Peter Oberparleiter <oberpar@linux.ibm.com>
+
+[ Upstream commit 40249c6962075c040fd071339acae524f18bfac9 ]
+
+Using gcov to collect coverage data for kernels compiled with GCC 10.1
+causes random malfunctions and kernel crashes.  This is the result of a
+changed GCOV_COUNTERS value in GCC 10.1 that causes a mismatch between
+the layout of the gcov_info structure created by GCC profiling code and
+the related structure used by the kernel.
+
+Fix this by updating the in-kernel GCOV_COUNTERS value.  Also re-enable
+config GCOV_KERNEL for use with GCC 10.
+
+Reported-by: Colin Ian King <colin.king@canonical.com>
+Reported-by: Leon Romanovsky <leonro@nvidia.com>
+Signed-off-by: Peter Oberparleiter <oberpar@linux.ibm.com>
+Tested-by: Leon Romanovsky <leonro@nvidia.com>
+Tested-and-Acked-by: Colin Ian King <colin.king@canonical.com>
+Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
+Signed-off-by: Sasha Levin <sashal@kernel.org>
+---
+ kernel/gcov/Kconfig   | 1 -
+ kernel/gcov/gcc_4_7.c | 4 +++-
+ 2 files changed, 3 insertions(+), 2 deletions(-)
+
+diff --git a/kernel/gcov/Kconfig b/kernel/gcov/Kconfig
+index bb4b680e8455a..3110c77230c7f 100644
+--- a/kernel/gcov/Kconfig
++++ b/kernel/gcov/Kconfig
+@@ -4,7 +4,6 @@ menu "GCOV-based kernel profiling"
+ config GCOV_KERNEL
+       bool "Enable gcov-based kernel profiling"
+       depends on DEBUG_FS
+-      depends on !CC_IS_GCC || GCC_VERSION < 100000
+       select CONSTRUCTORS if !UML
+       default n
+       help
+diff --git a/kernel/gcov/gcc_4_7.c b/kernel/gcov/gcc_4_7.c
+index 908fdf5098c32..53c67c87f141b 100644
+--- a/kernel/gcov/gcc_4_7.c
++++ b/kernel/gcov/gcc_4_7.c
+@@ -19,7 +19,9 @@
+ #include <linux/vmalloc.h>
+ #include "gcov.h"
+-#if (__GNUC__ >= 7)
++#if (__GNUC__ >= 10)
++#define GCOV_COUNTERS                 8
++#elif (__GNUC__ >= 7)
+ #define GCOV_COUNTERS                 9
+ #elif (__GNUC__ > 5) || (__GNUC__ == 5 && __GNUC_MINOR__ >= 1)
+ #define GCOV_COUNTERS                 10
+-- 
+2.25.1
+
index ae7a97102a453b78b9bb2653258c439a49d58949..d702791335f75e9445968623040ee4b33af7bcc1 100644 (file)
@@ -174,3 +174,4 @@ usb-typec-intel_pmc_mux-un-register-the-usb-role-switch.patch
 usb-typec-intel_pmc_mux-do-not-configure-altmode-hpd-high.patch
 usb-typec-intel_pmc_mux-do-not-configure-sbu-and-hsl-orientation-in-alternate-modes.patch
 drm-msm-gpu-make-ringbuffer-readonly.patch
+gcov-add-support-for-gcc-10.1.patch