Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp4601931pxf; Tue, 30 Mar 2021 11:50:34 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwx34SVF6scNW2xzpBl3S3nvCAQfZ/IWwnrbytUVpWMoomI59avagFH+gf+cVK1Mamx8dMP X-Received: by 2002:a50:fd8b:: with SMTP id o11mr34975328edt.346.1617130234642; Tue, 30 Mar 2021 11:50:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617130234; cv=none; d=google.com; s=arc-20160816; b=v3AJxIUGi8yopxgz2UpYm8ZWdwOhIwludzxshtbk+p7d9KifX5QPdiuC78QwSOr2Ro TXtHT3257HWSA2r1/YZJOHt2ITDYgmbO5EgrlSK8GS9DExu1lF3jucz01esxP5Fv0kH/ Gz9wIfVhRagM7Br8pqxi8NVBHiijeLOIsypdXu1+2eWeFx/RFEa+iSVqvFiNKnen1jrK WBMEwYr88EjWq+xt0LG5JFR0Emd/LQtD/nP/OCN+Whxsy1q1E/dJURw722wyRvR1FGiy YBFrUYW2lYLXR9yl6btkR301gpb5q/M9HTp1Y+zehON1WJbwpmp86eHpbdHHmFQYSHm3 ra2Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:date:cc:to:from:subject:message-id; bh=WaFuqvJZGPkD8wIT4laNaFm1mz/iIKBjksHlMPpuU28=; b=FitC8D/TzKNoMCWLbtJksz38p29O7bZyePiziIDFnHCWUsWzUSzZ1fOUCjpisE8I6d avB8S9rLXtT/vnIW2nqqsWOTu8uIKo9ElrKMLg2pkgRorP9ht3IIgCW+PP8P5eZLVsPv BxvYfLMAfjjkEj/ukIUfiibb7zOJwidkQpL3M7xcunUF5vL11gpUkuB1EV6zf9/GxmIh CF8UBYRpS5dIRJJFF9wE8sEHAvYuwK8jUYg3/SffXLKDDaHe9tFJyqcN5VyAqJI6nSyN peN29Yg/tYkzOcGvuDZucVtvPTx/YHMmW4tzon+gc4drpOir39/ewg5TaPAqO2GbQOUh cFCg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a3si14067733edr.505.2021.03.30.11.50.11; Tue, 30 Mar 2021 11:50:34 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232910AbhC3Ssp (ORCPT + 99 others); Tue, 30 Mar 2021 14:48:45 -0400 Received: from smtprelay0076.hostedemail.com ([216.40.44.76]:39256 "EHLO smtprelay.hostedemail.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S232901AbhC3Ssi (ORCPT ); Tue, 30 Mar 2021 14:48:38 -0400 Received: from omf18.hostedemail.com (clb03-v110.bra.tucows.net [216.40.38.60]) by smtprelay07.hostedemail.com (Postfix) with ESMTP id 1A328181D337B; Tue, 30 Mar 2021 18:48:37 +0000 (UTC) Received: from [192.168.1.159] (unknown [47.151.137.21]) (Authenticated sender: joe@perches.com) by omf18.hostedemail.com (Postfix) with ESMTPA id 0B1202EBFA0; Tue, 30 Mar 2021 18:48:35 +0000 (UTC) Message-ID: Subject: [PATCH] checkpatch: Warn when missing newline in return sysfs_emit() formats From: Joe Perches To: Andrew Morton , Andy Whitcroft Cc: Tomas Winkler , Greg KH , LKML Date: Tue, 30 Mar 2021 11:48:34 -0700 Content-Type: text/plain; charset="ISO-8859-1" User-Agent: Evolution 3.38.1-1 MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=0.10 X-Stat-Signature: gtk9ypfu7oa15o3ox1on1zkwumj79y3y X-Rspamd-Server: rspamout05 X-Rspamd-Queue-Id: 0B1202EBFA0 X-HE-Tag: 1617130115-666885 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org return sysfs_emit() uses should include a newline. Suggest adding a newline when one is missing. Add one using --fix too. Signed-off-by: Joe Perches --- scripts/checkpatch.pl | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl index d67146d0b33c..4dbda85fd7e5 100755 --- a/scripts/checkpatch.pl +++ b/scripts/checkpatch.pl @@ -7198,6 +7198,17 @@ sub process { "Using $1 should generally have parentheses around the comparison\n" . $herecurr); } +# return sysfs_emit(foo, fmt, ...) fmt without newline + if ($line =~ /\breturn\s+sysfs_emit\s*\(\s*$FuncArg\s*,\s*($String)/ && + substr($rawline, $-[6], $+[6] - $-[6]) !~ /\\n"$/) { + my $offset = $+[6] - 1; + if (WARN("SYSFS_EMIT", + "return sysfs_emit(...) formats should include a terminating newline\n" . $herecurr) && + $fix) { + substr($fixed[$fixlinenr], $offset, 0) = '\\n'; + } + } + # nested likely/unlikely calls if ($line =~ /\b(?:(?:un)?likely)\s*\(\s*!?\s*(IS_ERR(?:_OR_NULL|_VALUE)?|WARN)/) { WARN("LIKELY_MISUSE",