Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp2578600imm; Fri, 20 Jul 2018 00:49:52 -0700 (PDT) X-Google-Smtp-Source: AAOMgpcii7nzDKQdGloEZT1fIvcF5lWxBGgFB+XJu32pJZM2suTEWAxz8pEjQiryHMc+tQtgWlEq X-Received: by 2002:a62:5543:: with SMTP id j64-v6mr1111046pfb.188.1532072992550; Fri, 20 Jul 2018 00:49:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532072992; cv=none; d=google.com; s=arc-20160816; b=ExR4bvmXwhCgzEcovJIP4z3DcVSrlgnNGWw4vb+4rytFdlozJTaexHzEIgqG3c3+I1 osvHytQXI/0b26rOVs3ZYqUlGZdU1kG6Mf9hChf8yNPSSkj2F1i4pYjdKUJ3zPsZ0mEz Op5yRr+rzFA7Vz1npYul5hJWTNvY4Sc/GoLSv+OYE0j6N2QR/rik+6g4Pq0z/XoMybRY U0Xx2GciDUDiRAzjNHX0qezNtazKV6xpYuLOoyk6RN6Pe7IWtRlmjlrUkfDuOhXpcVRJ tUf2zQkXw0QgNQ2E7aj1oEHh2/nFAw6CypuBMvIGuDzxhs3u+RcHHAJt9+/C0V2ktH/Y CFWg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=41Tb/ovCYj+O5JnPlIID4cOCdfV9w4PegPrHuavci74=; b=BK0n1dD73Cyo0u9jp4tK39Zu2o1PqgynkFMd/OcmtlUkjO63eYXPe7vcBNIvaTeTKp 1z5eKq5NdMN8u/DOhNswf0LjDzICjFLFPFzSjYgEim47ky9MYCtUSJqHEeMkV/FpFpng l30MPTWsYJU1P4Y1ka3Yek0q3OxlqYRLcKNzaU0QIpiIdeSwZ99fpFdpmSHB9hdvX2SV g/ag3TwajNKeVsL0cs6X2ILY/QqUheegiV4p+9J0oNmLOKkSBi+zMXee8vV7Z0tQMVuN I3b+McW+iv7X9QzOizxPklace484piMSWDTp34H5pwSwymltotAJYOV+wPRrS5lW9V29 CDMg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gouders.net header.s=gnet header.b=YKKPLOcY; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p11-v6si1316076pgh.274.2018.07.20.00.49.38; Fri, 20 Jul 2018 00:49:52 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gouders.net header.s=gnet header.b=YKKPLOcY; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728271AbeGTIfj (ORCPT + 99 others); Fri, 20 Jul 2018 04:35:39 -0400 Received: from services.gouders.net ([141.101.32.176]:54496 "EHLO services.gouders.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727141AbeGTIfi (ORCPT ); Fri, 20 Jul 2018 04:35:38 -0400 Received: from lena.gouders.net ([193.175.198.193]) (authenticated bits=0) by services.gouders.net (8.14.8/8.14.8) with ESMTP id w6K7mGpI031540 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES128-GCM-SHA256 bits=128 verify=NO); Fri, 20 Jul 2018 09:48:27 +0200 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=gouders.net; s=gnet; t=1532072908; bh=RC4mWJZYhMl7JHiAjT75Qx//tBV/boReNxyhISHoMpY=; h=From:To:Cc:Subject:Date:In-Reply-To:References; b=YKKPLOcY2E80z9PPM/4YD/X3m451h/l/A28KuPSVLT4Rz+l1blBeu823sE9C2P31k dDoWoNIHfC2TOqBLeXNpnSfehanM5blHOYbz37/SBg1Vacaiun9VXNpTawt2xi1UNu FSytM3hjhbd46oKP0tIPV1bJ5Hn5dRtlL47shfXw= From: Dirk Gouders To: Joe Perches Cc: Dirk Gouders , Andy Whitcroft , Masahiro Yamada , linux-kbuild@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v2] checkpatch: kbuild: if_changed: check for multiple calls in targets Date: Fri, 20 Jul 2018 09:48:04 +0200 Message-Id: <20180720074804.4160-1-dirk@gouders.net> X-Mailer: git-send-email 2.16.1 In-Reply-To: References: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The kbuild function if_changed should not be called more than once for a target. Because that function writes the command line to a .cmd file for later tests, multiple calls of it within a target would result in overwrites of previous values and effectively render the command line test meaningless, resulting in flip-flop behaviour. Add a check for makefiles and kbuild files and produce an error for targets with multiple calls to if_changed. Three examples that now could be detected: 98f78525371b55ccd (x86/boot: Refuse to build with data relocations) 6a8dfe1cac5c591ae (microblaze: support U-BOOT image format) 684151a75bf25f5ae (sparc32: added U-Boot build target: uImage) Reviewed-by: Joe Perches Suggested-by: Masahiro Yamada Signed-off-by: Dirk Gouders --- v2: rework commit message and regular expression --- scripts/checkpatch.pl | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl index 447857ffaf6b..437e98414f74 100755 --- a/scripts/checkpatch.pl +++ b/scripts/checkpatch.pl @@ -2911,6 +2911,14 @@ sub process { "Use of $flag is deprecated, please use \`$replacement->{$flag} instead.\n" . $herecurr) if ($replacement->{$flag}); } + # Check for multiple calls of if_changed within a target in Makefiles + if (($realfile =~ /Makefile.*/ || $realfile =~ /Kbuild.*/) && + ($prevline =~ /^[ +]\t\s*\$\(call\s+if_changed,/) && + ($line =~ /^[ +]\t\s*\$\(call\s+if_changed,/)) { + ERROR("MULTIPLE_IF_CHANGED", + "Multiple calls of if_changed within a target.\n" . $herecurr); + } + # check for DT compatible documentation if (defined $root && (($realfile =~ /\.dtsi?$/ && $line =~ /^\+\s*compatible\s*=\s*\"/) || -- 2.16.1