[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH v6] automation/eclair: update configuration of D4.10


  • To: Stefano Stabellini <sstabellini@xxxxxxxxxx>, "xen-devel@xxxxxxxxxxxxxxxxxxxx" <xen-devel@xxxxxxxxxxxxxxxxxxxx>
  • From: Dmytro Prokopchuk1 <dmytro_prokopchuk1@xxxxxxxx>
  • Date: Wed, 2 Jul 2025 14:05:07 +0000
  • Accept-language: en-US, uk-UA, ru-RU
  • Arc-authentication-results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=epam.com; dmarc=pass action=none header.from=epam.com; dkim=pass header.d=epam.com; arc=none
  • Arc-message-signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=rR6Xcx6hSElClwQM5kxB1BR3kYJ0Z3NzmSSAGj4jo+s=; b=oyN79NGIbU3WzVHsKjt9BtnUGIRtBxbyYH2/MGF7+/FB45q3DzHE6YyeR+tADOi4h0Cr2DX/Lf2542zuIWtkLS2eYYtf+W+TqzgfoR5Eh1jPMNZ9AAyTfevFHrXTV+703z3XNMPVc6xrZ8GqahW2dcYjIYMsG1tBuieOm7F92shsPasdNFjo7pI7p2XWdiyChe5C8u9PC2CnRqX+oELd/mUeoD/DDtI+BKM9iFb0j3iWPTpn/zdUHvmsv8TWJtiZEYt5nPX84tFnw5ogbpOaZx/ypU36xRoNHYVFJmll3bjM7fOwU43ROzY3EkRCKOFzNcwJxwaxbvDlClGhb9pP7g==
  • Arc-seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=SKXJVrHb8BJb8rN6vtbtegg8s5b8YUsVF28Ydnvgn2GK6xzHnBIyTkZb1+8Ln7aeiV0NBKSzeVruyGZNo+/JqKMeNmlFZy3RuhN3w8GjGVhm4miZjYIr0VYOdCHDJ26XS7t5BxJJ+U2RY3GyULOAYLzqJqaPSyYVMmpU4/bZPmsYUntKHmF8MBfxVJxSHg2beV2rFcXUAwcPgWrFyFVzBFmNpRLKawImlyBecb86pzGAXsXlEgyTudYlQwELiRVe1CZ9r/hvvW9B/ZlwtEv5tRUcgGZVmQD3U7+vcADQfsGCzN88vbBXC7g1JGnFm+RYeBCb/azexjrEJgD+ORS7vQ==
  • Authentication-results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=epam.com;
  • Cc: Andrew Cooper <andrew.cooper3@xxxxxxxxxx>, "michal.orzel@xxxxxxx" <michal.orzel@xxxxxxx>, "jbeulich@xxxxxxxx" <jbeulich@xxxxxxxx>, "julien@xxxxxxx" <julien@xxxxxxx>, "roger.pau@xxxxxxxxxx" <roger.pau@xxxxxxxxxx>, "bertrand.marquis@xxxxxxx" <bertrand.marquis@xxxxxxx>, "federico.serafini@xxxxxxxxxxx" <federico.serafini@xxxxxxxxxxx>, Nicola Vetrini <nicola.vetrini@xxxxxxxxxxx>
  • Delivery-date: Wed, 02 Jul 2025 14:05:22 +0000
  • List-id: Xen developer discussion <xen-devel.lists.xenproject.org>
  • Thread-index: AQHb61pQiVWFZuQzhEmR/C63uK1zeg==
  • Thread-topic: [PATCH v6] automation/eclair: update configuration of D4.10

Hello, All!

Do you have any comments on this patch?
Вoes it need any improvement?

BR, Dmytro.

On 6/24/25 04:19, Stefano Stabellini wrote:
> MISRA C Directive 4.10 states that "Precautions shall be taken in order
> to prevent the contents of a header file being included more than
> once".
> 
> Add a SAF tag and update the comment on top of cpufeatures.h.
> Add a header inclusion guard to compile.h.
> Generate header guards for hypercall-defs.h
> 
> Update ECLAIR configuration to:
> - extend existing deviation to other comments explicitly saying a file
>    is intended for multiple inclusion;
> - extend existing deviation to other autogenerated files;
> - tag the guidelines as clean.
> 
> Update deviations.rst accordingly.
> 
> Signed-off-by: Federico Serafini <federico.serafini@xxxxxxxxxxx>
> Signed-off-by: Stefano Stabellini <stefano.stabellini@xxxxxxx>
> Acked-by: Jan Beulich <jbeulich@xxxxxxxx> # x86
> ---
> Changes in v6:
> - remove in-code comment and use SAF-8-safe instead
> - add header guards for hypercall-defs.h
> 
> Successful pipeline:
> https://gitlab.com/xen-project/people/sstabellini/xen/-/pipelines/1885561040
> ---
> 
> diff --git a/automation/eclair_analysis/ECLAIR/deviations.ecl 
> b/automation/eclair_analysis/ECLAIR/deviations.ecl
> index 9c67358d46..3b5bc87e1d 100644
> --- a/automation/eclair_analysis/ECLAIR/deviations.ecl
> +++ b/automation/eclair_analysis/ECLAIR/deviations.ecl
> @@ -72,11 +72,14 @@ they are not instances of commented-out code."
>   -config=MC3A2.D4.3,reports+={deliberate, 
> "any_area(any_loc(file(arm64_bitops))&&context(name(int_clear_mask16)))"}
>   -doc_end
>   
> --doc_begin="Files that are intended to be included more than once do not 
> need to
> -conform to the directive."
> +-doc_begin="Files that are intended to be included more than once (and have
> +a comment that says this explicitly) do not need to conform to the 
> directive."
>   -config=MC3A2.D4.10,reports+={safe, "first_area(text(^/\\* This file is 
> intended to be included multiple times\\. \\*/$, begin-4))"}
> --config=MC3A2.D4.10,reports+={safe, "first_area(text(^/\\* Generated file, 
> do not edit! \\*/$, begin-3))"}
> --config=MC3A2.D4.10,reports+={safe, 
> "all_area(all_loc(file(^xen/include/generated/autoconf.h$)))"}
> +-config=MC3A2.D4.10,reports+={safe, "first_area(text(^/\\* Generated file, 
> do not edit! \\*/$, begin-3...begin-2))"}
> +-doc_end
> +
> +-doc_begin="Autogenerated files that do not need to conform to the 
> directive."
> +-config=MC3A2.D4.10,reports+={safe, 
> "all_area(all_loc(file(^xen/include/generated/autoconf\\.h$)))"}
>   -doc_end
>   
>   -doc_begin="Including multiple times a .c file is safe because every 
> function or data item
> diff --git a/automation/eclair_analysis/ECLAIR/tagging.ecl 
> b/automation/eclair_analysis/ECLAIR/tagging.ecl
> index f9da5d5f4d..b95f07feb0 100644
> --- a/automation/eclair_analysis/ECLAIR/tagging.ecl
> +++ b/automation/eclair_analysis/ECLAIR/tagging.ecl
> @@ -23,6 +23,7 @@
>   "MC3A2.D1.1||
>   MC3A2.D2.1||
>   MC3A2.D4.1||
> +MC3A2.D4.10||
>   MC3A2.D4.11||
>   MC3A2.D4.14||
>   MC3A2.R1.1||
> diff --git a/docs/misra/deviations.rst b/docs/misra/deviations.rst
> index fe0b1e10a2..63caa8f4a2 100644
> --- a/docs/misra/deviations.rst
> +++ b/docs/misra/deviations.rst
> @@ -30,6 +30,18 @@ Deviations related to MISRA C:2012 Directives:
>          not to add an additional encapsulation layer.
>        - Tagged as `deliberate` for ECLAIR.
>   
> +   * - D4.10
> +     - Files that are intended to be included more than once (and have
> +       a comment that says this explicitly) do not need to conform to the
> +       directive.
> +     - Tagged as `safe` for ECLAIR.
> +
> +   * - D4.10
> +     - There are autogenerated files that do not need to comply to the
> +       directive.
> +     - Tagged as `safe` for ECLAIR. Such files are:
> +        - xen/include/generated/autoconf.h
> +
>      * - D4.10
>        - Including multiple times a .c file is safe because every function or 
> data item
>          it defines would in (the common case) be already defined.
> diff --git a/xen/arch/x86/include/asm/cpufeatures.h 
> b/xen/arch/x86/include/asm/cpufeatures.h
> index 9e3ed21c02..dce0713adf 100644
> --- a/xen/arch/x86/include/asm/cpufeatures.h
> +++ b/xen/arch/x86/include/asm/cpufeatures.h
> @@ -1,7 +1,6 @@
> -/*
> - * Explicitly intended for multiple inclusion.
> - */
> +/* This file is intended to be included multiple times. */
>   
> +/* SAF-8-safe */
>   #include <xen/lib/x86/cpuid-autogen.h>
>   
>   /* Number of capability words covered by the featureset words. */
> diff --git a/xen/include/xen/compile.h.in b/xen/include/xen/compile.h.in
> index 3151d1e7d1..9206341ba6 100644
> --- a/xen/include/xen/compile.h.in
> +++ b/xen/include/xen/compile.h.in
> @@ -1,3 +1,6 @@
> +#ifndef XEN_COMPILE_H
> +#define XEN_COMPILE_H
> +
>   #define XEN_COMPILE_DATE    "@@date@@"
>   #define XEN_COMPILE_TIME    "@@time@@"
>   #define XEN_COMPILE_BY              "@@whoami@@"
> diff --git a/xen/scripts/gen_hypercall.awk b/xen/scripts/gen_hypercall.awk
> index 1a7e051fde..47a18cd75e 100644
> --- a/xen/scripts/gen_hypercall.awk
> +++ b/xen/scripts/gen_hypercall.awk
> @@ -2,6 +2,8 @@
>   # the calls of the handlers inside a switch() statement.
>   
>   BEGIN {
> +    printf("#ifndef XEN_HYPERCALL_DEFS_H\n");
> +    printf("#define XEN_HYPERCALL_DEFS_H\n\n");
>       printf("/* Generated file, do not edit! */\n\n");
>       e = 0;
>       n = 0;
> @@ -311,4 +313,5 @@ END {
>                   printf("[__HYPERVISOR_%s] = %d, \\\n", fn[call_fn[i]], 
> n_args[call_fn[i]]);
>           printf("}\n");
>       }
> +    printf("\n#endif /* XEN_HYPERCALL_DEFS_H */\n");
>   }
> diff --git a/xen/tools/process-banner.sed b/xen/tools/process-banner.sed
> index 56c76558bc..4cf3f9a116 100755
> --- a/xen/tools/process-banner.sed
> +++ b/xen/tools/process-banner.sed
> @@ -12,3 +12,8 @@ s_(.*)_"\1\\n"_
>   
>   # Trailing \ on all but the final line.
>   $!s_$_ \\_
> +
> +# Append closing header guard
> +$a\
> +\
> +#endif /* XEN_COMPILE_H */

 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.