perf bpf: Move the declaration of struct rq
struct rq is defined in vmlinux.h when the vmlinux.h is generated,
this causes a redefinition failure if it is declared in
lock_contention.bpf.c. Move the definition to vmlinux.h for
consistency with the generated version.
Fixes: 760ebc4574
("perf lock contention: Add empty 'struct rq' to satisfy libbpf 'runqueue' type verification")
Signed-off-by: Ian Rogers <irogers@google.com>
Acked-by: Andrii Nakryiko <andrii@kernel.org>
Acked-by: Namhyung Kim <namhyung@kernel.org>
Acked-by: Jiri Olsa <jolsa@kernel.org>
Cc: James Clark <james.clark@arm.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Yang Jihong <yangjihong1@huawei.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Arnaldo Carvalho de Melo <acme@kernel.org>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Tiezhu Yang <yangtiezhu@loongson.cn>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: bpf@vger.kernel.org
Link: https://lore.kernel.org/r/20230623041405.4039475-3-irogers@google.com
Signed-off-by: Namhyung Kim <namhyung@kernel.org>
This commit is contained in:
Родитель
b7a2d774c9
Коммит
5c45b21047
|
@ -416,8 +416,6 @@ int contention_end(u64 *ctx)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct rq {};
|
|
||||||
|
|
||||||
extern struct rq runqueues __ksym;
|
extern struct rq runqueues __ksym;
|
||||||
|
|
||||||
struct rq___old {
|
struct rq___old {
|
||||||
|
|
|
@ -171,4 +171,14 @@ struct bpf_perf_event_data_kern {
|
||||||
struct perf_sample_data *data;
|
struct perf_sample_data *data;
|
||||||
struct perf_event *event;
|
struct perf_event *event;
|
||||||
} __attribute__((preserve_access_index));
|
} __attribute__((preserve_access_index));
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If 'struct rq' isn't defined for lock_contention.bpf.c, for the sake of
|
||||||
|
* rq___old and rq___new, then the type for the 'runqueue' variable ends up
|
||||||
|
* being a forward declaration (BTF_KIND_FWD) while the kernel has it defined
|
||||||
|
* (BTF_KIND_STRUCT). The definition appears in vmlinux.h rather than
|
||||||
|
* lock_contention.bpf.c for consistency with a generated vmlinux.h.
|
||||||
|
*/
|
||||||
|
struct rq {};
|
||||||
|
|
||||||
#endif // __VMLINUX_H
|
#endif // __VMLINUX_H
|
||||||
|
|
Загрузка…
Ссылка в новой задаче