Consolidate the if (foo) bar(foo) detectors into a single check. Add debugfs_remove and family.
Based on a patch by Constantine Shulyupin <co...@makelinux.com>. Signed-off-by: Andy Whitcroft <a...@canonical.com> --- scripts/checkpatch.pl | 20 ++++++++------------ 1 file changed, 8 insertions(+), 12 deletions(-) This is a fully merged version as the fix patch was bigger than the whole merged patch and this is much clearer as to purpose. Hope that makes sense. -apw diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl index ae01b90..e83a137 100755 --- a/scripts/checkpatch.pl +++ b/scripts/checkpatch.pl @@ -3239,20 +3239,16 @@ sub process { $herecurr); } +# check for needless "if (<foo>) fn(<foo>)" uses + if ($prevline =~ /\bif\s*\(\s*($Lval)\s*\)/) { + my $expr = '\s*\(\s*' . quotemeta($1) . '\s*\)\s*;'; + # check for needless kfree() checks - if ($prevline =~ /\bif\s*\(([^\)]*)\)/) { - my $expr = $1; - if ($line =~ /\bkfree\(\Q$expr\E\);/) { - WARN("NEEDLESS_KFREE", - "kfree(NULL) is safe this check is probably not required\n" . $hereprev); - } - } # check for needless usb_free_urb() checks - if ($prevline =~ /\bif\s*\(([^\)]*)\)/) { - my $expr = $1; - if ($line =~ /\busb_free_urb\(\Q$expr\E\);/) { - WARN("NEEDLESS_USB_FREE_URB", - "usb_free_urb(NULL) is safe this check is probably not required\n" . $hereprev); +# check for needless debugfs_remove() and debugfs_remove_recursive*() checks + if ($line =~ /\b(kfree|usb_free_urb|debugfs_remove(?:_recursive)?)$expr/) { + WARN('NEEDLESS_IF', + "$1(NULL) is safe this check is probably not required\n" . $hereprev); } } -- 1.7.10.4 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/