Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1768424pxb; Thu, 4 Mar 2021 22:03:56 -0800 (PST) X-Google-Smtp-Source: ABdhPJx75UconySC7VrHiJiXsa2gtr7NJJUAjWZuTb9C99C140DUzElrCNdDbE8Ou7MUET9jIhaf X-Received: by 2002:a02:817:: with SMTP id 23mr8042447jac.23.1614924236774; Thu, 04 Mar 2021 22:03:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614924236; cv=none; d=google.com; s=arc-20160816; b=ghfgvfZYyPbD0V8uwpvbm1cZKeKvnBLmCmfYTsKZx3+FlevfKYtIPEn8xY2S438mUJ oAhFJ+IACLJAyZGQiicSr66Ok3ic7WA2GUVMi/wVIvydzHael2yKifkHQDEXwiJwJtFY t8XR9wPkc92Ot18zmIHQAzkzWcXUmXrZ9QVITjO01iwstO0mjXznWAv+KQj1lM8Hsg+m jra5rU2pOFTWMSRL0ronozbX9xhb/3oFk1vvVnUNnuPcpJo0hefwQ41K/wfySQpF2W+u XfiLs8JmBbvbODZ4ZFXxArGUy9N1r6MIe8B7MXpex1C3IBkRHu9Nj6FjUyaq73H2lT0i j+ag== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature:dkim-filter; bh=8j+Joi2P3uXrOj9ujoo+ykWpnsA3cqH4DLBOMX+P6Qk=; b=cYjpzl6FzVw9iIDmLiqApCoGu8luP4omdZ307EgN7AgmKEj0ImykUbJjjt2Ss/I/ly M/TUWnhRSObs5hZQIeiV0VknosYci5sRlyWAiNA6WUl1KaTM+KdGVTxz0uHZ99P2M7Cg 93hAX3ZIDJ1qoL1BjnMR4jCcSESsYMdEmy5d24qCAjI35/yWGThqdfLYL9/oydMeSv9F EBC1Ui79sxzu92GulQ/wP6QDoqDpOlkrD+EfD0fYf2pNFC56cAy6WAJX8wG30r84iW4k sh0FJKP5oshmleVWS3Cqkqja0a/1APUpPh/mnUM7DeF3eNI7uR3ik20E04zYj7z5HdRC Qtaw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nifty.com header.s=dec2015msa header.b=tFSMsKK+; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f13si1637317jat.92.2021.03.04.22.03.43; Thu, 04 Mar 2021 22:03:56 -0800 (PST) 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; dkim=pass header.i=@nifty.com header.s=dec2015msa header.b=tFSMsKK+; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229580AbhCEGAX (ORCPT + 99 others); Fri, 5 Mar 2021 01:00:23 -0500 Received: from conssluserg-06.nifty.com ([210.131.2.91]:48628 "EHLO conssluserg-06.nifty.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229448AbhCEGAW (ORCPT ); Fri, 5 Mar 2021 01:00:22 -0500 Received: from mail-pj1-f42.google.com (mail-pj1-f42.google.com [209.85.216.42]) (authenticated) by conssluserg-06.nifty.com with ESMTP id 125605Ox002584; Fri, 5 Mar 2021 15:00:05 +0900 DKIM-Filter: OpenDKIM Filter v2.10.3 conssluserg-06.nifty.com 125605Ox002584 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nifty.com; s=dec2015msa; t=1614924006; bh=8j+Joi2P3uXrOj9ujoo+ykWpnsA3cqH4DLBOMX+P6Qk=; h=References:In-Reply-To:From:Date:Subject:To:Cc:From; b=tFSMsKK+FeCi6TtSglrHBgWf4EDpf0dJV2yuFdI/IowUYzS3/SiOlf94RAZV9Tx3S JHvW2UPlTiOAlIxWopcoZGwhEYO0+SulkJTBgpjTfhsS5keyYm5MVY1qHm4WeSDwmJ q64c+is4VpJBipB3d2T6zzvYxKu2Ap+BFzgl7D62Smg3j5iaHzIoCSEocrJjdnufdt 1gwJBMS06bTCpI1YJfHp6Du6BhnQ9lsNA7FMmWE7Z82DVM9sumJEBoEcW62Gh9b2Rp xh1ZcpQNV22H6UGssEFF7SVInsLoNAvo5UdCJ6A54aL0b0qj36kES8cs1LdJR6Im14 gb5VFP840BQYA== X-Nifty-SrcIP: [209.85.216.42] Received: by mail-pj1-f42.google.com with SMTP id i14so1196416pjz.4; Thu, 04 Mar 2021 22:00:05 -0800 (PST) X-Gm-Message-State: AOAM531gqB5TPCztnSYu2Xck4H/XIrJeoAQx29j7xJHgQEPGwSxcI8wk 3vJOgzTBkNyafmtjyG4TnPyF2pUIE7yFlBqvk9M= X-Received: by 2002:a17:902:c48c:b029:e4:c093:593a with SMTP id n12-20020a170902c48cb02900e4c093593amr7216851plx.1.1614924004952; Thu, 04 Mar 2021 22:00:04 -0800 (PST) MIME-Version: 1.0 References: <20210224105256.1939169-1-linux@rasmusvillemoes.dk> In-Reply-To: <20210224105256.1939169-1-linux@rasmusvillemoes.dk> From: Masahiro Yamada Date: Fri, 5 Mar 2021 14:59:28 +0900 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH] kbuild: add CONFIG_VMLINUX_MAP expert option To: Rasmus Villemoes Cc: Michal Marek , Linux Kernel Mailing List , Linux Kbuild mailing list Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Feb 24, 2021 at 7:53 PM Rasmus Villemoes wrote: > > It can be quite useful to have ld emit a link map file, in order to > debug or verify that special sections end up where they are supposed > to, and to see what LD_DEAD_CODE_DATA_ELIMINATION manages to get rid > of. > > The only reason I'm not just adding this unconditionally is that the > .map file can be rather large (several MB), and that's a waste of > space when one isn't interested in these things. Also hide the prompt > behind CONFIG_EXPERT. > > Signed-off-by: Rasmus Villemoes > --- > .gitignore | 1 + > Makefile | 3 ++- > lib/Kconfig.debug | 9 +++++++++ > scripts/link-vmlinux.sh | 9 +++++++++ > 4 files changed, 21 insertions(+), 1 deletion(-) > > diff --git a/.gitignore b/.gitignore > index 3af66272d6f1..d3038aff4485 100644 > --- a/.gitignore > +++ b/.gitignore > @@ -58,6 +58,7 @@ modules.order > /TAGS > /linux > /vmlinux > +/vmlinux.map Could you move this one line below so that vmlinux.map is placed between vmlinux.32 and vmlinux.symvers ? I know this list is not sorted... > /vmlinux.32 > /vmlinux.symvers > /vmlinux-gdb.py Please add this to Documentation/dontdiff as well. > diff --git a/Makefile b/Makefile > index b18dbc634690..be6fbd99a214 100644 > --- a/Makefile > +++ b/Makefile > @@ -1501,7 +1501,8 @@ endif # CONFIG_MODULES > # Directories & files removed with 'make clean' > CLEAN_FILES += include/ksym vmlinux.symvers \ > modules.builtin modules.builtin.modinfo modules.nsdeps \ > - compile_commands.json > + compile_commands.json \ > + vmlinux.map Do you need this ? You already added this to cleanup() of scripts/link-vmlinux.sh, which is invoked from 'make clean'. > # Directories & files removed with 'make mrproper' > MRPROPER_FILES += include/config include/generated \ > diff --git a/lib/Kconfig.debug b/lib/Kconfig.debug > index 5ea0c1773b0a..d6af084c11ae 100644 > --- a/lib/Kconfig.debug > +++ b/lib/Kconfig.debug > @@ -412,6 +412,15 @@ config VMLINUX_VALIDATION > depends on STACK_VALIDATION && DEBUG_ENTRY && !PARAVIRT > default y > > +config VMLINUX_MAP > + bool "Generate vmlinux.map file when linking" if EXPERT Please use depends on EXPERT because VMLINUX_MAP is not select or implied by anyone. > + help > + Selecting this option will pass "-Map=vmlinux.map" to ld > + when linking vmlinux. That file can be useful for verifying > + and debugging magic section games, and for seeing which > + pieces of code get eliminated with > + CONFIG_LD_DEAD_CODE_DATA_ELIMINATION. > + > config DEBUG_FORCE_WEAK_PER_CPU > bool "Force weak per-cpu definitions" > depends on DEBUG_KERNEL > diff --git a/scripts/link-vmlinux.sh b/scripts/link-vmlinux.sh > index 3b261b0f74f0..bba58839db40 100755 > --- a/scripts/link-vmlinux.sh > +++ b/scripts/link-vmlinux.sh > @@ -166,6 +166,12 @@ vmlinux_link() > strip_debug=-Wl,--strip-debug > fi > > + if [ -n "${CONFIG_VMLINUX_MAP}" ]; then > + map_option="-Map=${output}.map" > + else > + map_option="" > + fi > + For consistency, please do like strip_debug, that is, define this as a local variable, and set the value of the 'if' case. > if [ "${SRCARCH}" != "um" ]; then > if [ -n "${CONFIG_LTO_CLANG}" ]; then > # Use vmlinux.o instead of performing the slow LTO > @@ -187,6 +193,7 @@ vmlinux_link() > ${LD} ${KBUILD_LDFLAGS} ${LDFLAGS_vmlinux} \ > ${strip_debug#-Wl,} \ > -o ${output} \ > + ${map_option} \ > -T ${lds} ${objects} > else > objects="-Wl,--whole-archive \ > @@ -200,6 +207,7 @@ vmlinux_link() > ${CC} ${CFLAGS_vmlinux} \ > ${strip_debug} \ > -o ${output} \ > + ${map_option:+-Wl,${map_option}} \ > -Wl,-T,${lds} \ > ${objects} \ > -lutil -lrt -lpthread > @@ -303,6 +311,7 @@ cleanup() > rm -f .tmp_vmlinux* > rm -f System.map > rm -f vmlinux > + rm -f vmlinux.map > rm -f vmlinux.o > } > > -- > 2.29.2 > -- Best Regards Masahiro Yamada