]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
perf bpf-filter: Pass 'target' to perf_bpf_filter__prepare()
authorNamhyung Kim <namhyung@kernel.org>
Wed, 3 Jul 2024 22:30:29 +0000 (15:30 -0700)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Thu, 1 Aug 2024 15:11:33 +0000 (12:11 -0300)
This is needed to prepare target-specific actions in the later patch.
We want to reuse the pinned BPF program and map for regular users to
profile their own processes.

Signed-off-by: Namhyung Kim <namhyung@kernel.org>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Ian Rogers <irogers@google.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: KP Singh <kpsingh@kernel.org>
Cc: Kan Liang <kan.liang@linux.intel.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Song Liu <song@kernel.org>
Cc: Stephane Eranian <eranian@google.com>
Cc: bpf@vger.kernel.org
Link: https://lore.kernel.org/r/20240703223035.2024586-3-namhyung@kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/builtin-record.c
tools/perf/builtin-stat.c
tools/perf/builtin-top.c
tools/perf/builtin-trace.c
tools/perf/util/bpf-filter.c
tools/perf/util/bpf-filter.h
tools/perf/util/evlist.c
tools/perf/util/evlist.h

index a94516e8c522269e614492bf98b62d650551b0ba..c599e620ee89eae183a67bcab9ba1e268ac0e7b0 100644 (file)
@@ -1389,7 +1389,7 @@ try_again:
 "even with a suitable vmlinux or kallsyms file.\n\n");
        }
 
-       if (evlist__apply_filters(evlist, &pos)) {
+       if (evlist__apply_filters(evlist, &pos, &opts->target)) {
                pr_err("failed to set filter \"%s\" on event %s with %d (%s)\n",
                        pos->filter ?: "BPF", evsel__name(pos), errno,
                        str_error_r(errno, msg, sizeof(msg)));
index 661832756a248f5c0c0a394d20e6ccd24469258f..1f92445f748071273e1ca413125e6674b53ed35e 100644 (file)
@@ -833,7 +833,7 @@ try_again_reset:
                        return -1;
        }
 
-       if (evlist__apply_filters(evsel_list, &counter)) {
+       if (evlist__apply_filters(evsel_list, &counter, &target)) {
                pr_err("failed to set filter \"%s\" on event %s with %d (%s)\n",
                        counter->filter, evsel__name(counter), errno,
                        str_error_r(errno, msg, sizeof(msg)));
index e8cbbf10d361e70d421753d38dc27f6de4571758..d1a06a88d6935dd857bd9f0cf834c2eae2d0696e 100644 (file)
@@ -1055,7 +1055,7 @@ try_again:
                }
        }
 
-       if (evlist__apply_filters(evlist, &counter)) {
+       if (evlist__apply_filters(evlist, &counter, &opts->target)) {
                pr_err("failed to set filter \"%s\" on event %s with %d (%s)\n",
                        counter->filter ?: "BPF", evsel__name(counter), errno,
                        str_error_r(errno, msg, sizeof(msg)));
index 488c2cedc1101f0aacf64fe9b40ad587da9fee0b..ef951ce1a0ddb4dcb4fd9801224a4f00e72993f8 100644 (file)
@@ -4135,7 +4135,7 @@ static int trace__run(struct trace *trace, int argc, const char **argv)
        err = trace__expand_filters(trace, &evsel);
        if (err)
                goto out_delete_evlist;
-       err = evlist__apply_filters(evlist, &evsel);
+       err = evlist__apply_filters(evlist, &evsel, &trace->opts.target);
        if (err < 0)
                goto out_error_apply_filters;
 
index 2510832d83f95e03980803158d9c84a76dc0da20..0b2eca56aa10d9118196e68a8ae723c0d2dc332c 100644 (file)
@@ -91,7 +91,7 @@ static int check_sample_flags(struct evsel *evsel, struct perf_bpf_filter_expr *
        return -1;
 }
 
-int perf_bpf_filter__prepare(struct evsel *evsel)
+int perf_bpf_filter__prepare(struct evsel *evsel, struct target *target __maybe_unused)
 {
        int i, x, y, fd, ret;
        struct sample_filter_bpf *skel;
index cd6764442c165a7f6049f369fa45dbe513ec3df9..605a3d0226e0748bb7a3b846b3e8ae2d33478cf2 100644 (file)
@@ -16,6 +16,7 @@ struct perf_bpf_filter_expr {
 };
 
 struct evsel;
+struct target;
 
 #ifdef HAVE_BPF_SKEL
 struct perf_bpf_filter_expr *perf_bpf_filter_expr__new(enum perf_bpf_filter_term term,
@@ -23,7 +24,7 @@ struct perf_bpf_filter_expr *perf_bpf_filter_expr__new(enum perf_bpf_filter_term
                                                       enum perf_bpf_filter_op op,
                                                       unsigned long val);
 int perf_bpf_filter__parse(struct list_head *expr_head, const char *str);
-int perf_bpf_filter__prepare(struct evsel *evsel);
+int perf_bpf_filter__prepare(struct evsel *evsel, struct target *target);
 int perf_bpf_filter__destroy(struct evsel *evsel);
 u64 perf_bpf_filter__lost_count(struct evsel *evsel);
 
@@ -34,7 +35,8 @@ static inline int perf_bpf_filter__parse(struct list_head *expr_head __maybe_unu
 {
        return -EOPNOTSUPP;
 }
-static inline int perf_bpf_filter__prepare(struct evsel *evsel __maybe_unused)
+static inline int perf_bpf_filter__prepare(struct evsel *evsel __maybe_unused,
+                                          struct target *target __maybe_unused)
 {
        return -EOPNOTSUPP;
 }
index 3a719edafc7ad263f0d5226184f47050de29a945..1417f9a23083708845a2ae0d6dd7deb39de1487d 100644 (file)
@@ -1086,7 +1086,8 @@ out_delete_threads:
        return -1;
 }
 
-int evlist__apply_filters(struct evlist *evlist, struct evsel **err_evsel)
+int evlist__apply_filters(struct evlist *evlist, struct evsel **err_evsel,
+                         struct target *target)
 {
        struct evsel *evsel;
        int err = 0;
@@ -1108,7 +1109,7 @@ int evlist__apply_filters(struct evlist *evlist, struct evsel **err_evsel)
                 * non-tracepoint events can have BPF filters.
                 */
                if (!list_empty(&evsel->bpf_filters)) {
-                       err = perf_bpf_filter__prepare(evsel);
+                       err = perf_bpf_filter__prepare(evsel, target);
                        if (err) {
                                *err_evsel = evsel;
                                break;
index cb91dc9117a2726b34b9dce5265186c89eee96cd..cccc34da5a02a3d6f340054a0e3bec6232f0bba6 100644 (file)
@@ -20,6 +20,7 @@ struct pollfd;
 struct thread_map;
 struct perf_cpu_map;
 struct record_opts;
+struct target;
 
 /*
  * State machine of bkw_mmap_state:
@@ -212,7 +213,8 @@ void evlist__enable_non_dummy(struct evlist *evlist);
 void evlist__set_selected(struct evlist *evlist, struct evsel *evsel);
 
 int evlist__create_maps(struct evlist *evlist, struct target *target);
-int evlist__apply_filters(struct evlist *evlist, struct evsel **err_evsel);
+int evlist__apply_filters(struct evlist *evlist, struct evsel **err_evsel,
+                         struct target *target);
 
 u64 __evlist__combined_sample_type(struct evlist *evlist);
 u64 evlist__combined_sample_type(struct evlist *evlist);