From: Greg Kroah-Hartman Date: Mon, 24 Oct 2022 11:18:47 +0000 (+0200) Subject: 5.4-stable patches X-Git-Tag: v6.0.4~11 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=d60ab95ed31d947f84a399c411dc5287d491a281;p=thirdparty%2Fkernel%2Fstable-queue.git 5.4-stable patches added patches: gcov-support-gcc-12.1-and-newer-compilers.patch --- diff --git a/queue-5.4/gcov-support-gcc-12.1-and-newer-compilers.patch b/queue-5.4/gcov-support-gcc-12.1-and-newer-compilers.patch new file mode 100644 index 00000000000..c8efff2f568 --- /dev/null +++ b/queue-5.4/gcov-support-gcc-12.1-and-newer-compilers.patch @@ -0,0 +1,80 @@ +From 977ef30a7d888eeb52fb6908f99080f33e5309a8 Mon Sep 17 00:00:00 2001 +From: Martin Liska +Date: Thu, 13 Oct 2022 09:40:59 +0200 +Subject: gcov: support GCC 12.1 and newer compilers + +From: Martin Liska + +commit 977ef30a7d888eeb52fb6908f99080f33e5309a8 upstream. + +Starting with GCC 12.1, the created .gcda format can't be read by gcov +tool. There are 2 significant changes to the .gcda file format that +need to be supported: + +a) [gcov: Use system IO buffering] + (23eb66d1d46a34cb28c4acbdf8a1deb80a7c5a05) changed that all sizes in + the format are in bytes and not in words (4B) + +b) [gcov: make profile merging smarter] + (72e0c742bd01f8e7e6dcca64042b9ad7e75979de) add a new checksum to the + file header. + +Tested with GCC 7.5, 10.4, 12.2 and the current master. + +Link: https://lkml.kernel.org/r/624bda92-f307-30e9-9aaa-8cc678b2dfb2@suse.cz +Signed-off-by: Martin Liska +Tested-by: Peter Oberparleiter +Reviewed-by: Peter Oberparleiter +Cc: +Signed-off-by: Andrew Morton +Signed-off-by: Greg Kroah-Hartman +--- + kernel/gcov/gcc_4_7.c | 18 ++++++++++++++++-- + 1 file changed, 16 insertions(+), 2 deletions(-) + +--- a/kernel/gcov/gcc_4_7.c ++++ b/kernel/gcov/gcc_4_7.c +@@ -33,6 +33,13 @@ + + #define GCOV_TAG_FUNCTION_LENGTH 3 + ++/* Since GCC 12.1 sizes are in BYTES and not in WORDS (4B). */ ++#if (__GNUC__ >= 12) ++#define GCOV_UNIT_SIZE 4 ++#else ++#define GCOV_UNIT_SIZE 1 ++#endif ++ + static struct gcov_info *gcov_info_head; + + /** +@@ -451,12 +458,18 @@ static size_t convert_to_gcda(char *buff + pos += store_gcov_u32(buffer, pos, info->version); + pos += store_gcov_u32(buffer, pos, info->stamp); + ++#if (__GNUC__ >= 12) ++ /* Use zero as checksum of the compilation unit. */ ++ pos += store_gcov_u32(buffer, pos, 0); ++#endif ++ + for (fi_idx = 0; fi_idx < info->n_functions; fi_idx++) { + fi_ptr = info->functions[fi_idx]; + + /* Function record. */ + pos += store_gcov_u32(buffer, pos, GCOV_TAG_FUNCTION); +- pos += store_gcov_u32(buffer, pos, GCOV_TAG_FUNCTION_LENGTH); ++ pos += store_gcov_u32(buffer, pos, ++ GCOV_TAG_FUNCTION_LENGTH * GCOV_UNIT_SIZE); + pos += store_gcov_u32(buffer, pos, fi_ptr->ident); + pos += store_gcov_u32(buffer, pos, fi_ptr->lineno_checksum); + pos += store_gcov_u32(buffer, pos, fi_ptr->cfg_checksum); +@@ -470,7 +483,8 @@ static size_t convert_to_gcda(char *buff + /* Counter record. */ + pos += store_gcov_u32(buffer, pos, + GCOV_TAG_FOR_COUNTER(ct_idx)); +- pos += store_gcov_u32(buffer, pos, ci_ptr->num * 2); ++ pos += store_gcov_u32(buffer, pos, ++ ci_ptr->num * 2 * GCOV_UNIT_SIZE); + + for (cv_idx = 0; cv_idx < ci_ptr->num; cv_idx++) { + pos += store_gcov_u64(buffer, pos, diff --git a/queue-5.4/series b/queue-5.4/series index 84f98d7efe5..486631e06be 100644 --- a/queue-5.4/series +++ b/queue-5.4/series @@ -52,6 +52,7 @@ media-cedrus-set-the-platform-driver-data-earlier.patch kvm-x86-emulator-fix-handing-of-pop-ss-to-correctly-set-interruptibility.patch kvm-nvmx-unconditionally-purge-queued-injected-events-on-nested-exit.patch kvm-vmx-drop-bits-31-16-when-shoving-exception-error-code-into-vmcs.patch +gcov-support-gcc-12.1-and-newer-compilers.patch drm-nouveau-fix-a-use-after-free-in-nouveau_gem_prime_import_sg_table.patch selinux-use-grep-e-instead-of-egrep.patch tracing-disable-interrupt-or-preemption-before-acquiring-arch_spinlock_t.patch