]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
Fixes for 5.4
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.4/gcov-add-support-for-gcc-10.1.patch [new file with mode: 0644]
queue-5.4/series

diff --git a/queue-5.4/gcov-add-support-for-gcc-10.1.patch b/queue-5.4/gcov-add-support-for-gcc-10.1.patch
new file mode 100644 (file)
index 0000000..3410ec9
--- /dev/null
@@ -0,0 +1,60 @@
+From 528c4d782ba8d3c55031b198cd9b9d6c780f067d 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 005d8b851bc18..3941a9c48f833 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 ec37563674d62..60c7be5ff5c8c 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 b86b4ddb593441353e64f20cbb4f476e50a984fc..d090876a34c7750b1382fab96cf4e982c7bbfd58 100644 (file)
@@ -127,3 +127,4 @@ usb-fix-out-of-sync-data-toggle-if-a-configured-device-is-reconfigured.patch
 usb-typec-ucsi-acpi-check-the-_dep-dependencies.patch
 drm-msm-gpu-make-ringbuffer-readonly.patch
 drm-msm-disable-the-rptr-shadow.patch
+gcov-add-support-for-gcc-10.1.patch