2022-12-20 11:17:51

by Rickard x Andersson

[permalink] [raw]
Subject: [PATCH v2] gcov: Add support for checksum field

From: Rickard x Andersson <[email protected]>

In GCC version 12.1 a checksum field was added.

This patch fixes a kernel crash occurring during boot when
using gcov-kernel with GCC version 12.2. The crash occurred on
a system running on i.MX6SX.

Fixes: 977ef30a7d88 ("gcov: support GCC 12.1 and newer compilers")
Signed-off-by: Rickard x Andersson <[email protected]>
Reviewed-by: Peter Oberparleiter <[email protected]>
Tested-by: Peter Oberparleiter <[email protected]>
Cc: <[email protected]>
---
kernel/gcov/gcc_4_7.c | 5 +++++
1 file changed, 5 insertions(+)

diff --git a/kernel/gcov/gcc_4_7.c b/kernel/gcov/gcc_4_7.c
index c699feda21ac..04880d8fba25 100644
--- a/kernel/gcov/gcc_4_7.c
+++ b/kernel/gcov/gcc_4_7.c
@@ -85,6 +85,7 @@ struct gcov_fn_info {
* @version: gcov version magic indicating the gcc version used for compilation
* @next: list head for a singly-linked list
* @stamp: uniquifying time stamp
+ * @checksum: unique object checksum
* @filename: name of the associated gcov data file
* @merge: merge functions (null for unused counter type)
* @n_functions: number of instrumented functions
@@ -97,6 +98,10 @@ struct gcov_info {
unsigned int version;
struct gcov_info *next;
unsigned int stamp;
+ /* Since GCC 12.1 a checksum field is added. */
+#if (__GNUC__ >= 12)
+ unsigned int checksum;
+#endif
const char *filename;
void (*merge[GCOV_COUNTERS])(gcov_type *, unsigned int);
unsigned int n_functions;
--
2.30.2


2022-12-20 18:16:54

by Peter Oberparleiter

[permalink] [raw]
Subject: Re: [PATCH v2] gcov: Add support for checksum field

On 20.12.2022 11:23, Rickard Andersson wrote:
> From: Rickard x Andersson <[email protected]>
>
> In GCC version 12.1 a checksum field was added.
>
> This patch fixes a kernel crash occurring during boot when
> using gcov-kernel with GCC version 12.2. The crash occurred on
> a system running on i.MX6SX.
>
> Fixes: 977ef30a7d88 ("gcov: support GCC 12.1 and newer compilers")
> Signed-off-by: Rickard x Andersson <[email protected]>
> Reviewed-by: Peter Oberparleiter <[email protected]>
> Tested-by: Peter Oberparleiter <[email protected]>
> Cc: <[email protected]>

Thank you for the fix!

Andrew, could you pick this up via your tree?

> ---
> kernel/gcov/gcc_4_7.c | 5 +++++
> 1 file changed, 5 insertions(+)
>
> diff --git a/kernel/gcov/gcc_4_7.c b/kernel/gcov/gcc_4_7.c
> index c699feda21ac..04880d8fba25 100644
> --- a/kernel/gcov/gcc_4_7.c
> +++ b/kernel/gcov/gcc_4_7.c
> @@ -85,6 +85,7 @@ struct gcov_fn_info {
> * @version: gcov version magic indicating the gcc version used for compilation
> * @next: list head for a singly-linked list
> * @stamp: uniquifying time stamp
> + * @checksum: unique object checksum
> * @filename: name of the associated gcov data file
> * @merge: merge functions (null for unused counter type)
> * @n_functions: number of instrumented functions
> @@ -97,6 +98,10 @@ struct gcov_info {
> unsigned int version;
> struct gcov_info *next;
> unsigned int stamp;
> + /* Since GCC 12.1 a checksum field is added. */
> +#if (__GNUC__ >= 12)
> + unsigned int checksum;
> +#endif
> const char *filename;
> void (*merge[GCOV_COUNTERS])(gcov_type *, unsigned int);
> unsigned int n_functions;

--
Peter Oberparleiter
Linux on IBM Z Development - IBM Germany R&D

2022-12-20 18:28:11

by Peter Oberparleiter

[permalink] [raw]
Subject: Re: [PATCH v2] gcov: Add support for checksum field

On 20.12.2022 18:53, Peter Oberparleiter wrote:
> On 20.12.2022 11:23, Rickard Andersson wrote:
>> From: Rickard x Andersson <[email protected]>
>>
>> In GCC version 12.1 a checksum field was added.
>>
>> This patch fixes a kernel crash occurring during boot when
>> using gcov-kernel with GCC version 12.2. The crash occurred on
>> a system running on i.MX6SX.
>>
>> Fixes: 977ef30a7d88 ("gcov: support GCC 12.1 and newer compilers")
>> Signed-off-by: Rickard x Andersson <[email protected]>
>> Reviewed-by: Peter Oberparleiter <[email protected]>
>> Tested-by: Peter Oberparleiter <[email protected]>
>> Cc: <[email protected]>
>
> Thank you for the fix!
>
> Andrew, could you pick this up via your tree?

Oh, I forgot to add Martin's R-B from the v1 review (see [1]), so please
include:

Reviewed-By: Martin Liska <[email protected]>

https://lore.kernel.org/lkml/[email protected]/t/#mc2625879466e8af245cbebcc99acc4b8dd0b8cdc

>
>> ---
>> kernel/gcov/gcc_4_7.c | 5 +++++
>> 1 file changed, 5 insertions(+)
>>
>> diff --git a/kernel/gcov/gcc_4_7.c b/kernel/gcov/gcc_4_7.c
>> index c699feda21ac..04880d8fba25 100644
>> --- a/kernel/gcov/gcc_4_7.c
>> +++ b/kernel/gcov/gcc_4_7.c
>> @@ -85,6 +85,7 @@ struct gcov_fn_info {
>> * @version: gcov version magic indicating the gcc version used for compilation
>> * @next: list head for a singly-linked list
>> * @stamp: uniquifying time stamp
>> + * @checksum: unique object checksum
>> * @filename: name of the associated gcov data file
>> * @merge: merge functions (null for unused counter type)
>> * @n_functions: number of instrumented functions
>> @@ -97,6 +98,10 @@ struct gcov_info {
>> unsigned int version;
>> struct gcov_info *next;
>> unsigned int stamp;
>> + /* Since GCC 12.1 a checksum field is added. */
>> +#if (__GNUC__ >= 12)
>> + unsigned int checksum;
>> +#endif
>> const char *filename;
>> void (*merge[GCOV_COUNTERS])(gcov_type *, unsigned int);
>> unsigned int n_functions;
>

--
Peter Oberparleiter
Linux on IBM Z Development - IBM Germany R&D