X-Git-Url: http://git.lttng.org./?a=blobdiff_plain;f=ltt-debugfs-abi.h;h=d7d68926960d3a51a030d5179f83a4c063ed3436;hb=41affe319e5f4c049ba0ae427f485d8cdfb65488;hp=103e561b45f0460b8ac43bdb1acbd8f7c76d3dcc;hpb=38d024aef3fc8a0dc8dbecf6fbd4b55dc1e5e49f;p=lttng-modules.git diff --git a/ltt-debugfs-abi.h b/ltt-debugfs-abi.h index 103e561b..d7d68926 100644 --- a/ltt-debugfs-abi.h +++ b/ltt-debugfs-abi.h @@ -11,9 +11,12 @@ #include +#define LTTNG_SYM_NAME_LEN 128 + enum lttng_kernel_instrumentation { LTTNG_KERNEL_TRACEPOINTS, LTTNG_KERNEL_KPROBES, + LTTNG_KERNEL_FUNCTION_TRACER, }; /* @@ -21,26 +24,45 @@ enum lttng_kernel_instrumentation { */ struct lttng_kernel_channel { - int overwrite; /* 1: overwrite, 0: discard */ - u64 subbuf_size; - u64 num_subbuf; - unsigned int switch_timer_interval; - unsigned int read_timer_interval; + int overwrite; /* 1: overwrite, 0: discard */ + uint64_t subbuf_size; /* in bytes */ + uint64_t num_subbuf; + unsigned int switch_timer_interval; /* usecs */ + unsigned int read_timer_interval; /* usecs */ }; -struct lttng_kernel_event { - enum lttng_kernel_instrumentation instrumentation; - char name[]; +struct lttng_kernel_tracepoint { }; /* * Either addr is used, or symbol_name and offset. */ struct lttng_kernel_kprobe { - u64 addr; + uint64_t addr; + + uint64_t offset; + char symbol_name[LTTNG_SYM_NAME_LEN]; +}; + +struct lttng_kernel_function_tracer { + char symbol_name[LTTNG_SYM_NAME_LEN]; +}; + +struct lttng_kernel_event { + char name[LTTNG_SYM_NAME_LEN]; /* event name */ + enum lttng_kernel_instrumentation instrumentation; + /* Per instrumentation type configuration */ + union { + struct lttng_kernel_tracepoint tracepoint; + struct lttng_kernel_kprobe kprobe; + struct lttng_kernel_function_tracer ftrace; + } u; +}; - u64 offset; - char symbol_name[]; +struct lttng_kernel_tracer_version { + uint32_t version; + uint32_t patchlevel; + uint32_t sublevel; }; #define LTTNG_KERNEL_SESSION _IO(0xF6, 0x40) @@ -56,6 +78,6 @@ struct lttng_kernel_kprobe { #define LTTNG_KERNEL_KPROBE \ _IOW(0xF6, 0x47, struct lttng_kernel_kprobe) #define LTTNG_KERNEL_TRACER_VERSION \ - _IOW(0xF6, 0x48, struct lttng_kernel_tracer_version) + _IOR(0xF6, 0x48, struct lttng_kernel_tracer_version) #endif /* _LTT_DEBUGFS_ABI_H */