Received: by 2002:a05:7412:8d10:b0:f3:1519:9f41 with SMTP id bj16csp676692rdb; Tue, 5 Dec 2023 17:21:43 -0800 (PST) X-Google-Smtp-Source: AGHT+IEMqb1H8nL4m93s3RRJdPiKUwd9OR9lyDL1P1jpjaY5/FPvCme4yxpbpJCxnLHZLCe/LsKx X-Received: by 2002:a05:6830:4410:b0:6d7:d4bd:1fca with SMTP id q16-20020a056830441000b006d7d4bd1fcamr225045otv.17.1701825703612; Tue, 05 Dec 2023 17:21:43 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1701825703; cv=none; d=google.com; s=arc-20160816; b=q17kApurTPKx7goiYzLUydMNIzJ4qid5Pc21kH7bLyf4QrAH7j1eOMDff3TsJuMbh3 0KDTK51aDRp8SqwSrRqtPrO/G2fwAhyFu4UrFuoe2w1U+EyFzQUct0nr3Y+ZmuxwKHmr Brevm16bWk/Mg5oAIPXoel9ma5Mlv71E6dDgo5ho8XOMpmSWn1UDJDuf5uR3Hr5yC1nM WY/XDMXYouDQFotEXrVyib3a6PLeNs6VJuoIs2sdAyAmByGZKwoNK6N3qRJ0K87t3GSe db0cjUlIYCV/BSUTcIdkzUllJIY+oUhL8VOCdaaSHp8ffOO2AaGipYkWG+YYHufp8+cp B1DA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:feedback-id:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:cc:to :from; bh=5Wm66qSKRbv0+leB4BTnb+Fhh08Ypv6LXOe1tvNgAkI=; fh=QOostrrTAXmb7T9ajawDaKIc+XrUqDGGWegM2Zu1y8g=; b=qDKt8dh+ZOh/qHUvPISFfxgoLbji3EEj5qscb56z2PdyqkQGlvQnPQpThgtjez5A4q TlTGyIKWBV3LLe2XjnW2vLCp7jqUSw+6/8hv3xqIyTOeTz1Mz9FbSsMbACWKFR8icDVX yiwatFe7jH/XAHb3xa8B0X8wogEYlKa2GG0qcQPfVjbrhjkO88lmLaDkf2do8R7c5zmB sS7W+2tWKNigcZQXsQHeClKzc32+S0Xn5T8j+wyfZ2k0XfxGQzGDY94WHsh7i6FMmDgC uqSM1I1P26XN7u8YHA+yuZmavKH9y+DfRnzhju1qnzzG4IrIp7pBiG3pKibOUf4FUfhu bcvw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from pete.vger.email (pete.vger.email. [2620:137:e000::3:6]) by mx.google.com with ESMTPS id 72-20020a63014b000000b005c21c4a46ddsi10385471pgb.356.2023.12.05.17.21.43 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 05 Dec 2023 17:21:43 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) client-ip=2620:137:e000::3:6; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by pete.vger.email (Postfix) with ESMTP id E8AAE8026C2B; Tue, 5 Dec 2023 17:21:40 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at pete.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229617AbjLFBVZ (ORCPT + 99 others); Tue, 5 Dec 2023 20:21:25 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33114 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229943AbjLFBVY (ORCPT ); Tue, 5 Dec 2023 20:21:24 -0500 Received: from bg4.exmail.qq.com (bg4.exmail.qq.com [43.154.54.12]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 29C781AA; Tue, 5 Dec 2023 17:21:29 -0800 (PST) X-QQ-mid: bizesmtp68t1701825671tkvj01k2 Received: from localhost.localdomain ( [219.147.0.78]) by bizesmtp.qq.com (ESMTP) with id ; Wed, 06 Dec 2023 09:20:54 +0800 (CST) X-QQ-SSF: 01200000000000B0J000000A0000000 X-QQ-FEAT: C46Rb8GPIEdQevORz54Ns4TE4UnwfxCC0E13jQg+0AJuwH4J+RvoDvhcR29qZ fd0I2Ya2QhUAnVu/XxurUCK+OByf5q1TR0Hu5nCKXHaNMwwHUUTkJO7SCYNczNTCXxaR500 0uxLbSKqY7gbYJ77VPDhHYDpbA/HqgvojNLcHXj50CeNMyO+UMgvqku3YGgz9dV8Fee5LuR Drj+X0E+7G91YYjQWovG3fFKB4UJ1zjPOosS5hOxNkCqMliB24gi25duq3jL0bHbhE1GLHm ZZO1TFyhqJ52D1uDR9CkbztAnnUsGK3/lCbxidLYcd4wrGIMnSmcW7ToygoVOsryUMbQYj0 pScmh8LSKGGbj7U1YQTjprvkSyZHO8bvrt1RHK3bsApOPZbUCQ= X-QQ-GoodBg: 0 X-BIZMAIL-ID: 16475695321451035816 From: Jialu Xu To: nathan@kernel.org Cc: justinstitt@google.com, linux-kbuild@vger.kernel.org, linux-kernel@vger.kernel.org, llvm@lists.linux.dev, masahiroy@kernel.org, morbo@google.com, ndesaulniers@google.com, xujialu@vimux.org Subject: [PATCH v3] gen_compile_commands.py: fix path resolve with symlinks in it Date: Wed, 6 Dec 2023 09:20:36 +0800 Message-Id: <20231206012034.833057-2-xujialu@vimux.org> X-Mailer: git-send-email 2.39.2 In-Reply-To: <20231205165648.GA391810@dev-arch.thelio-3990X> References: <20231205165648.GA391810@dev-arch.thelio-3990X> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-QQ-SENDSIZE: 520 Feedback-ID: bizesmtp:vimux.org:qybglogicsvrgz:qybglogicsvrgz5a-1 X-Spam-Status: No, score=-0.8 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on pete.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (pete.vger.email [0.0.0.0]); Tue, 05 Dec 2023 17:21:41 -0800 (PST) When a path contains relative symbolic links, os.path.abspath() might not follow the symlinks and instead return the absolute path with just the relative paths resolved, resulting in an incorrect path. 1. Say "drivers/hdf/" has some symlinks: # ls -l drivers/hdf/ total 364 drwxrwxr-x 2 ... 4096 ... evdev lrwxrwxrwx 1 ... 44 ... framework -> ../../../../../../drivers/hdf_core/framework -rw-rw-r-- 1 ... 359010 ... hdf_macro_test.h lrwxrwxrwx 1 ... 55 ... inner_api -> ../../../../../../drivers/hdf_core/interfaces/inner_api lrwxrwxrwx 1 ... 53 ... khdf -> ../../../../../../drivers/hdf_core/adapter/khdf/linux -rw-r--r-- 1 ... 74 ... Makefile drwxrwxr-x 3 ... 4096 ... wifi 2. One .cmd file records that: # head -1 ./framework/core/manager/src/.devmgr_service.o.cmd cmd_drivers/hdf/khdf/manager/../../../../framework/core/manager/src/devmgr_service.o := ... \ /path/to/out/drivers/hdf/khdf/manager/../../../../framework/core/manager/src/devmgr_service.c 3. os.path.abspath returns "/path/to/out/framework/core/manager/src/devmgr_service.c", not correct: # ./scripts/clang-tools/gen_compile_commands.py INFO: Could not add line from ./framework/core/manager/src/.devmgr_service.o.cmd: File \ /path/to/out/framework/core/manager/src/devmgr_service.c not found Use pathlib.Path.resolve(), which resolves the symlinks and normalizes the paths correctly. # cat compile_commands.json ... { "command": ... "directory": ... "file": "/path/to/blabla/drivers/hdf_core/framework/core/manager/src/devmgr_service.c" }, ... Reviewed-by: Nathan Chancellor --- scripts/clang-tools/gen_compile_commands.py | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/scripts/clang-tools/gen_compile_commands.py b/scripts/clang-tools/gen_compile_commands.py index 180952fb91c1b..99e28b7152c19 100755 --- a/scripts/clang-tools/gen_compile_commands.py +++ b/scripts/clang-tools/gen_compile_commands.py @@ -11,6 +11,7 @@ import argparse import json import logging import os +from pathlib import Path import re import subprocess import sys @@ -172,8 +173,9 @@ def process_line(root_directory, command_prefix, file_path): # by Make, so this code replaces the escaped version with '#'. prefix = command_prefix.replace('\#', '#').replace('$(pound)', '#') - # Use os.path.abspath() to normalize the path resolving '.' and '..' . - abs_path = os.path.abspath(os.path.join(root_directory, file_path)) + # Make the path absolute, resolving all symlinks on the way and also normalizing it. + # Convert Path object to a string because 'PosixPath' is not JSON serializable. + abs_path = str(Path(root_directory, file_path).resolve()) if not os.path.exists(abs_path): raise ValueError('File %s not found' % abs_path) return { -- 2.39.2