Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp2289161imm; Mon, 16 Jul 2018 05:40:50 -0700 (PDT) X-Google-Smtp-Source: AAOMgpc3wQfkydMVyhsSVEZVbRC11meFO9zz6u+Ko4qscwu2ossCMUdKeYE9RsqBYHUM1XixeMwD X-Received: by 2002:a63:3f05:: with SMTP id m5-v6mr15162745pga.51.1531744850606; Mon, 16 Jul 2018 05:40:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531744850; cv=none; d=google.com; s=arc-20160816; b=ie882Zc4lNzCzKXtflPcaf4lV1ZqZs9GaJRl54gGH69+XtdcqxCFqld68+FaNE16nV xq4Lch8sVe0SF/78S59iaAtrFYw7JbdyJscj7xMwD+pyFd7XivrCevqRYcOHb8M8qnW5 tYFdrOMs88SqIwfgZjO8a2WVdOqCxPm3B3EK6/TmgsoCRfBFb3fvE9W9Soo5vsq3cX/F wxwZj+htXzx/yoiGnZffaCc7vGesv76GGCi3oEYcgZ6Q8+QmIYsX4l5eiQ9h9uj9Wg6T 5Mc5Ir6GRasIbxo3bXRGy8eb3QPyrXTfP0mJBDGmPOeMgxup6S4oixHISNANk/By45GN AziA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=v6IvYXM5+Mp+3J4dKKv8joroF3lynA1l0rsiFYov2X8=; b=Zx2W7wU2GcDDJwwJtpdnzA/z6rYP894GbIE/pWPbft+xwNZGo+AsqRFEODV06x3fKG iOBNWMUvYYJ3F8q8Z6IpMsTycwTZ1v5kj2YWNV2yJVVg2Uq+vR/C+d9aeHNRzezOQAkT RvRY8jHZNQH4IQ8j2ztLInv+HTfmpE9onj8iXWMIPhEyusCDk4ZdOR8pzLodB+vEeE8M kE4exdoAZ3cpke/TmMM3qAUnJuy2V55TdSyAuZc0qVKiUM6G6VC+9InUQlzadxyIxPVJ PVY6UwV7mGFs54jP+rjjv3/qY4gqpEJKcVyHBl7VCWcMf1cDkrm4DZiI2VGYsxd8USsL KPkg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gouders.net header.s=gnet header.b="UiGZcpN/"; 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 w188-v6si17049554pfw.307.2018.07.16.05.40.35; Mon, 16 Jul 2018 05:40:50 -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="UiGZcpN/"; 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 S1729913AbeGPNHF (ORCPT + 99 others); Mon, 16 Jul 2018 09:07:05 -0400 Received: from services.gouders.net ([141.101.32.176]:36140 "EHLO services.gouders.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728437AbeGPNHF (ORCPT ); Mon, 16 Jul 2018 09:07:05 -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 w6GCdRnG011181 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES128-GCM-SHA256 bits=128 verify=NO); Mon, 16 Jul 2018 14:39:38 +0200 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=gouders.net; s=gnet; t=1531744778; bh=Pp7yxRotF0kC0fYRR8X3GkFpaswQe84KPuVwD7sYPxw=; h=From:To:Cc:Subject:Date; b=UiGZcpN/Q9vBniot+WReOrW52b8JdHvMXog+aa/k5yAL+Jc2vw7E4E9mwlkBY6428 lFViJt/Eagu+4xRO9O0Jr9erJldlRGBwoqMXTlUslGt9OQDp5lzq4xaXfTvJGH6/S4 h5OtMH7pJn1YFiWcu7JBIrh7m7bXHF3TXPHppioE= From: Dirk Gouders To: Andy Whitcroft , Joe Perches Cc: Dirk Gouders , Masahiro Yamada , linux-kbuild@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH] checkpatch: if_changed: check for multiple calls in targets Date: Mon, 16 Jul 2018 14:39:02 +0200 Message-Id: <20180716123902.5337-1-dirk@gouders.net> X-Mailer: git-send-email 2.16.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Because the kbuild function if_changed writes the command line to a .cmd file for later tests, multiple calls of that function within a target would result in overwrites of previous values and effectively render the command line test meaningless, resulting in flip-flop behaviour. Produce an error for targets with multiple calls to if_changed. Three examples that would now 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) Suggested-by: Masahiro Yamada Signed-off-by: Dirk Gouders --- scripts/checkpatch.pl | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/scripts/checkpatch.pl b/scripts/checkpatch.pl index 447857ffaf6b..b0aadf23148e 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\$\(call if_changed,/) && + ($line =~ /^[ +]\t\$\(call 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.17.1