1 #ifndef _LTTNG_UST_ABI_H
2 #define _LTTNG_UST_ABI_H
7 * Copyright 2010-2011 (c) - Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
11 * THIS MATERIAL IS PROVIDED AS IS, WITH ABSOLUTELY NO WARRANTY EXPRESSED
12 * OR IMPLIED. ANY USE IS AT YOUR OWN RISK.
14 * Permission is hereby granted to use or copy this program
15 * for any purpose, provided the above notices are retained on all copies.
16 * Permission to modify the code and to distribute modified code is granted,
17 * provided the above notices are retained, and a notice that the code was
18 * modified is included with the above copyright notice.
23 #define LTTNG_UST_SYM_NAME_LEN 256
25 #define LTTNG_UST_COMM_VERSION_MAJOR 0
26 #define LTTNG_UST_COMM_VERSION_MINOR 1
28 enum lttng_ust_instrumentation
{
29 LTTNG_UST_TRACEPOINT
= 0,
31 LTTNG_UST_FUNCTION
= 2,
32 LTTNG_UST_TRACEPOINT_LOGLEVEL
= 3,
35 enum lttng_ust_output
{
39 struct lttng_ust_tracer_version
{
45 struct lttng_ust_channel
{
46 int overwrite
; /* 1: overwrite, 0: discard */
47 uint64_t subbuf_size
; /* in bytes */
49 unsigned int switch_timer_interval
; /* usecs */
50 unsigned int read_timer_interval
; /* usecs */
51 enum lttng_ust_output output
; /* output mode */
55 * This structure is only used internally within UST. It is not per-se
56 * part of the communication between sessiond and UST.
58 struct lttng_ust_stream
{
61 uint64_t memory_map_size
;
64 struct lttng_ust_event
{
65 char name
[LTTNG_UST_SYM_NAME_LEN
]; /* event name */
66 enum lttng_ust_instrumentation instrumentation
;
67 /* Per instrumentation type configuration */
72 enum lttng_ust_context_type
{
73 LTTNG_UST_CONTEXT_VTID
= 0,
74 LTTNG_UST_CONTEXT_VPID
= 1,
75 LTTNG_UST_CONTEXT_PTHREAD_ID
= 2,
76 LTTNG_UST_CONTEXT_PROCNAME
= 3,
79 struct lttng_ust_context
{
80 enum lttng_ust_context_type ctx
;
86 * Tracer channel attributes.
88 struct lttng_ust_channel_attr
{
89 int overwrite
; /* 1: overwrite, 0: discard */
90 uint64_t subbuf_size
; /* bytes */
91 uint64_t num_subbuf
; /* power of 2 */
92 unsigned int switch_timer_interval
; /* usec */
93 unsigned int read_timer_interval
; /* usec */
94 enum lttng_ust_output output
; /* splice, mmap */
97 struct lttng_ust_tracepoint_iter
{
98 char name
[LTTNG_UST_SYM_NAME_LEN
]; /* provider:name */
99 char loglevel
[LTTNG_UST_SYM_NAME_LEN
]; /* loglevel */
100 int64_t loglevel_value
;
103 struct lttng_ust_object_data
{
107 uint64_t memory_map_size
;
110 #define _UST_CMD(minor) (minor)
111 #define _UST_CMDR(minor, type) (minor)
112 #define _UST_CMDW(minor, type) (minor)
114 /* Handled by object descriptor */
115 #define LTTNG_UST_RELEASE _UST_CMD(0x1)
117 /* Handled by object cmd */
119 /* LTTng-UST commands */
120 #define LTTNG_UST_SESSION _UST_CMD(0x40)
121 #define LTTNG_UST_TRACER_VERSION \
122 _UST_CMDR(0x41, struct lttng_ust_tracer_version)
123 #define LTTNG_UST_TRACEPOINT_LIST _UST_CMD(0x42)
124 #define LTTNG_UST_WAIT_QUIESCENT _UST_CMD(0x43)
125 #define LTTNG_UST_REGISTER_DONE _UST_CMD(0x44)
127 /* Session FD commands */
128 #define LTTNG_UST_METADATA \
129 _UST_CMDW(0x50, struct lttng_ust_channel)
130 #define LTTNG_UST_CHANNEL \
131 _UST_CMDW(0x51, struct lttng_ust_channel)
132 #define LTTNG_UST_SESSION_START _UST_CMD(0x52)
133 #define LTTNG_UST_SESSION_STOP _UST_CMD(0x53)
135 /* Channel FD commands */
136 #define LTTNG_UST_STREAM _UST_CMD(0x60)
137 #define LTTNG_UST_EVENT \
138 _UST_CMDW(0x61, struct lttng_ust_event)
140 /* Event and Channel FD commands */
141 #define LTTNG_UST_CONTEXT \
142 _UST_CMDW(0x70, struct lttng_ust_context)
143 #define LTTNG_UST_FLUSH_BUFFER \
146 /* Event, Channel and Session commands */
147 #define LTTNG_UST_ENABLE _UST_CMD(0x80)
148 #define LTTNG_UST_DISABLE _UST_CMD(0x81)
150 /* Tracepoint list commands */
151 #define LTTNG_UST_TRACEPOINT_LIST_GET _UST_CMD(0x90)
153 #define LTTNG_UST_ROOT_HANDLE 0
155 struct lttng_ust_obj
;
161 uint64_t *memory_map_size
;
166 uint64_t *memory_map_size
;
170 struct lttng_ust_objd_ops
{
171 long (*cmd
)(int objd
, unsigned int cmd
, unsigned long arg
,
172 union ust_args
*args
);
173 int (*release
)(int objd
);
176 /* Create root handle. Always ID 0. */
177 int lttng_abi_create_root_handle(void);
179 const struct lttng_ust_objd_ops
*objd_ops(int id
);
180 int lttng_ust_objd_unref(int id
);
182 void lttng_ust_abi_exit(void);
183 void lttng_ust_events_exit(void);
185 #endif /* _LTTNG_UST_ABI_H */