From: Namhyung Kim <namhyung@kernel.org>
To: Ian Rogers <irogers@google.com>
Cc: Peter Zijlstra <peterz@infradead.org>,
Ingo Molnar <mingo@redhat.com>,
Arnaldo Carvalho de Melo <acme@kernel.org>,
Mark Rutland <mark.rutland@arm.com>,
Alexander Shishkin <alexander.shishkin@linux.intel.com>,
Jiri Olsa <jolsa@kernel.org>,
Adrian Hunter <adrian.hunter@intel.com>,
Kan Liang <kan.liang@linux.intel.com>,
James Clark <james.clark@linaro.org>,
Dapeng Mi <dapeng1.mi@linux.intel.com>,
Thomas Richter <tmricht@linux.ibm.com>,
Veronika Molnarova <vmolnaro@redhat.com>,
Hao Ge <gehao@kylinos.cn>, Howard Chu <howardchu95@gmail.com>,
Weilin Wang <weilin.wang@intel.com>,
Levi Yun <yeoreum.yun@arm.com>,
"Dr. David Alan Gilbert" <linux@treblig.org>,
Dominique Martinet <asmadeus@codewreck.org>,
Xu Yang <xu.yang_2@nxp.com>, Tengda Wu <wutengda@huaweicloud.com>,
linux-perf-users@vger.kernel.org, linux-kernel@vger.kernel.org,
bpf@vger.kernel.org
Subject: Re: [PATCH v3 00/10] Move uid filtering to BPF filters
Date: Mon, 2 Jun 2025 21:41:15 -0700 [thread overview]
Message-ID: <aD586_XkeOH2_Fes@google.com> (raw)
In-Reply-To: <CAP-5=fXiYHbe9gd_TNyy=txzrd+ONxecnpZr+uPeOnF5XxunGw@mail.gmail.com>
Hi Ian,
On Tue, May 27, 2025 at 01:39:21PM -0700, Ian Rogers wrote:
> On Fri, Apr 25, 2025 at 2:40 PM Ian Rogers <irogers@google.com> wrote:
> >
> > Rather than scanning /proc and skipping PIDs based on their UIDs, use
> > BPF filters for uid filtering. The /proc scanning in thread_map is
> > racy as the PID may exit before the perf_event_open causing perf to
> > abort. BPF UID filters are more robust as they avoid the race. The
> > /proc scanning also misses processes starting after the perf
> > command. Add a helper for commands that support UID filtering and wire
> > up. Remove the non-BPF UID filtering support given it doesn't work.
> >
> > v3: Add lengthier commit messages as requested by Arnaldo. Rebase on
> > tmp.perf-tools-next.
> >
> > v2: Add a perf record uid test (Namhyung) and force setting
> > system-wide for perf trace and perf record (Namhyung). Ensure the
> > uid filter isn't set on tracepoint evsels.
> >
> > v1: https://lore.kernel.org/lkml/20250111190143.1029906-1-irogers@google.com/
>
> Ping. Thanks,
I'm ok with preferring BPF over /proc scanning, but still hesitate to
remove it since some people don't use BPF. Can you please drop that
part and make parse_uid_filter() conditional on BPF?
Thanks,
Namhyung
> > Ian Rogers (10):
> > perf parse-events filter: Use evsel__find_pmu
> > perf target: Separate parse_uid into its own function
> > perf parse-events: Add parse_uid_filter helper
> > perf record: Switch user option to use BPF filter
> > perf tests record: Add basic uid filtering test
> > perf top: Switch user option to use BPF filter
> > perf trace: Switch user option to use BPF filter
> > perf bench evlist-open-close: Switch user option to use BPF filter
> > perf target: Remove uid from target
> > perf thread_map: Remove uid options
> >
> > tools/perf/bench/evlist-open-close.c | 36 ++++++++------
> > tools/perf/builtin-ftrace.c | 1 -
> > tools/perf/builtin-kvm.c | 2 -
> > tools/perf/builtin-record.c | 27 ++++++-----
> > tools/perf/builtin-stat.c | 4 +-
> > tools/perf/builtin-top.c | 22 +++++----
> > tools/perf/builtin-trace.c | 27 +++++++----
> > tools/perf/tests/backward-ring-buffer.c | 1 -
> > tools/perf/tests/event-times.c | 8 ++-
> > tools/perf/tests/keep-tracking.c | 2 +-
> > tools/perf/tests/mmap-basic.c | 2 +-
> > tools/perf/tests/openat-syscall-all-cpus.c | 2 +-
> > tools/perf/tests/openat-syscall-tp-fields.c | 1 -
> > tools/perf/tests/openat-syscall.c | 2 +-
> > tools/perf/tests/perf-record.c | 1 -
> > tools/perf/tests/perf-time-to-tsc.c | 2 +-
> > tools/perf/tests/shell/record.sh | 26 ++++++++++
> > tools/perf/tests/switch-tracking.c | 2 +-
> > tools/perf/tests/task-exit.c | 1 -
> > tools/perf/tests/thread-map.c | 2 +-
> > tools/perf/util/bpf-filter.c | 2 +-
> > tools/perf/util/evlist.c | 3 +-
> > tools/perf/util/parse-events.c | 33 ++++++++-----
> > tools/perf/util/parse-events.h | 1 +
> > tools/perf/util/python.c | 10 ++--
> > tools/perf/util/target.c | 54 +++------------------
> > tools/perf/util/target.h | 15 ++----
> > tools/perf/util/thread_map.c | 32 ++----------
> > tools/perf/util/thread_map.h | 6 +--
> > tools/perf/util/top.c | 4 +-
> > tools/perf/util/top.h | 1 +
> > 31 files changed, 150 insertions(+), 182 deletions(-)
> >
> > --
> > 2.49.0.850.g28803427d3-goog
> >
next prev parent reply other threads:[~2025-06-03 4:41 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-04-25 21:39 [PATCH v3 00/10] Move uid filtering to BPF filters Ian Rogers
2025-04-25 21:39 ` [PATCH v3 01/10] perf parse-events filter: Use evsel__find_pmu Ian Rogers
2025-04-25 21:40 ` [PATCH v3 02/10] perf target: Separate parse_uid into its own function Ian Rogers
2025-04-25 21:40 ` [PATCH v3 03/10] perf parse-events: Add parse_uid_filter helper Ian Rogers
2025-04-25 21:40 ` [PATCH v3 04/10] perf record: Switch user option to use BPF filter Ian Rogers
2025-04-25 21:40 ` [PATCH v3 05/10] perf tests record: Add basic uid filtering test Ian Rogers
2025-04-25 21:40 ` [PATCH v3 06/10] perf top: Switch user option to use BPF filter Ian Rogers
2025-04-25 21:40 ` [PATCH v3 07/10] perf trace: " Ian Rogers
2025-04-25 21:40 ` [PATCH v3 08/10] perf bench evlist-open-close: " Ian Rogers
2025-04-25 21:40 ` [PATCH v3 09/10] perf target: Remove uid from target Ian Rogers
2025-04-25 21:40 ` [PATCH v3 10/10] perf thread_map: Remove uid options Ian Rogers
2025-05-27 20:39 ` [PATCH v3 00/10] Move uid filtering to BPF filters Ian Rogers
2025-06-03 4:41 ` Namhyung Kim [this message]
2025-06-03 6:26 ` Ian Rogers
2025-06-03 22:32 ` Namhyung Kim
2025-06-03 23:22 ` Ian Rogers
2025-06-03 23:41 ` Namhyung Kim
2025-06-04 0:01 ` Ian Rogers
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=aD586_XkeOH2_Fes@google.com \
--to=namhyung@kernel.org \
--cc=acme@kernel.org \
--cc=adrian.hunter@intel.com \
--cc=alexander.shishkin@linux.intel.com \
--cc=asmadeus@codewreck.org \
--cc=bpf@vger.kernel.org \
--cc=dapeng1.mi@linux.intel.com \
--cc=gehao@kylinos.cn \
--cc=howardchu95@gmail.com \
--cc=irogers@google.com \
--cc=james.clark@linaro.org \
--cc=jolsa@kernel.org \
--cc=kan.liang@linux.intel.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-perf-users@vger.kernel.org \
--cc=linux@treblig.org \
--cc=mark.rutland@arm.com \
--cc=mingo@redhat.com \
--cc=peterz@infradead.org \
--cc=tmricht@linux.ibm.com \
--cc=vmolnaro@redhat.com \
--cc=weilin.wang@intel.com \
--cc=wutengda@huaweicloud.com \
--cc=xu.yang_2@nxp.com \
--cc=yeoreum.yun@arm.com \
/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.