X-Git-Url: http://git.efficios.com/?p=lttng-tools.git;a=blobdiff_plain;f=src%2Fcommon%2Flttng-kernel.h;h=cd1a15f67cf256fb66c63edd2517acb1d9e683c8;hp=fa8ba6108cb3694210383406ce555d2323184594;hb=1ab8c2ad460ea71dd6d1580d6b69fb0cf68ce9ad;hpb=4dbc372b53ef1ac713497164e7a8b92100db7ae2 diff --git a/src/common/lttng-kernel.h b/src/common/lttng-kernel.h index fa8ba6108..cd1a15f67 100644 --- a/src/common/lttng-kernel.h +++ b/src/common/lttng-kernel.h @@ -21,8 +21,12 @@ #define _LTTNG_KERNEL_H #include +#include +#include +#include #define LTTNG_KERNEL_SYM_NAME_LEN 256 +#define LTTNG_KERNEL_MAX_UPROBE_NUM 32 /* * LTTng DebugFS ABI structures. @@ -38,11 +42,12 @@ enum lttng_kernel_instrumentation { LTTNG_KERNEL_KRETPROBE = 3, LTTNG_KERNEL_NOOP = 4, /* not hooked */ LTTNG_KERNEL_SYSCALL = 5, + LTTNG_KERNEL_UPROBE = 6, }; enum lttng_kernel_context_type { LTTNG_KERNEL_CONTEXT_PID = 0, - LTTNG_KERNEL_CONTEXT_PERF_COUNTER = 1, + LTTNG_KERNEL_CONTEXT_PERF_CPU_COUNTER = 1, LTTNG_KERNEL_CONTEXT_PROCNAME = 2, LTTNG_KERNEL_CONTEXT_PRIO = 3, LTTNG_KERNEL_CONTEXT_NICE = 4, @@ -52,6 +57,13 @@ enum lttng_kernel_context_type { LTTNG_KERNEL_CONTEXT_PPID = 8, LTTNG_KERNEL_CONTEXT_VPPID = 9, LTTNG_KERNEL_CONTEXT_HOSTNAME = 10, + LTTNG_KERNEL_CONTEXT_CPU_ID = 11, + LTTNG_KERNEL_CONTEXT_INTERRUPTIBLE = 12, + LTTNG_KERNEL_CONTEXT_PREEMPTIBLE = 13, + LTTNG_KERNEL_CONTEXT_NEED_RESCHEDULE = 14, + LTTNG_KERNEL_CONTEXT_MIGRATABLE = 15, + LTTNG_KERNEL_CONTEXT_CALLSTACK_KERNEL = 16, + LTTNG_KERNEL_CONTEXT_CALLSTACK_USER = 17, }; /* Perf counter attributes */ @@ -59,7 +71,7 @@ struct lttng_kernel_perf_counter_ctx { uint32_t type; uint64_t config; char name[LTTNG_KERNEL_SYM_NAME_LEN]; -}__attribute__((packed)); +} LTTNG_PACKED; /* Event/Channel context */ #define LTTNG_KERNEL_CONTEXT_PADDING1 16 @@ -72,14 +84,14 @@ struct lttng_kernel_context { struct lttng_kernel_perf_counter_ctx perf_counter; char padding[LTTNG_KERNEL_CONTEXT_PADDING2]; } u; -}__attribute__((packed)); +} LTTNG_PACKED; struct lttng_kernel_kretprobe { uint64_t addr; uint64_t offset; char symbol_name[LTTNG_KERNEL_SYM_NAME_LEN]; -}__attribute__((packed)); +} LTTNG_PACKED; /* * Either addr is used, or symbol_name and offset. @@ -89,12 +101,26 @@ struct lttng_kernel_kprobe { uint64_t offset; char symbol_name[LTTNG_KERNEL_SYM_NAME_LEN]; -}__attribute__((packed)); +} LTTNG_PACKED; + +struct lttng_kernel_uprobe { + int fd; +} LTTNG_PACKED; + +struct lttng_kernel_event_callsite_uprobe { + uint64_t offset; +} LTTNG_PACKED; + +struct lttng_kernel_event_callsite { + union { + struct lttng_kernel_event_callsite_uprobe uprobe; + } u; +} LTTNG_PACKED; /* Function tracer */ struct lttng_kernel_function { char symbol_name[LTTNG_KERNEL_SYM_NAME_LEN]; -}__attribute__((packed)); +} LTTNG_PACKED; #define LTTNG_KERNEL_EVENT_PADDING1 16 #define LTTNG_KERNEL_EVENT_PADDING2 LTTNG_KERNEL_SYM_NAME_LEN + 32 @@ -107,24 +133,27 @@ struct lttng_kernel_event { union { struct lttng_kernel_kretprobe kretprobe; struct lttng_kernel_kprobe kprobe; + struct lttng_kernel_uprobe uprobe; struct lttng_kernel_function ftrace; char padding[LTTNG_KERNEL_EVENT_PADDING2]; } u; -}__attribute__((packed)); +} LTTNG_PACKED; struct lttng_kernel_tracer_version { uint32_t major; uint32_t minor; uint32_t patchlevel; -}__attribute__((packed)); +} LTTNG_PACKED; -enum lttng_kernel_calibrate_type { - LTTNG_KERNEL_CALIBRATE_KRETPROBE, -}; +struct lttng_kernel_tracer_abi_version { + uint32_t major; + uint32_t minor; +} LTTNG_PACKED; -struct lttng_kernel_calibrate { - enum lttng_kernel_calibrate_type type; /* type (input) */ -}__attribute__((packed)); +struct lttng_kernel_syscall_mask { + uint32_t len; /* in bits */ + char mask[]; +} LTTNG_PACKED; /* * kernel channel @@ -139,6 +168,14 @@ struct lttng_kernel_channel { int overwrite; /* 1: overwrite, 0: discard */ char padding[LTTNG_KERNEL_CHANNEL_PADDING1]; -}__attribute__((packed)); +} LTTNG_PACKED; + +#define KERNEL_FILTER_BYTECODE_MAX_LEN 65536 +struct lttng_kernel_filter_bytecode { + uint32_t len; + uint32_t reloc_offset; + uint64_t seqnum; + char data[0]; +} LTTNG_PACKED; #endif /* _LTTNG_KERNEL_H */