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

diff --git a/queue-4.14/gcov-add-support-for-gcc-10.1.patch b/queue-4.14/gcov-add-support-for-gcc-10.1.patch
new file mode 100644 (file)
index 0000000..60d13b2
--- /dev/null
@@ -0,0 +1,60 @@
+From 130457f934a9ce8bca212ab2ed0fb3b984c1809a 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 1d78ed19a3512..1276aabaab550 100644
+--- a/kernel/gcov/Kconfig
++++ b/kernel/gcov/Kconfig
+@@ -3,7 +3,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 ca5e5c0ef8536..5b9e76117ded1 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 afb792217485a241e0f7035aa8d589ab14f603f2..ec0da1437df0d7940d9b586c3d75517e353f9f51 100644 (file)
@@ -57,3 +57,4 @@ usb-serial-option-support-dynamic-quectel-usb-compositions.patch
 usb-serial-option-add-support-for-sim7070-sim7080-sim7090-modules.patch
 usb-fix-out-of-sync-data-toggle-if-a-configured-device-is-reconfigured.patch
 usb-typec-ucsi-acpi-check-the-_dep-dependencies.patch
+gcov-add-support-for-gcc-10.1.patch