Re: [PATCH] scripts: checkpatch.pl add warning for dummy label

From: Nitin Kuppelur
Date: Tue Sep 09 2014 - 12:41:42 EST


Hi Joe,

Thanks for feedback.

The idea of adding new warning came from the review comments from
one of my PATCH, where it was suggested by few reviewers to remove such
"Do-Nothing" labels. But current checkpatch.pl does not warn about that.

[PATCH]
http://www.mail-archive.com/linux-kernel@xxxxxxxxxxxxxxx/msg720639.html


Regards,
Nitin

On 09/09/2014 05:43 PM, Joe Perches wrote:
> On Tue, 2014-09-09 at 15:54 +0200, Nitin Kuppelur wrote:
>> Added new warning DUMMY_LABEL in checkpatch.pl. This warns
>> if return statement is encountered just after goto label target
>> like "out:". In such scenario it is best to call "return;" directly
>> instead of "goto out;"
>
> I'm not sure this is desired/correct.
>
> There are many functions written like:
>
> return_type foo(...)
> {
> [some initialization...]
>
> err = some_test(...);
> if (err)
> goto out;
>
> [...]
>
> out:
> [some cleanup...]
> return err;
> }
>
> In many cases, a void function is a simple
> variant of a non-void function and many people
> like to see the same code "shape" in functions,
> just without the init and cleanup bits.
>
>> diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl
> []
>> @@ -3798,10 +3798,14 @@ sub process {
>> if ($sline =~ /^[ \+]}\s*$/ &&
>> $prevline =~ /^\+\treturn\s*;\s*$/ &&
>> $linenr >= 3 &&
>> - $lines[$linenr - 3] =~ /^[ +]/ &&
>> - $lines[$linenr - 3] !~ /^[ +]\s*$Ident\s*:/) {
>> - WARN("RETURN_VOID",
>> - "void function return statements are not generally useful\n" . $hereprev);
>> + $lines[$linenr - 3] =~ /^[ +]/) {
>> + if ($lines[$linenr - 3] !~ /^[ +]\s*$Ident\s*:/) {
>> + WARN("RETURN_VOID",
>> + "void function return statements are not generally useful\n" . $hereprev);
>> + } elsif ($lines[$linenr - 3] =~ /^[ +]\s*$Ident\s*:/) {
>> + WARN("DUMMY_LABEL",
>> + "labels doing nothing are not generally useful\n" . $hereprev);
>> + }
>> }
>>
>> # if statements using unnecessary parentheses - ie: if ((foo == bar))
>
>
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/