2 * net/tipc/trace.h: TIPC tracepoints
4 * Copyright (c) 2018, Ericsson AB
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions are met:
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. Neither the names of the copyright holders nor the names of its
16 * contributors may be used to endorse or promote products derived from
17 * this software without specific prior written permission.
19 * Alternatively, this software may be distributed under the terms of the
20 * GNU General Public License ("GPL") version 2 as published by the Free
21 * Software Foundation.
23 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "ASIS"
24 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,THE
25 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
27 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
28 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
29 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
30 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
31 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
32 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33 * POSSIBILITY OF SUCH DAMAGE.
37 #define TRACE_SYSTEM tipc
39 #if !defined(_TIPC_TRACE_H) || defined(TRACE_HEADER_MULTI_READ)
42 #include <linux/tracepoint.h>
48 #define SKB_LMIN (100)
49 #define SKB_LMAX (SKB_LMIN * 2)
50 #define LIST_LMIN (SKB_LMIN * 3)
51 #define LIST_LMAX (SKB_LMIN * 11)
52 #define SK_LMIN (SKB_LMIN * 2)
53 #define SK_LMAX (SKB_LMIN * 11)
54 #define LINK_LMIN (SKB_LMIN)
55 #define LINK_LMAX (SKB_LMIN * 16)
56 #define NODE_LMIN (SKB_LMIN)
57 #define NODE_LMAX (SKB_LMIN * 11)
59 #ifndef __TIPC_TRACE_ENUM
60 #define __TIPC_TRACE_ENUM
64 TIPC_DUMP_TRANSMQ
= 1,
65 TIPC_DUMP_BACKLOGQ
= (1 << 1),
66 TIPC_DUMP_DEFERDQ
= (1 << 2),
67 TIPC_DUMP_INPUTQ
= (1 << 3),
68 TIPC_DUMP_WAKEUP
= (1 << 4),
70 TIPC_DUMP_SK_SNDQ
= (1 << 8),
71 TIPC_DUMP_SK_RCVQ
= (1 << 9),
72 TIPC_DUMP_SK_BKLGQ
= (1 << 10),
73 TIPC_DUMP_ALL
= 0xffffu
77 /* Link & Node FSM states: */
78 #define state_sym(val) \
79 __print_symbolic(val, \
80 {(0xe), "ESTABLISHED" },\
81 {(0xe << 4), "ESTABLISHING" },\
82 {(0x1 << 8), "RESET" },\
83 {(0x2 << 12), "RESETTING" },\
84 {(0xd << 16), "PEER_RESET" },\
85 {(0xf << 20), "FAILINGOVER" },\
86 {(0xc << 24), "SYNCHING" },\
87 {(0xdd), "SELF_DOWN_PEER_DOWN" },\
88 {(0xaa), "SELF_UP_PEER_UP" },\
89 {(0xd1), "SELF_DOWN_PEER_LEAVING" },\
90 {(0xac), "SELF_UP_PEER_COMING" },\
91 {(0xca), "SELF_COMING_PEER_UP" },\
92 {(0x1d), "SELF_LEAVING_PEER_DOWN" },\
93 {(0xf0), "FAILINGOVER" },\
94 {(0xcc), "SYNCHING" })
96 /* Link & Node FSM events: */
97 #define evt_sym(val) \
98 __print_symbolic(val, \
99 {(0xec1ab1e), "ESTABLISH_EVT" },\
100 {(0x9eed0e), "PEER_RESET_EVT" },\
101 {(0xfa110e), "FAILURE_EVT" },\
102 {(0x10ca1d0e), "RESET_EVT" },\
103 {(0xfa110bee), "FAILOVER_BEGIN_EVT" },\
104 {(0xfa110ede), "FAILOVER_END_EVT" },\
105 {(0xc1ccbee), "SYNCH_BEGIN_EVT" },\
106 {(0xc1ccede), "SYNCH_END_EVT" },\
107 {(0xece), "SELF_ESTABL_CONTACT_EVT" },\
108 {(0x1ce), "SELF_LOST_CONTACT_EVT" },\
109 {(0x9ece), "PEER_ESTABL_CONTACT_EVT" },\
110 {(0x91ce), "PEER_LOST_CONTACT_EVT" },\
111 {(0xfbe), "FAILOVER_BEGIN_EVT" },\
112 {(0xfee), "FAILOVER_END_EVT" },\
113 {(0xcbe), "SYNCH_BEGIN_EVT" },\
114 {(0xcee), "SYNCH_END_EVT" })
116 /* Bearer, net device events: */
117 #define dev_evt_sym(val) \
118 __print_symbolic(val, \
119 {(NETDEV_CHANGE), "NETDEV_CHANGE" },\
120 {(NETDEV_GOING_DOWN), "NETDEV_GOING_DOWN" },\
121 {(NETDEV_UP), "NETDEV_UP" },\
122 {(NETDEV_CHANGEMTU), "NETDEV_CHANGEMTU" },\
123 {(NETDEV_CHANGEADDR), "NETDEV_CHANGEADDR" },\
124 {(NETDEV_UNREGISTER), "NETDEV_UNREGISTER" },\
125 {(NETDEV_CHANGENAME), "NETDEV_CHANGENAME" })
127 extern unsigned long sysctl_tipc_sk_filter
[5] __read_mostly
;
129 int tipc_skb_dump(struct sk_buff
*skb
, bool more
, char *buf
);
130 int tipc_list_dump(struct sk_buff_head
*list
, bool more
, char *buf
);
131 int tipc_sk_dump(struct sock
*sk
, u16 dqueues
, char *buf
);
132 int tipc_link_dump(struct tipc_link
*l
, u16 dqueues
, char *buf
);
133 int tipc_node_dump(struct tipc_node
*n
, bool more
, char *buf
);
134 bool tipc_sk_filtering(struct sock
*sk
);
136 DECLARE_EVENT_CLASS(tipc_skb_class
,
138 TP_PROTO(struct sk_buff
*skb
, bool more
, const char *header
),
140 TP_ARGS(skb
, more
, header
),
143 __string(header
, header
)
144 __dynamic_array(char, buf
, (more
) ? SKB_LMAX
: SKB_LMIN
)
148 __assign_str(header
, header
);
149 tipc_skb_dump(skb
, more
, __get_str(buf
));
152 TP_printk("%s\n%s", __get_str(header
), __get_str(buf
))
155 #define DEFINE_SKB_EVENT(name) \
156 DEFINE_EVENT(tipc_skb_class, name, \
157 TP_PROTO(struct sk_buff *skb, bool more, const char *header), \
158 TP_ARGS(skb, more, header))
159 DEFINE_SKB_EVENT(tipc_skb_dump
);
160 DEFINE_SKB_EVENT(tipc_proto_build
);
161 DEFINE_SKB_EVENT(tipc_proto_rcv
);
163 DECLARE_EVENT_CLASS(tipc_list_class
,
165 TP_PROTO(struct sk_buff_head
*list
, bool more
, const char *header
),
167 TP_ARGS(list
, more
, header
),
170 __string(header
, header
)
171 __dynamic_array(char, buf
, (more
) ? LIST_LMAX
: LIST_LMIN
)
175 __assign_str(header
, header
);
176 tipc_list_dump(list
, more
, __get_str(buf
));
179 TP_printk("%s\n%s", __get_str(header
), __get_str(buf
))
182 #define DEFINE_LIST_EVENT(name) \
183 DEFINE_EVENT(tipc_list_class, name, \
184 TP_PROTO(struct sk_buff_head *list, bool more, const char *header), \
185 TP_ARGS(list, more, header))
186 DEFINE_LIST_EVENT(tipc_list_dump
);
188 DECLARE_EVENT_CLASS(tipc_sk_class
,
190 TP_PROTO(struct sock
*sk
, struct sk_buff
*skb
, u16 dqueues
,
193 TP_ARGS(sk
, skb
, dqueues
, header
),
196 __string(header
, header
)
198 __dynamic_array(char, buf
, (dqueues
) ? SK_LMAX
: SK_LMIN
)
199 __dynamic_array(char, skb_buf
, (skb
) ? SKB_LMIN
: 1)
203 __assign_str(header
, header
);
204 __entry
->portid
= tipc_sock_get_portid(sk
);
205 tipc_sk_dump(sk
, dqueues
, __get_str(buf
));
207 tipc_skb_dump(skb
, false, __get_str(skb_buf
));
209 *(__get_str(skb_buf
)) = '\0';
212 TP_printk("<%u> %s\n%s%s", __entry
->portid
, __get_str(header
),
213 __get_str(skb_buf
), __get_str(buf
))
216 #define DEFINE_SK_EVENT_FILTER(name) \
217 DEFINE_EVENT_CONDITION(tipc_sk_class, name, \
218 TP_PROTO(struct sock *sk, struct sk_buff *skb, u16 dqueues, \
219 const char *header), \
220 TP_ARGS(sk, skb, dqueues, header), \
221 TP_CONDITION(tipc_sk_filtering(sk)))
222 DEFINE_SK_EVENT_FILTER(tipc_sk_dump
);
223 DEFINE_SK_EVENT_FILTER(tipc_sk_create
);
224 DEFINE_SK_EVENT_FILTER(tipc_sk_sendmcast
);
225 DEFINE_SK_EVENT_FILTER(tipc_sk_sendmsg
);
226 DEFINE_SK_EVENT_FILTER(tipc_sk_sendstream
);
227 DEFINE_SK_EVENT_FILTER(tipc_sk_poll
);
228 DEFINE_SK_EVENT_FILTER(tipc_sk_filter_rcv
);
229 DEFINE_SK_EVENT_FILTER(tipc_sk_advance_rx
);
230 DEFINE_SK_EVENT_FILTER(tipc_sk_rej_msg
);
231 DEFINE_SK_EVENT_FILTER(tipc_sk_drop_msg
);
232 DEFINE_SK_EVENT_FILTER(tipc_sk_release
);
233 DEFINE_SK_EVENT_FILTER(tipc_sk_shutdown
);
235 #define DEFINE_SK_EVENT_FILTER_COND(name, cond) \
236 DEFINE_EVENT_CONDITION(tipc_sk_class, name, \
237 TP_PROTO(struct sock *sk, struct sk_buff *skb, u16 dqueues, \
238 const char *header), \
239 TP_ARGS(sk, skb, dqueues, header), \
240 TP_CONDITION(tipc_sk_filtering(sk) && (cond)))
241 DEFINE_SK_EVENT_FILTER_COND(tipc_sk_overlimit1
, tipc_sk_overlimit1(sk
, skb
));
242 DEFINE_SK_EVENT_FILTER_COND(tipc_sk_overlimit2
, tipc_sk_overlimit2(sk
, skb
));
244 DECLARE_EVENT_CLASS(tipc_link_class
,
246 TP_PROTO(struct tipc_link
*l
, u16 dqueues
, const char *header
),
248 TP_ARGS(l
, dqueues
, header
),
251 __string(header
, header
)
252 __array(char, name
, TIPC_MAX_LINK_NAME
)
253 __dynamic_array(char, buf
, (dqueues
) ? LINK_LMAX
: LINK_LMIN
)
257 __assign_str(header
, header
);
258 memcpy(__entry
->name
, tipc_link_name(l
), TIPC_MAX_LINK_NAME
);
259 tipc_link_dump(l
, dqueues
, __get_str(buf
));
262 TP_printk("<%s> %s\n%s", __entry
->name
, __get_str(header
),
266 #define DEFINE_LINK_EVENT(name) \
267 DEFINE_EVENT(tipc_link_class, name, \
268 TP_PROTO(struct tipc_link *l, u16 dqueues, const char *header), \
269 TP_ARGS(l, dqueues, header))
270 DEFINE_LINK_EVENT(tipc_link_dump
);
271 DEFINE_LINK_EVENT(tipc_link_conges
);
272 DEFINE_LINK_EVENT(tipc_link_timeout
);
273 DEFINE_LINK_EVENT(tipc_link_reset
);
275 #define DEFINE_LINK_EVENT_COND(name, cond) \
276 DEFINE_EVENT_CONDITION(tipc_link_class, name, \
277 TP_PROTO(struct tipc_link *l, u16 dqueues, const char *header), \
278 TP_ARGS(l, dqueues, header), \
280 DEFINE_LINK_EVENT_COND(tipc_link_too_silent
, tipc_link_too_silent(l
));
282 DECLARE_EVENT_CLASS(tipc_link_transmq_class
,
284 TP_PROTO(struct tipc_link
*r
, u16 f
, u16 t
, struct sk_buff_head
*tq
),
286 TP_ARGS(r
, f
, t
, tq
),
289 __array(char, name
, TIPC_MAX_LINK_NAME
)
298 memcpy(__entry
->name
, tipc_link_name(r
), TIPC_MAX_LINK_NAME
);
301 __entry
->len
= skb_queue_len(tq
);
302 __entry
->fseqno
= __entry
->len
?
303 msg_seqno(buf_msg(skb_peek(tq
))) : 0;
304 __entry
->lseqno
= __entry
->len
?
305 msg_seqno(buf_msg(skb_peek_tail(tq
))) : 0;
308 TP_printk("<%s> retrans req: [%u-%u] transmq: %u [%u-%u]\n",
309 __entry
->name
, __entry
->from
, __entry
->to
,
310 __entry
->len
, __entry
->fseqno
, __entry
->lseqno
)
313 DEFINE_EVENT_CONDITION(tipc_link_transmq_class
, tipc_link_retrans
,
314 TP_PROTO(struct tipc_link
*r
, u16 f
, u16 t
, struct sk_buff_head
*tq
),
315 TP_ARGS(r
, f
, t
, tq
),
316 TP_CONDITION(less_eq(f
, t
))
319 DEFINE_EVENT_PRINT(tipc_link_transmq_class
, tipc_link_bc_ack
,
320 TP_PROTO(struct tipc_link
*r
, u16 f
, u16 t
, struct sk_buff_head
*tq
),
321 TP_ARGS(r
, f
, t
, tq
),
322 TP_printk("<%s> acked: %u gap: %u transmq: %u [%u-%u]\n",
323 __entry
->name
, __entry
->from
, __entry
->to
,
324 __entry
->len
, __entry
->fseqno
, __entry
->lseqno
)
327 DECLARE_EVENT_CLASS(tipc_node_class
,
329 TP_PROTO(struct tipc_node
*n
, bool more
, const char *header
),
331 TP_ARGS(n
, more
, header
),
334 __string(header
, header
)
336 __dynamic_array(char, buf
, (more
) ? NODE_LMAX
: NODE_LMIN
)
340 __assign_str(header
, header
);
341 __entry
->addr
= tipc_node_get_addr(n
);
342 tipc_node_dump(n
, more
, __get_str(buf
));
345 TP_printk("<%x> %s\n%s", __entry
->addr
, __get_str(header
),
349 #define DEFINE_NODE_EVENT(name) \
350 DEFINE_EVENT(tipc_node_class, name, \
351 TP_PROTO(struct tipc_node *n, bool more, const char *header), \
352 TP_ARGS(n, more, header))
353 DEFINE_NODE_EVENT(tipc_node_dump
);
354 DEFINE_NODE_EVENT(tipc_node_create
);
355 DEFINE_NODE_EVENT(tipc_node_delete
);
356 DEFINE_NODE_EVENT(tipc_node_lost_contact
);
357 DEFINE_NODE_EVENT(tipc_node_timeout
);
358 DEFINE_NODE_EVENT(tipc_node_link_up
);
359 DEFINE_NODE_EVENT(tipc_node_link_down
);
360 DEFINE_NODE_EVENT(tipc_node_reset_links
);
361 DEFINE_NODE_EVENT(tipc_node_check_state
);
363 DECLARE_EVENT_CLASS(tipc_fsm_class
,
365 TP_PROTO(const char *name
, u32 os
, u32 ns
, int evt
),
367 TP_ARGS(name
, os
, ns
, evt
),
377 __assign_str(name
, name
);
383 TP_printk("<%s> %s--(%s)->%s\n", __get_str(name
),
384 state_sym(__entry
->os
), evt_sym(__entry
->evt
),
385 state_sym(__entry
->ns
))
388 #define DEFINE_FSM_EVENT(fsm_name) \
389 DEFINE_EVENT(tipc_fsm_class, fsm_name, \
390 TP_PROTO(const char *name, u32 os, u32 ns, int evt), \
391 TP_ARGS(name, os, ns, evt))
392 DEFINE_FSM_EVENT(tipc_link_fsm
);
393 DEFINE_FSM_EVENT(tipc_node_fsm
);
395 TRACE_EVENT(tipc_l2_device_event
,
397 TP_PROTO(struct net_device
*dev
, struct tipc_bearer
*b
,
400 TP_ARGS(dev
, b
, evt
),
403 __string(dev_name
, dev
->name
)
404 __string(b_name
, b
->name
)
405 __field(unsigned long, evt
)
412 __assign_str(dev_name
, dev
->name
);
413 __assign_str(b_name
, b
->name
);
415 __entry
->b_up
= test_bit(0, &b
->up
);
416 __entry
->carrier
= netif_carrier_ok(dev
);
417 __entry
->oper
= netif_oper_up(dev
);
420 TP_printk("%s on: <%s>/<%s> oper: %s carrier: %s bearer: %s\n",
421 dev_evt_sym(__entry
->evt
), __get_str(dev_name
),
422 __get_str(b_name
), (__entry
->oper
) ? "up" : "down",
423 (__entry
->carrier
) ? "ok" : "notok",
424 (__entry
->b_up
) ? "up" : "down")
427 #endif /* _TIPC_TRACE_H */
429 /* This part must be outside protection */
430 #undef TRACE_INCLUDE_PATH
431 #define TRACE_INCLUDE_PATH .
432 #undef TRACE_INCLUDE_FILE
433 #define TRACE_INCLUDE_FILE trace
434 #include <trace/define_trace.h>