From: Namhyung Kim <namhyung@kernel.org>
To: Arnaldo Carvalho de Melo <acme@kernel.org>
Cc: Ian Rogers <irogers@google.com>,
Kan Liang <kan.liang@linux.intel.com>,
Jiri Olsa <jolsa@kernel.org>,
Adrian Hunter <adrian.hunter@intel.com>,
Peter Zijlstra <peterz@infradead.org>,
Ingo Molnar <mingo@kernel.org>,
LKML <linux-kernel@vger.kernel.org>,
linux-perf-users@vger.kernel.org
Subject: Re: [PATCH] perf hist: Remove output field from sort-list properly
Date: Fri, 2 May 2025 11:12:49 -0700 [thread overview]
Message-ID: <aBULIc_DhfnY33dZ@google.com> (raw)
In-Reply-To: <aBTqq3-splDRYxO5@x1>
Hi Arnaldo,
On Fri, May 02, 2025 at 12:54:19PM -0300, Arnaldo Carvalho de Melo wrote:
> On Wed, Apr 30, 2025 at 11:03:21AM -0700, Namhyung Kim wrote:
> > When it removes an output format for cancelled children or latency, it
> > should delete itself from the sort list as well. Otherwise assertion
> > in fmt_free() will fire.
> >
> > $ perf report -H --stdio
> > perf: ui/hist.c:603: fmt_free: Assertion `!(!list_empty(&fmt->sort_list))' failed.
> > Aborted (core dumped)
> >
> > Also convert to perf_hpp__column_unregister() for the same open codes.
> >
> > Fixes: dbd11b6bdab12f60 ("perf hist: Remove formats in hierarchy when cancel children")
> > Signed-off-by: Namhyung Kim <namhyung@kernel.org>
>
> Tested and added the following patch just before this one.
>
> Please check.
>
> Thanks, applied to perf-tools-next.
Thanks!
>
> - Arnaldo
>
> From 0184752e038f00ea2ccdc4ef4fdb6713ef2a328e Mon Sep 17 00:00:00 2001
> From: Arnaldo Carvalho de Melo <acme@redhat.com>
> Date: Fri, 2 May 2025 12:48:28 -0300
> Subject: [PATCH 1/2] perf test perf-report-hierarchy: Add new test
>
> Super simple test to check that at least we're not segfaulting when
> trying to use 'perf report --hierarchy', more subtests should be added
> to make sure the output is the expected one.
Thanks for doing this. We have a test suite for perf report and there's
a test for the --hierarchy option already. But I'm afrail it didn't
check if the command crashed. I'm fine with adding this separately and
maybe I can add more tests later.
Thanks,
Namhyung
>
> This is being merged right before a fix for that that this test detects:
>
> # perf test hierarchy
> 83: perf report --hierarchy : FAILED!
> # perf test -v hierarchy
> --- start ---
> test child forked, pid 102242
> perf report --hierarchy
> Linux
> [ perf record: Woken up 1 times to write data ]
> [ perf record: Captured and wrote 0.025 MB /tmp/perf-test-report.HX0N85TlPq/perf-report-hierarchy-perf.data (6 samples) ]
> perf: ui/hist.c:603: fmt_free: Assertion `!(!list_empty(&fmt->sort_list))' failed.
> /home/acme/libexec/perf-core/tests/shell/perf-report-hierarchy.sh: line 34: 102250 Aborted (core dumped) perf report --hierarchy > /dev/null
> --- Cleaning up ---
> ---- end(-1) ----
> 83: perf report --hierarchy : FAILED!
> #
>
> Cc: Adrian Hunter <adrian.hunter@intel.com>
> Cc: Ian Rogers <irogers@google.com>
> Cc: James Clark <james.clark@linaro.org>
> Cc: Jiri Olsa <jolsa@kernel.org>
> Cc: Kan Liang <kan.liang@linux.intel.com>
> Cc: Namhyung Kim <namhyung@kernel.org>
> Link: https://lore.kernel.org/lkml/20250430180321.736939-1-namhyung@kernel.org
> Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
> ---
> .../perf/tests/shell/perf-report-hierarchy.sh | 47 +++++++++++++++++++
> 1 file changed, 47 insertions(+)
> create mode 100755 tools/perf/tests/shell/perf-report-hierarchy.sh
>
> diff --git a/tools/perf/tests/shell/perf-report-hierarchy.sh b/tools/perf/tests/shell/perf-report-hierarchy.sh
> new file mode 100755
> index 0000000000000000..a9cc1edae36ba003
> --- /dev/null
> +++ b/tools/perf/tests/shell/perf-report-hierarchy.sh
> @@ -0,0 +1,47 @@
> +#!/bin/sh
> +# perf report --hierarchy
> +# SPDX-License-Identifier: GPL-2.0
> +# Arnaldo Carvalho de Melo <acme@redhat.com>
> +
> +set -e
> +
> +temp_dir=$(mktemp -d /tmp/perf-test-report.XXXXXXXXXX)
> +
> +perfdatafile="${temp_dir}/perf.data"
> +
> +err=0
> +
> +cleanup()
> +{
> + trap - EXIT TERM INT
> + sane=$(echo "${temp_dir}" | cut -b 1-21)
> + if [ "${sane}" = "/tmp/perf-test-report" ] ; then
> + echo "--- Cleaning up ---"
> + rm -rf "${temp_dir:?}/"*
> + rmdir "${temp_dir}"
> + fi
> +}
> +
> +trap_cleanup()
> +{
> + cleanup
> + exit 1
> +}
> +
> +trap trap_cleanup EXIT TERM INT
> +
> +test_report_hierarchy()
> +{
> + echo "perf report --hierarchy"
> +
> + perf_data="${temp_dir}/perf-report-hierarchy-perf.data"
> + perf record -o "${perf_data}" uname
> + perf report --hierarchy > /dev/null
> + echo "perf report --hierarchy test [Success]"
> +}
> +
> +test_report_hierarchy
> +
> +cleanup
> +
> +exit $err
> --
> 2.49.0
>
prev parent reply other threads:[~2025-05-02 18:12 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-04-30 18:03 [PATCH] perf hist: Remove output field from sort-list properly Namhyung Kim
2025-05-02 15:54 ` Arnaldo Carvalho de Melo
2025-05-02 18:12 ` Namhyung Kim [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=aBULIc_DhfnY33dZ@google.com \
--to=namhyung@kernel.org \
--cc=acme@kernel.org \
--cc=adrian.hunter@intel.com \
--cc=irogers@google.com \
--cc=jolsa@kernel.org \
--cc=kan.liang@linux.intel.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-perf-users@vger.kernel.org \
--cc=mingo@kernel.org \
--cc=peterz@infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.