Add padding to ABI
[lttng-modules.git] / lttng-abi.h
CommitLineData
e8951e63
MD
1#ifndef _LTTNG_ABI_H
2#define _LTTNG_ABI_H
57a13317
MD
3
4/*
e8951e63 5 * lttng-abi.h
57a13317
MD
6 *
7 * Copyright 2010 (c) - Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
8 *
80996790 9 * LTTng ABI header
17baffe2
MD
10 *
11 * Dual LGPL v2.1/GPL v2 license.
57a13317
MD
12 */
13
14#include <linux/fs.h>
15
f8695253 16#define LTTNG_KERNEL_SYM_NAME_LEN 256
d6d808f3 17
38d024ae 18enum lttng_kernel_instrumentation {
4c183524
MD
19 LTTNG_KERNEL_TRACEPOINT = 0,
20 LTTNG_KERNEL_KPROBE = 1,
21 LTTNG_KERNEL_FUNCTION = 2,
7371f44c 22 LTTNG_KERNEL_KRETPROBE = 3,
1ec65de1 23 LTTNG_KERNEL_NOOP = 4, /* not hooked */
43880ee8 24 LTTNG_KERNEL_SYSCALL = 5,
57a13317
MD
25};
26
96ba7208
JD
27/*
28 * LTTng consumer mode
29 */
30enum lttng_kernel_output {
31 LTTNG_KERNEL_SPLICE = 0,
32 LTTNG_KERNEL_MMAP = 1,
33};
34
57a13317
MD
35/*
36 * LTTng DebugFS ABI structures.
37 */
8e099bae 38#define LTTNG_KERNEL_CHANNEL_PADDING LTTNG_KERNEL_SYM_NAME_LEN + 32
38d024ae 39struct lttng_kernel_channel {
9e245ead
MD
40 int overwrite; /* 1: overwrite, 0: discard */
41 uint64_t subbuf_size; /* in bytes */
80c16bcf 42 uint64_t num_subbuf;
9e245ead
MD
43 unsigned int switch_timer_interval; /* usecs */
44 unsigned int read_timer_interval; /* usecs */
96ba7208 45 enum lttng_kernel_output output; /* splice, mmap */
8e099bae 46 char padding[LTTNG_KERNEL_CHANNEL_PADDING];
57a13317
MD
47};
48
8e099bae 49#define LTTNG_KERNEL_KRETPROBE_PADDING LTTNG_KERNEL_SYM_NAME_LEN + 32
7371f44c
MD
50struct lttng_kernel_kretprobe {
51 uint64_t addr;
52
53 uint64_t offset;
f8695253 54 char symbol_name[LTTNG_KERNEL_SYM_NAME_LEN];
7371f44c
MD
55};
56
38d024ae
MD
57/*
58 * Either addr is used, or symbol_name and offset.
59 */
8e099bae 60#define LTTNG_KERNEL_KPROBE_PADDING LTTNG_KERNEL_SYM_NAME_LEN + 32
38d024ae 61struct lttng_kernel_kprobe {
80c16bcf 62 uint64_t addr;
38d024ae 63
80c16bcf 64 uint64_t offset;
f8695253 65 char symbol_name[LTTNG_KERNEL_SYM_NAME_LEN];
d6d808f3
MD
66};
67
8e099bae 68#define LTTNG_KERNEL_FUNCTION_TRACER_PADDING LTTNG_KERNEL_SYM_NAME_LEN + 32
f17701fb 69struct lttng_kernel_function_tracer {
f8695253 70 char symbol_name[LTTNG_KERNEL_SYM_NAME_LEN];
f17701fb
MD
71};
72
43880ee8
MD
73/*
74 * For syscall tracing, name = '\0' means "enable all".
75 */
8e099bae
MD
76#define LTTNG_KERNEL_EVENT_PADDING1 16
77#define LTTNG_KERNEL_EVENT_PADDING2 LTTNG_KERNEL_SYM_NAME_LEN + 32
d6d808f3 78struct lttng_kernel_event {
f8695253 79 char name[LTTNG_KERNEL_SYM_NAME_LEN]; /* event name */
d6d808f3 80 enum lttng_kernel_instrumentation instrumentation;
8e099bae
MD
81 char padding[LTTNG_KERNEL_EVENT_PADDING1];
82
d6d808f3
MD
83 /* Per instrumentation type configuration */
84 union {
7371f44c 85 struct lttng_kernel_kretprobe kretprobe;
d6d808f3 86 struct lttng_kernel_kprobe kprobe;
f17701fb 87 struct lttng_kernel_function_tracer ftrace;
8e099bae 88 char padding[LTTNG_KERNEL_EVENT_PADDING2];
d6d808f3 89 } u;
38d024ae 90};
c099397a 91
80c16bcf
MD
92struct lttng_kernel_tracer_version {
93 uint32_t version;
94 uint32_t patchlevel;
95 uint32_t sublevel;
96};
97
3db41b2c
MD
98enum lttng_kernel_calibrate_type {
99 LTTNG_KERNEL_CALIBRATE_KRETPROBE,
57105fc2
MD
100};
101
3db41b2c
MD
102struct lttng_kernel_calibrate {
103 enum lttng_kernel_calibrate_type type; /* type (input) */
57105fc2
MD
104};
105
12a313a5 106enum lttng_kernel_context_type {
4c183524
MD
107 LTTNG_KERNEL_CONTEXT_PID = 0,
108 LTTNG_KERNEL_CONTEXT_PERF_COUNTER = 1,
a2563e83 109 LTTNG_KERNEL_CONTEXT_PROCNAME = 2,
4c183524
MD
110 LTTNG_KERNEL_CONTEXT_PRIO = 3,
111 LTTNG_KERNEL_CONTEXT_NICE = 4,
112 LTTNG_KERNEL_CONTEXT_VPID = 5,
113 LTTNG_KERNEL_CONTEXT_TID = 6,
114 LTTNG_KERNEL_CONTEXT_VTID = 7,
115 LTTNG_KERNEL_CONTEXT_PPID = 8,
116 LTTNG_KERNEL_CONTEXT_VPPID = 9,
8070f5c0
MD
117};
118
119struct lttng_kernel_perf_counter_ctx {
120 uint32_t type;
121 uint64_t config;
f8695253 122 char name[LTTNG_KERNEL_SYM_NAME_LEN];
8070f5c0
MD
123};
124
8e099bae
MD
125#define LTTNG_KERNEL_CONTEXT_PADDING1 16
126#define LTTNG_KERNEL_CONTEXT_PADDING2 LTTNG_KERNEL_SYM_NAME_LEN + 32
8070f5c0 127struct lttng_kernel_context {
12a313a5 128 enum lttng_kernel_context_type ctx;
8e099bae
MD
129 char padding[LTTNG_KERNEL_CONTEXT_PADDING1];
130
8070f5c0 131 union {
8070f5c0 132 struct lttng_kernel_perf_counter_ctx perf_counter;
8e099bae 133 char padding[LTTNG_KERNEL_CONTEXT_PADDING2];
8070f5c0
MD
134 } u;
135};
136
33749530 137/* LTTng file descriptor ioctl */
ab2277d6 138#define LTTNG_KERNEL_SESSION _IO(0xF6, 0x40)
33749530
MD
139#define LTTNG_KERNEL_TRACER_VERSION \
140 _IOR(0xF6, 0x41, struct lttng_kernel_tracer_version)
271b6681 141#define LTTNG_KERNEL_TRACEPOINT_LIST _IO(0xF6, 0x42)
360f38ea 142#define LTTNG_KERNEL_WAIT_QUIESCENT _IO(0xF6, 0x43)
57105fc2 143#define LTTNG_KERNEL_CALIBRATE \
3db41b2c 144 _IOWR(0xF6, 0x44, struct lttng_kernel_calibrate)
33749530
MD
145
146/* Session FD ioctl */
147#define LTTNG_KERNEL_METADATA \
148 _IOW(0xF6, 0x50, struct lttng_kernel_channel)
ab2277d6 149#define LTTNG_KERNEL_CHANNEL \
33749530
MD
150 _IOW(0xF6, 0x51, struct lttng_kernel_channel)
151#define LTTNG_KERNEL_SESSION_START _IO(0xF6, 0x52)
152#define LTTNG_KERNEL_SESSION_STOP _IO(0xF6, 0x53)
153
154/* Channel FD ioctl */
155#define LTTNG_KERNEL_STREAM _IO(0xF6, 0x60)
ab2277d6 156#define LTTNG_KERNEL_EVENT \
33749530 157 _IOW(0xF6, 0x61, struct lttng_kernel_event)
57a13317 158
8070f5c0
MD
159/* Event and Channel FD ioctl */
160#define LTTNG_KERNEL_CONTEXT \
161 _IOW(0xF6, 0x70, struct lttng_kernel_context)
162
e64957da
MD
163/* Event, Channel and Session ioctl */
164#define LTTNG_KERNEL_ENABLE _IO(0xF6, 0x80)
165#define LTTNG_KERNEL_DISABLE _IO(0xF6, 0x81)
166
e8951e63 167#endif /* _LTTNG_ABI_H */
This page took 0.033348 seconds and 4 git commands to generate.