Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp5122588rwr; Mon, 8 May 2023 18:51:12 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ4EtOALfHIjKyor73Ovysfc9NC9WLA9yJzB8KC+iLgxvhn/Z0U6t+fX4nuXgpao4g8p30Ka X-Received: by 2002:a17:90b:1997:b0:250:2337:9b96 with SMTP id mv23-20020a17090b199700b0025023379b96mr12904223pjb.9.1683597072269; Mon, 08 May 2023 18:51:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1683597072; cv=none; d=google.com; s=arc-20160816; b=TVJ4B/AZS1Zfc28ItrnuPiTAhm3snuynzCHqp/mH9g5RaEvbcb949zF5gnu8N6pfmT R02UhhcbSK5PXsYUBmz8CGG3o2ViAQoPi4VZ04IMdq/jLrDBGmiZOSWlrOhdJSw7+oLr XOlNzIixvsb9IyOaeuUd4e2lKZKU+cIbq3l+Qt4vvx1xt7yZsKYB25WrPXi/tAYo6HKV G6Kl98PuiroZD1l1aR7rTTvJRCuPQSsWshHNL99WC+kDEyuGTI2ZBZ1SEgUL5T2fNp6u mAwRbaRh3vb2itEfqu7k1S7LxeTz2Uo1r2qKl6119lhxwFwd92WBJ5llEIMWyWdww/CR SYiQ== 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 :references:in-reply-to:message-id:date:subject:cc:to:dkim-signature :dkim-signature:from; bh=uStzLe1tmofW57614nQAyaAY3eSlDqWR3vQxVmQVS1Y=; b=RePxUDPjmV9OTEjo17xU7AmXZ88QkhJ0ZsmFiLELFPfYjJEoXGeKgGt9cLF31kFScH n5VaTeD64jUL8mPFuUu8KxOUhcDe5KuAKKER4ZzX1F6glpfuVdQu0iAYsCY6ZmDS1/y/ HGfjzpAwMyfKU/3BgDFlRqcoX2UhUAn6Lrv6+icu8Jo92kudLWLzWQ5IOY3bA5dcYts4 oqrMxN/B6Gmh6I23RJhqAYsXpfFGgf3GipDYt6G7wpeV5kaFyo6LOB/87HM/S+epISlB +Y6YPTep4prm3CWGMaKml5IpoS+bBkPVaEtzhhdp5tjs7Gg7bPDDVraUayZIdwQAgBVd uHZg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=xWNjFDl1; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e header.b=WJiot4UY; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id nn16-20020a17090b38d000b00246a5991cc6si28207287pjb.162.2023.05.08.18.50.58; Mon, 08 May 2023 18:51:12 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=xWNjFDl1; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e header.b=WJiot4UY; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229579AbjEIB0s (ORCPT + 99 others); Mon, 8 May 2023 21:26:48 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60116 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233265AbjEIB0n (ORCPT ); Mon, 8 May 2023 21:26:43 -0400 Received: from galois.linutronix.de (Galois.linutronix.de [193.142.43.55]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id ACAE0903C; Mon, 8 May 2023 18:26:39 -0700 (PDT) From: "Ahmed S. Darwish" DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1683595598; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=uStzLe1tmofW57614nQAyaAY3eSlDqWR3vQxVmQVS1Y=; b=xWNjFDl1s1ucegfBKQoncawd3d6If9tExr6i3v7IB0erVNUwt3jWQ6xpT9t2axmBV47Egz Qzzf/6eG0TQWoOSYHLyK98dgGPoWq8ZPdbKnLBF+bFMDkBIgUD80KfV3P4fHDLcVFEmJ1Q HKAZoci+2bpbtZ1iv9kQZ1koL34GE6y4AbhhEK5SRuKp1S60+KjRB4v/8MHrfVlyzt/aOm ewEZc6123SiU/pGCMhBFSqfDRsFxyVECyL0IWFbGbVRWNXoAghfj67OM2jzDVwAQAmoiQ0 hUyDmEWmdirizxsc1O1FFxo+AItwBn1ssPhe+phW2iue7vCxNDt/PUrrF1BIfg== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1683595598; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=uStzLe1tmofW57614nQAyaAY3eSlDqWR3vQxVmQVS1Y=; b=WJiot4UYEtS47knJadY85GFMDZjw4ZAVKGi64k8JHj3oZMySdSuYS/Vb8RZso5Gw1ThPCM 4eHRjiXqk7nTejDw== To: Masahiro Yamada , Nathan Chancellor , Nick Desaulniers , Nicolas Schier Cc: Thomas Gleixner , linux-kbuild@vger.kernel.org, LKML , "Ahmed S. Darwish" Subject: [PATCH v2 1/2] scripts/tags.sh: Resolve gtags empty index generation Date: Tue, 9 May 2023 03:26:15 +0200 Message-Id: <20230509012616.81579-2-darwi@linutronix.de> In-Reply-To: <20230509012616.81579-1-darwi@linutronix.de> References: <20230504201833.202494-1-darwi@linutronix.de> <20230509012616.81579-1-darwi@linutronix.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org gtags considers any file outside of its current working directory "outside the source tree" and refuses to index it. For O= kernel builds, or when "make" is invoked from a directory other then the kernel source tree, gtags ignores the entire kernel source and generates an empty index. Force-set gtags current working directory to the kernel source tree. Due to commit 9da0763bdd82 ("kbuild: Use relative path when building in a subdir of the source tree"), if the kernel build is done in a sub-directory of the kernel source tree, the kernel Makefile will set the kernel's $srctree to ".." for shorter compile-time and run-time warnings. Consequently, the list of files to be indexed will be in the "../*" form, rendering all such paths invalid once gtags switches to the kernel source tree as its current working directory. If gtags indexing is requested and the build directory is not the kernel source tree, index all files in absolute-path form. Note, indexing in absolute-path form will not affect the generated index, as paths in gtags indices are always relative to the gtags "root directory" (as evidenced by "gtags --dump"). Signed-off-by: Ahmed S. Darwish Cc: --- scripts/tags.sh | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/scripts/tags.sh b/scripts/tags.sh index ea31640b2671..3de4b4ebd891 100755 --- a/scripts/tags.sh +++ b/scripts/tags.sh @@ -32,6 +32,14 @@ else tree=${srctree}/ fi + +# gtags(1) refuses to index any file outside of its current working dir. +# If gtags indexing is requested and the build output directory is not +# the kernel source tree, index all files in absolute-path form. +if [ "$1" = "gtags" -a -n "${tree}" ]; then + tree=$(realpath $tree)/ +fi + # Detect if ALLSOURCE_ARCHS is set. If not, we assume SRCARCH if [ "${ALLSOURCE_ARCHS}" = "" ]; then ALLSOURCE_ARCHS=${SRCARCH} @@ -131,7 +139,11 @@ docscope() dogtags() { - all_target_sources | gtags -i -f - + local gtagsoutdir="${PWD}" + local gtagsroot="${tree}" + + [ -z "${gtagsroot}" ] && gtagsroot="." + all_target_sources | gtags -i -C $gtagsroot -f - $gtagsoutdir } # Basic regular expressions with an optional /kind-spec/ for ctags and -- 2.40.0