diff options
| author | Song Liu <songliubraving@fb.com> | 2017-12-06 17:45:13 -0500 |
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2018-02-06 04:18:04 -0500 |
| commit | 65074d43fc77bcae32776724b7fa2696923c78e4 (patch) | |
| tree | 82c5ecee9c2f55393b3f5d861dc19c166cb00652 | |
| parent | 59410f5ac70a0949a6f06ba43eecb8f99be31291 (diff) | |
perf/core: Prepare perf_event.h for new types: 'perf_kprobe' and 'perf_uprobe'
Two new perf types, perf_kprobe and perf_uprobe, will be added to allow
creating [k,u]probe with perf_event_open. These [k,u]probe are associated
with the file decriptor created by perf_event_open(), thus are easy to
clean when the file descriptor is destroyed.
kprobe_func and uprobe_path are added to union config1 for pointers to
function name for kprobe or binary path for uprobe.
kprobe_addr and probe_offset are added to union config2 for kernel
address (when kprobe_func is NULL), or [k,u]probe offset.
Signed-off-by: Song Liu <songliubraving@fb.com>
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Reviewed-by: Yonghong Song <yhs@fb.com>
Reviewed-by: Josef Bacik <jbacik@fb.com>
Acked-by: Alexei Starovoitov <ast@kernel.org>
Cc: <daniel@iogearbox.net>
Cc: <davem@davemloft.net>
Cc: <kernel-team@fb.com>
Cc: <rostedt@goodmis.org>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Link: http://lkml.kernel.org/r/20171206224518.3598254-4-songliubraving@fb.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>
| -rw-r--r-- | include/uapi/linux/perf_event.h | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/include/uapi/linux/perf_event.h b/include/uapi/linux/perf_event.h index c77c9a2ebbbb..5d49cfc509e7 100644 --- a/include/uapi/linux/perf_event.h +++ b/include/uapi/linux/perf_event.h | |||
| @@ -380,10 +380,14 @@ struct perf_event_attr { | |||
| 380 | __u32 bp_type; | 380 | __u32 bp_type; |
| 381 | union { | 381 | union { |
| 382 | __u64 bp_addr; | 382 | __u64 bp_addr; |
| 383 | __u64 kprobe_func; /* for perf_kprobe */ | ||
| 384 | __u64 uprobe_path; /* for perf_uprobe */ | ||
| 383 | __u64 config1; /* extension of config */ | 385 | __u64 config1; /* extension of config */ |
| 384 | }; | 386 | }; |
| 385 | union { | 387 | union { |
| 386 | __u64 bp_len; | 388 | __u64 bp_len; |
| 389 | __u64 kprobe_addr; /* when kprobe_func == NULL */ | ||
| 390 | __u64 probe_offset; /* for perf_[k,u]probe */ | ||
| 387 | __u64 config2; /* extension of config1 */ | 391 | __u64 config2; /* extension of config1 */ |
| 388 | }; | 392 | }; |
| 389 | __u64 branch_sample_type; /* enum perf_branch_sample_type */ | 393 | __u64 branch_sample_type; /* enum perf_branch_sample_type */ |
