From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 2C961C43334 for ; Mon, 18 Jul 2022 14:51:20 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234853AbiGROvS (ORCPT ); Mon, 18 Jul 2022 10:51:18 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43712 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234818AbiGROvM (ORCPT ); Mon, 18 Jul 2022 10:51:12 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2B9BB15A03; Mon, 18 Jul 2022 07:51:07 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 6F399B81616; Mon, 18 Jul 2022 14:51:05 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id D3E44C341C0; Mon, 18 Jul 2022 14:51:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1658155864; bh=C1xj80V0jqqtJ7Kst5Rh/INDGS8YzFtQrsffbUAm3vA=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=X2kkJnKsPpygAIgZeRTB3KoU/bGcQaQAmkMOkt1BlrPJ7Tkq6Zt7K8xOtz8DXiegC wpM8K1ATQjFSQeWlvTwzzl4Nut9dCrpaRGiuR5kgkEmCK8DZDAKs2Qii9Qp1VyKZiP SZOb+jwmfuVl4+pWS4wQIFbi+L1GbXP7ftrt+esPRmSd9VtfnWc5il9+fF2T4gV1o8 QrafqBElgWJeBDInvtPxwzkzH4EXuL6oya2x2BV6zD7/NFWY++zv1nVOK6UL9c0EK4 wK9EnlYKbHhkcFWnLCByXfjFXDIpfS8R3/b22GieU1j3UycdZYlWOW69AxbAI5AJ5Z LlJUlgaRrfowg== Received: by quaco.ghostprotocols.net (Postfix, from userid 1000) id 5EAFB40374; Mon, 18 Jul 2022 11:51:01 -0300 (-03) Date: Mon, 18 Jul 2022 11:51:01 -0300 From: Arnaldo Carvalho de Melo To: Jiri Olsa Cc: Blake Jones , Mark Rutland , Alexander Shishkin , Namhyung Kim , Ian Rogers , Peter Zijlstra , Ingo Molnar , linux-perf-users@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v3] Add a "-m" option to "perf buildid-list". Message-ID: References: <20220629213632.3899212-1-blakejones@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Url: http://acmel.wordpress.com Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Em Fri, Jul 01, 2022 at 10:23:26AM +0200, Jiri Olsa escreveu: > On Wed, Jun 29, 2022 at 02:36:32PM -0700, Blake Jones wrote: > > This new option displays all of the information needed to do external > > BuildID-based symbolization of kernel stack traces, such as those collected > > by bpf_get_stackid(). For each kernel module plus the main kernel, it > > displays the BuildID, the start and end virtual addresses of that module's > > text range (rounded out to page boundaries), and the pathname of the > > module. > > > > When run as a non-privileged user, the actual addresses of the modules' > > text ranges are not available, so the tools displays "0, " for > > kernel modules and "0, 0xffffffffffffffff" for the kernel itself. > > > > Sample output: > > > > root# perf buildid-list -m > > cf6df852fd4da122d616153353cc8f560fd12fe0 ffffffffa5400000 ffffffffa6001e27 [kernel.kallsyms] > > 1aa7209aa2acb067d66ed6cf7676d65066384d61 ffffffffc0087000 ffffffffc008b000 /lib/modules/5.15.15-1rodete2-amd64/kernel/crypto/sha512_generic.ko > > 3857815b5bf0183697b68f8fe0ea06121644041e ffffffffc008c000 ffffffffc0098000 /lib/modules/5.15.15-1rodete2-amd64/kernel/arch/x86/crypto/sha512-ssse3.ko > > 4081fde0bca2bc097cb3e9d1efcb836047d485f1 ffffffffc0099000 ffffffffc009f000 /lib/modules/5.15.15-1rodete2-amd64/kernel/drivers/acpi/button.ko > > 1ef81ba4890552ea6b0314f9635fc43fc8cef568 ffffffffc00a4000 ffffffffc00aa000 /lib/modules/5.15.15-1rodete2-amd64/kernel/crypto/cryptd.ko > > cc5c985506cb240d7d082b55ed260cbb851f983e ffffffffc00af000 ffffffffc00b6000 /lib/modules/5.15.15-1rodete2-amd64/kernel/drivers/i2c/busses/i2c-piix4.ko > > [...] > > > > Signed-off-by: Blake Jones > > Acked-by: Jiri Olsa To clarify, b4 found v3 and that was the one applied. Thanks, - Arnaldo > thanks, > jirka > > > --- > > .../perf/Documentation/perf-buildid-list.txt | 4 ++ > > tools/perf/builtin-buildid-list.c | 38 ++++++++++++++++++- > > tools/perf/util/machine.c | 15 ++++++++ > > tools/perf/util/machine.h | 5 +++ > > 4 files changed, 61 insertions(+), 1 deletion(-) > > > > diff --git a/tools/perf/Documentation/perf-buildid-list.txt b/tools/perf/Documentation/perf-buildid-list.txt > > index 25c52efcc7f0..e1e8fdbe06b9 100644 > > --- a/tools/perf/Documentation/perf-buildid-list.txt > > +++ b/tools/perf/Documentation/perf-buildid-list.txt > > @@ -33,6 +33,10 @@ OPTIONS > > -k:: > > --kernel:: > > Show running kernel build id. > > +-m:: > > +--kernel-maps:: > > + Show buildid, start/end text address, and path of running kernel and > > + its modules. > > -v:: > > --verbose:: > > Be more verbose. > > diff --git a/tools/perf/builtin-buildid-list.c b/tools/perf/builtin-buildid-list.c > > index cebadd632234..cffca6a536e9 100644 > > --- a/tools/perf/builtin-buildid-list.c > > +++ b/tools/perf/builtin-buildid-list.c > > @@ -12,6 +12,7 @@ > > #include "util/build-id.h" > > #include "util/debug.h" > > #include "util/dso.h" > > +#include "util/map.h" > > #include > > #include > > #include "util/session.h" > > @@ -20,6 +21,34 @@ > > #include > > #include > > > > +static int buildid__map_cb(struct map *map, void *arg __maybe_unused) > > +{ > > + const struct dso *dso = map->dso; > > + char bid_buf[SBUILD_ID_SIZE]; > > + > > + memset(bid_buf, 0, sizeof(bid_buf)); > > + if (dso->has_build_id) > > + build_id__sprintf(&dso->bid, bid_buf); > > + printf("%s %16lx %16lx", bid_buf, map->start, map->end); > > + if (dso->long_name != NULL) { > > + printf(" %s", dso->long_name); > > + } else if (dso->short_name != NULL) { > > + printf(" %s", dso->short_name); > > + } > > + printf("\n"); > > + > > + return 0; > > +} > > + > > +static void buildid__show_kernel_maps(void) > > +{ > > + struct machine *machine; > > + > > + machine = machine__new_host(); > > + machine__for_each_kernel_map(machine, buildid__map_cb, NULL); > > + machine__delete(machine); > > +} > > + > > static int sysfs__fprintf_build_id(FILE *fp) > > { > > char sbuild_id[SBUILD_ID_SIZE]; > > @@ -99,6 +128,7 @@ static int perf_session__list_build_ids(bool force, bool with_hits) > > int cmd_buildid_list(int argc, const char **argv) > > { > > bool show_kernel = false; > > + bool show_kernel_maps = false; > > bool with_hits = false; > > bool force = false; > > const struct option options[] = { > > @@ -106,6 +136,8 @@ int cmd_buildid_list(int argc, const char **argv) > > OPT_STRING('i', "input", &input_name, "file", "input file name"), > > OPT_BOOLEAN('f', "force", &force, "don't complain, do it"), > > OPT_BOOLEAN('k', "kernel", &show_kernel, "Show current kernel build id"), > > + OPT_BOOLEAN('m', "kernel-maps", &show_kernel_maps, > > + "Show build id of current kernel + modules"), > > OPT_INCR('v', "verbose", &verbose, "be more verbose"), > > OPT_END() > > }; > > @@ -117,8 +149,12 @@ int cmd_buildid_list(int argc, const char **argv) > > argc = parse_options(argc, argv, options, buildid_list_usage, 0); > > setup_pager(); > > > > - if (show_kernel) > > + if (show_kernel) { > > return !(sysfs__fprintf_build_id(stdout) > 0); > > + } else if (show_kernel_maps) { > > + buildid__show_kernel_maps(); > > + return 0; > > + } > > > > return perf_session__list_build_ids(force, with_hits); > > } > > diff --git a/tools/perf/util/machine.c b/tools/perf/util/machine.c > > index 009061852808..16d225149b93 100644 > > --- a/tools/perf/util/machine.c > > +++ b/tools/perf/util/machine.c > > @@ -3327,3 +3327,18 @@ int machine__for_each_dso(struct machine *machine, machine__dso_t fn, void *priv > > } > > return err; > > } > > + > > +int machine__for_each_kernel_map(struct machine *machine, machine__map_t fn, void *priv) > > +{ > > + struct maps *maps = machine__kernel_maps(machine); > > + struct map *map; > > + int err = 0; > > + > > + for (map = maps__first(maps); map != NULL; map = map__next(map)) { > > + err = fn(map, priv); > > + if (err != 0) { > > + break; > > + } > > + } > > + return err; > > +} > > diff --git a/tools/perf/util/machine.h b/tools/perf/util/machine.h > > index 5d7daf7cb7bc..e1476343cbb2 100644 > > --- a/tools/perf/util/machine.h > > +++ b/tools/perf/util/machine.h > > @@ -262,6 +262,11 @@ typedef int (*machine__dso_t)(struct dso *dso, struct machine *machine, void *pr > > > > int machine__for_each_dso(struct machine *machine, machine__dso_t fn, > > void *priv); > > + > > +typedef int (*machine__map_t)(struct map *map, void *priv); > > +int machine__for_each_kernel_map(struct machine *machine, machine__map_t fn, > > + void *priv); > > + > > int machine__for_each_thread(struct machine *machine, > > int (*fn)(struct thread *thread, void *p), > > void *priv); > > > > base-commit: 1bcca2b1bd67f3c0e5c3a88ed16c6389f01a5b31 > > -- > > 2.37.0.rc0.161.g10f37bed90-goog > > -- - Arnaldo