From: Namhyung Kim <namhyung@kernel.org>
To: Chun-Tse Shao <ctshao@google.com>
Cc: linux-kernel@vger.kernel.org,
Arnaldo Carvalho de Melo <acme@kernel.org>,
peterz@infradead.org, mingo@redhat.com, mark.rutland@arm.com,
alexander.shishkin@linux.intel.com, jolsa@kernel.org,
irogers@google.com, adrian.hunter@intel.com,
kan.liang@linux.intel.com, dvyukov@google.com,
ben.gainey@arm.com, linux-perf-users@vger.kernel.org
Subject: Re: [PATCH v2] perf report: Skip unsupported new event types
Date: Thu, 10 Apr 2025 17:41:50 -0700 [thread overview]
Message-ID: <Z_hlTkkeFPydVyI7@google.com> (raw)
In-Reply-To: <20250409183958.1540709-1-ctshao@google.com>
On Wed, Apr 09, 2025 at 11:39:30AM -0700, Chun-Tse Shao wrote:
> `perf report` currently halts with an error when encountering
> unsupported new event types (`event.type >= PERF_RECORD_HEADER_MAX`).
> This patch modifies the behavior to skip these samples and continue
> processing the remaining events.
>
> Signed-off-by: Chun-Tse Shao <ctshao@google.com>
> Suggested-by: Arnaldo Carvalho de Melo <acme@kernel.org>
> Suggested-by: Namhyung Kim <namhyung@kernel.org>
> ---
> tools/perf/util/session.c | 13 +++++++++++--
> 1 file changed, 11 insertions(+), 2 deletions(-)
>
> diff --git a/tools/perf/util/session.c b/tools/perf/util/session.c
> index 60fb9997ea0d..b4c7973c34e2 100644
> --- a/tools/perf/util/session.c
> +++ b/tools/perf/util/session.c
> @@ -1639,8 +1639,17 @@ static s64 perf_session__process_event(struct perf_session *session,
> if (session->header.needs_swap)
> event_swap(event, evlist__sample_id_all(evlist));
>
> - if (event->header.type >= PERF_RECORD_HEADER_MAX)
> - return -EINVAL;
> + if (event->header.type >= PERF_RECORD_HEADER_MAX) {
> + if (!PERF_ALIGN(event->header.size, sizeof(u64)))
I think you wanted:
if (event->header.size % sizeof(u64))
> + /* perf should not support unaligned event */
> + ui__warning("Skip unaligned event type %u.\n", event->header.type);
And I think we should stop here. Going with unaligned data will cause
more troubles I guess.
Thanks,
Namhyung
> + else
> + /* This perf is outdated and does not support the latest event type. */
> + ui__warning("Unsupported type %u, please considering update perf.\n",
> + event->header.type);
> + /* Skip unsupported/unaligned event by returning its size. */
> + return event->header.size;
> + }
>
> events_stats__inc(&evlist->stats, event->header.type);
>
> --
> 2.49.0.504.g3bcea36a83-goog
>
prev parent reply other threads:[~2025-04-11 0:41 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-04-09 18:39 [PATCH v2] perf report: Skip unsupported new event types Chun-Tse Shao
2025-04-11 0:41 ` 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=Z_hlTkkeFPydVyI7@google.com \
--to=namhyung@kernel.org \
--cc=acme@kernel.org \
--cc=adrian.hunter@intel.com \
--cc=alexander.shishkin@linux.intel.com \
--cc=ben.gainey@arm.com \
--cc=ctshao@google.com \
--cc=dvyukov@google.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=mark.rutland@arm.com \
--cc=mingo@redhat.com \
--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.