Re: [PATCH] scripts/checkpatch.pl - don't check for const structs if list is empty

From: Joe Perches
Date: Tue Sep 03 2019 - 12:05:55 EST


On Tue, 2019-09-03 at 06:38 -0400, Valdis KlÄtnieks wrote:
> If the list of structures we expect to be const is empty (due to file permissions,
> or the file being empty, etc), we get odd complaints about structures:
>
> [/usr/src/linux-next] scripts/checkpatch.pl -f drivers/staging/netlogic/platform_net.h
> No structs that should be const will be found - file '/usr/src/linux-next/scripts/const_structs.checkpatch': Permission denied
> WARNING: struct should normally be const
> #9: FILE: drivers/staging/netlogic/platform_net.h:9:
> +struct xlr_net_data {
>
> WARNING: struct should normally be const
> #20: FILE: drivers/staging/netlogic/platform_net.h:20:
> + struct xlr_fmn_info *gmac_fmn_info;
>
> total: 0 errors, 2 warnings, 0 checks, 21 lines checked
>
> Fix it so that it actually *obeys* what it said about not finding structures.
>
> Reported-by: Pablo Pellecchia <pablo9891@xxxxxxxxx>
> Signed-off-by: Valdis Kletnieks <valdis.kletnieks@xxxxxx>
> ---
> diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl
> index f4b6127ff469..103c67665f61 100755
> --- a/scripts/checkpatch.pl
> +++ b/scripts/checkpatch.pl
> @@ -6497,7 +6497,7 @@ sub process {
>
> # check for various structs that are normally const (ops, kgdb, device_tree)
> # and avoid what seem like struct definitions 'struct foo {'
> - if ($line !~ /\bconst\b/ &&
> + if ($line !~ /\bconst\b/ && $const_structs ne "" &&

Seems sensible, thanks.

I think this would read better with this test order reversed.

Maybe this should verify that const does not exist before the
specific struct found: (and is not also a forward declaration)
---
scripts/checkpatch.pl | 9 +++++----
1 file changed, 5 insertions(+), 4 deletions(-)

diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl
index f4b6127ff469..77d585950ab0 100755
--- a/scripts/checkpatch.pl
+++ b/scripts/checkpatch.pl
@@ -6496,11 +6496,12 @@ sub process {
}

# check for various structs that are normally const (ops, kgdb, device_tree)
-# and avoid what seem like struct definitions 'struct foo {'
- if ($line !~ /\bconst\b/ &&
- $line =~ /\bstruct\s+($const_structs)\b(?!\s*\{)/) {
+# avoid struct definitions 'struct foo {' and forward declarations 'struct foo;'
+ if ($const_structs ne "" &&
+ $line =~ /((\bstruct\s+($const_structs))\b(?!\s*[\{;]))/ &&
+ $line !~ /\bconst\s+\Q$1\E/) {
WARN("CONST_STRUCT",
- "struct $1 should normally be const\n" . $herecurr);
+ "struct $2 should normally be const\n" . $herecurr);
}

# use of NR_CPUS is usually wrong