Man page - tracefs_uprobe_alloc(3)
Packages contains this manual
- tracefs_instance_get_subbuf_size(3)
- tracefs_tracer_clear(3)
- tracefs_function_notrace(3)
- tracefs_instance_file_append(3)
- tracefs_hist_alloc_nd(3)
- tracefs_instance_get_affinity(3)
- tracefs_error_clear(3)
- tracefs_instance_get_dir(3)
- tracefs_filter_pid_function_clear(3)
- tracefs_buffer_stat_timestamp(3)
- tracefs_hist_add_key(3)
- tracefs_set_loglevel(3)
- tracefs_trace_pipe_stop(3)
- tracefs_instance_file_open(3)
- tracefs_iterate_stop(3)
- tracefs_synth_append_end_filter(3)
- tracefs_vprintf(3)
- tracefs_instance_put_stat(3)
- tracefs_hist_add_value(3)
- tracefs_cpu_read(3)
- tracefs_synth_free(3)
- tracefs_event_file_exists(3)
- tracefs_instance_clear(3)
- tracefs_event_enable(3)
- tracefs_dynevent_get(3)
- tracefs_synth_add_match_field(3)
- tracefs_mapped_is_supported(3)
- tracefs_list_add(3)
- tracefs_load_cmdlines(3)
- tracefs_instance_set_affinity_raw(3)
- libtracefs(3)
- tracefs_hist_set_sort_key(3)
- tracefs_event_filter_clear(3)
- tracefs_tracing_dir_is_mounted(3)
- tracefs_binary_write(3)
- tracefs_cpu_snapshot_open(3)
- tracefs_cpu_unmap(3)
- tracefs_synth_add_compare_field(3)
- tracefs_synth_show_event(3)
- tracefs_follow_event(3)
- tracefs_option_name(3)
- tracefs_instance_free(3)
- tracefs_synth_add_end_field(3)
- tracefs_uretprobe_alloc(3)
- tracefs_synth_snapshot(3)
- tracefs_hist_alloc_nd_cnt(3)
- tracefs_synth_trace(3)
- tracefs_option_mask_is_set(3)
- tracefs_buffer_stat_commit_overrun(3)
- tracefs_tracer_available(3)
- tracefs_instance_get_buffer_percent(3)
- tracefs_instance_file_read_number(3)
- tracefs_cpu_flush(3)
- tracefs_synth_get_name(3)
- tracefs_synth_get_event(3)
- tracefs_dir_exists(3)
- tracefs_printf(3)
- tracefs_event_systems(3)
- tracefs_error_all(3)
- tracefs_cpu_stop(3)
- tracefs_hist_alloc(3)
- tracefs_trace_on_get_fd(3)
- tracefs_instance_get_stat(3)
- tracefs_snapshot_snap(3)
- tracefs_buffer_stat_dropped_events(3)
- tracefs_event_disable(3)
- tracefs_hist_get_name(3)
- tracefs_iterate_snapshot_events(3)
- tracefs_synth_set_instance(3)
- tracefs_filter_string_verify(3)
- tracefs_trace_off(3)
- tracefs_synth_show_end_hist(3)
- tracefs_dynevent_info(3)
- tracefs_sql(3)
- tracefs_error_last(3)
- tracefs_dynevent_get_all(3)
- tracefs_file_exists(3)
- tracefs_synth_show_start_hist(3)
- tracefs_hist_add_sort_key(3)
- tracefs_instance_file_clear(3)
- tracefs_kprobe_raw(3)
- tracefs_dynevent_destroy_all(3)
- tracefs_dynevent_free(3)
- tracefs_cpu_open(3)
- tracefs_load_headers(3)
- tracefs_filter_pid_events_clear(3)
- tracefs_instance_tracers(3)
- tracefs_instance_reset(3)
- tracefs_tracers(3)
- tracefs_cpu_is_mapped(3)
- tracefs_hist_add_key_cnt(3)
- tracefs_debug_dir(3)
- tracefs_hist_add_name(3)
- tracefs_instance_destroy(3)
- tracefs_event_file_append(3)
- tracefs_buffer_stat_bytes(3)
- tracefs_cpu_flush_write(3)
- tracefs_instances(3)
- tracefs_cpu_close(3)
- tracefs_hist_destroy(3)
- tracefs_option_is_supported(3)
- tracefs_cpu_open_mapped(3)
- tracefs_buffer_stat_overrun(3)
- tracefs_dynevent_destroy(3)
- sqlhist(1)
- tracefs_instance_file_read(3)
- tracefs_cpu_read_buf(3)
- tracefs_instance_get_affinity_set(3)
- tracefs_snapshot_free(3)
- tracefs_instances_walk(3)
- tracefs_set_tracing_dir(3)
- tracefs_hist_pause(3)
- tracefs_synth_complete(3)
- tracefs_option_id(3)
- tracefs_cpu_free_fd(3)
- tracefs_hist_sort_key_direction(3)
- tracefs_hist_continue(3)
- tracefs_kretprobe_raw(3)
- tracefs_trace_on_fd(3)
- tracefs_synth_raw_fmt(3)
- tracefs_hist_echo_cmd(3)
- tracefs_time_conversion(3)
- tracefs_filter_pid_events(3)
- tracefs_hist_free(3)
- tracefs_hist_get_event(3)
- tracefs_buffer_stat_entries(3)
- tracefs_follow_missed_events(3)
- tracefs_synth_echo_cmd(3)
- tracefs_filter_pid_function(3)
- tracefs_get_clock(3)
- tracefs_get_tracing_file(3)
- tracefs_cpu_flush_buf(3)
- tracefs_options_get_enabled(3)
- tracefs_print_close(3)
- tracefs_local_events(3)
- tracefs_dynevent_list_free(3)
- tracefs_cpu_buffered_read_buf(3)
- tracefs_cpu_buffered_read(3)
- tracefs_trace_on(3)
- tracefs_event_file_clear(3)
- tracefs_option_enable(3)
- tracefs_snapshot_clear(3)
- tracefs_function_filter(3)
- tracefs_hist_append_filter(3)
- tracefs_list_free(3)
- tracefs_synth_add_start_field(3)
- tracefs_trace_pipe_print(3)
- tracefs_buffer_stat_read_events(3)
- tracefs_trace_is_on(3)
- tracefs_instance_set_buffer_size(3)
- tracefs_instance_get_affinity_raw(3)
- tracefs_hist_command(3)
- tracefs_instance_find_cid_pid(3)
- tracefs_follow_event_clear(3)
- tracefs_trace_pipe_stream(3)
- tracefs_event_is_enabled(3)
- tracefs_trace_off_fd(3)
- tracefs_cpu_read_size(3)
- tracefs_binary_close(3)
- tracefs_find_cid_pid(3)
- tracefs_instance_create(3)
- tracefs_instance_get_name(3)
- tracefs_buffer_stat_event_timestamp(3)
- tracefs_instance_set_affinity_set(3)
- tracefs_instance_get_file(3)
- tracefs_kprobe_alloc(3)
- tracefs_options_get_supported(3)
- tracefs_follow_missed_events_clear(3)
- tracefs_hist_start(3)
- tracefs_kretprobe_alloc(3)
- tracefs_hist_reset(3)
- tracefs_synth_destroy(3)
- tracefs_instance_get_buffer_size(3)
- tracefs_option_is_enabled(3)
- tracefs_binary_init(3)
- tracefs_instance_file_write(3)
- tracefs_instance_set_buffer_percent(3)
- tracefs_eprobe_alloc(3)
- tracefs_synth_create(3)
- tracefs_put_tracing_file(3)
- tracefs_event_filter_apply(3)
- tracefs_instance_alloc(3)
- tracefs_uprobe_alloc(3)
- tracefs_instance_get_trace_dir(3)
- tracefs_event_file_read(3)
- tracefs_option_disable(3)
- tracefs_iterate_raw_events(3)
- tracefs_event_file_write(3)
- tracefs_system_events(3)
- tracefs_fill_local_events(3)
- tracefs_cpu_map(3)
- tracefs_dynevent_get_event(3)
- tracefs_cpu_write(3)
- tracefs_dynevent_create(3)
- tracefs_synth_append_start_filter(3)
- tracefs_synth_get_start_hist(3)
- tracefs_instance_file_write_number(3)
- tracefs_list_size(3)
- tracefs_print_init(3)
- tracefs_filter_functions(3)
- tracefs_instance_exists(3)
- tracefs_instance_set_affinity(3)
- tracefs_options(3)
- tracefs_kprobe_destroy(3)
- tracefs_hist_get_system(3)
- tracefs_cpu_pipe(3)
- tracefs_hist_alloc_2d(3)
- tracefs_synth_save(3)
- tracefs_instance_set_subbuf_size(3)
- tracefs_filter_string_append(3)
- tracefs_cpu_alloc_fd(3)
- tracefs_event_get_file(3)
- tracefs_tracing_dir(3)
- tracefs_instance_is_new(3)
- tracefs_local_events_system(3)
- tracefs_tracer_set(3)
- tracefs_synth_alloc(3)
apt-get install libtracefs-doc
Manual
LIBTRACEFS
NAMESYNOPSIS
DESCRIPTION
RETURN VALUE
EXAMPLE
FILES
SEE ALSO
AUTHOR
REPORTING BUGS
LICENSE
RESOURCES
COPYING
NOTES
NAME
tracefs_uprobe_alloc, tracefs_uretprobe_alloc - Allocate new user (return) probe
SYNOPSIS
#include <tracefs.h>
struct
tracefs_dynevent *
tracefs_uprobe_alloc
(const char *
system
, const
char *
event
,
const char *
file
, unsigned long long
offset
,
const char *
fetchargs
)
struct tracefs_dynevent *
tracefs_uretprobe_alloc
(const char *
system
, const
char *
event
,
const char *
file
, unsigned long long
offset
,
const char *
fetchargs
)
DESCRIPTION
tracefs_uprobe_alloc () allocates a new uprobe context. It will be in the system group (or uprobes if system is NULL) and with event name. The uprobe will be attached to offset within the file . The list of arguments, described in fetchargs , will be fetched with the uprobe. The returned pointer to the user probe context must be freed with tracefs_dynevent_free (). The ubrobe is not configured in the system, tracefs_dynevent_* set of APIs can be used to configure it.
The tracefs_uretprobe_alloc () behaves the same as tracefs_uprobe_alloc (), the only difference is that it allocates context to user return probe (uretprobe).
RETURN VALUE
The tracefs_uprobe_alloc () and tracefs_uretprobe_alloc () APIs return a pointer to an allocated tracefs_dynevent structure, describing the user probe. This pointer must be freed with tracefs_dynevent_free (3). Note, this only allocates a descriptor representing the uprobe. It does not modify the running system. On error NULL is returned.
EXAMPLE
#include
<stdlib.h>
#include <unistd.h>
#include <sys/wait.h>
#include <tracefs.h>
static int
callback(struct tep_event *event, struct tep_record *record,
int cpu, void *data)
{
struct trace_seq seq;
trace_seq_init(&seq);
tep_print_event(event->tep, &seq, record,
"%d-%s: %s",
TEP_PRINT_PID, TEP_PRINT_COMM, TEP_PRINT_NAME);
trace_seq_puts(&seq, "'\n");
trace_seq_terminate(&seq);
trace_seq_do_printf(&seq);
trace_seq_destroy(&seq);
return 0;
}
static pid_t
run_exec(char **argv, char **env)
{
pid_t pid;
pid = fork();
if (pid)
return pid;
execve(argv[0],
argv, env);
perror("exec");
exit(-1);
}
const char *myprobe = "my_urobes";
int main (int
argc, char **argv, char **env)
{
struct tracefs_dynevent *uprobe, *uretprobe;
struct tep_handle *tep;
struct tracefs_instance *instance;
const char *sysnames[] = { myprobe, NULL };
long addr;
pid_t pid;
if (argc <
3) {
printf("usage: %s file_offset command\n",
argv[0]);
exit(-1);
}
addr = strtol(argv[1], NULL, 0);
instance =
tracefs_instance_create("exec_open");
if (!instance) {
perror("creating instance");
exit(-1);
}
tracefs_dynevent_destroy_all(TRACEFS_DYNEVENT_UPROBE|TRACEFS_DYNEVENT_URETPROBE, true);
uprobe =
tracefs_uprobe_alloc(myprobe, "user_probe",
argv[2], addr, NULL);
uretprobe = tracefs_uretprobe_alloc(myprobe,
"user_retprobe", argv[2], addr, NULL);
if (!uprobe || !uretprobe) {
perror("allocating user probes");
exit(-1);
}
if
(tracefs_dynevent_create(uprobe) ||
tracefs_dynevent_create(uretprobe)) {
perror("creating user probes");
exit(-1);
}
tep =
tracefs_local_events_system(NULL, sysnames);
if (!tep) {
perror("reading events");
exit(-1);
}
tracefs_event_enable(instance,
myprobe, "user_probe");
tracefs_event_enable(instance, myprobe,
"user_retprobe");
pid = run_exec(&argv[2], env);
/* Let the
child start to run */
sched_yield();
do {
tracefs_load_cmdlines(NULL, tep);
tracefs_iterate_raw_events(tep, instance, NULL, 0, callback,
NULL);
} while (waitpid(pid, NULL, WNOHANG) != pid);
/* disable and
destroy the events */
tracefs_dynevent_destroy(uprobe, true);
tracefs_dynevent_destroy(uretprobe, true);
tracefs_dynevent_free(uprobe);
tracefs_dynevent_free(uretprobe);
tracefs_instance_destroy(instance);
return 0;
}
FILES
tracefs.h
Header file to include in order to have access to the
library APIs.
-ltracefs
Linker switch to add when building a program that uses the
library.
SEE ALSO
libtracefs (3), libtraceevent (3), trace-cmd (1)
AUTHOR
Steven
Rostedt
<
rostedt@goodmis.org
[1]
>
Tzvetomir Stoyanov
<
tz.stoyanov@gmail.com
[2]
>
REPORTING BUGS
Report bugs to < linux-trace-devel@vger.kernel.org [3] >
LICENSE
libtracefs is Free Software licensed under the GNU LGPL 2.1
RESOURCES
https://git.kernel.org/pub/scm/libs/libtrace/libtracefs.git/
COPYING
Copyright (C) 2022 VMware, Inc. Free use of this software is granted under the terms of the GNU Public License (GPL).
NOTES
|
1. |
rostedt@goodmis.org |
mailto:rostedt@goodmis.org
|
2. |
tz.stoyanov@gmail.com |
mailto:tz.stoyanov@gmail.com
|
3. |
linux-trace-devel@vger.kernel.org |
mailto:linux-trace-devel@vger.kernel.org