Linux Audio

Check our new training course

Loading...
Note: File does not exist in v4.17.
  1/* SPDX-License-Identifier: GPL-2.0-only */
  2#undef TRACE_SYSTEM
  3#define TRACE_SYSTEM l2tp
  4
  5#if !defined(_TRACE_L2TP_H) || defined(TRACE_HEADER_MULTI_READ)
  6#define _TRACE_L2TP_H
  7
  8#include <linux/tracepoint.h>
  9#include <linux/l2tp.h>
 10#include "l2tp_core.h"
 11
 12#define encap_type_name(e) { L2TP_ENCAPTYPE_##e, #e }
 13#define show_encap_type_name(val) \
 14	__print_symbolic(val, \
 15			encap_type_name(UDP), \
 16			encap_type_name(IP))
 17
 18#define pw_type_name(p) { L2TP_PWTYPE_##p, #p }
 19#define show_pw_type_name(val) \
 20	__print_symbolic(val, \
 21	pw_type_name(ETH_VLAN), \
 22	pw_type_name(ETH), \
 23	pw_type_name(PPP), \
 24	pw_type_name(PPP_AC), \
 25	pw_type_name(IP))
 26
 27DECLARE_EVENT_CLASS(tunnel_only_evt,
 28	TP_PROTO(struct l2tp_tunnel *tunnel),
 29	TP_ARGS(tunnel),
 30	TP_STRUCT__entry(
 31		__array(char, name, L2TP_TUNNEL_NAME_MAX)
 32	),
 33	TP_fast_assign(
 34		memcpy(__entry->name, tunnel->name, L2TP_TUNNEL_NAME_MAX);
 35	),
 36	TP_printk("%s", __entry->name)
 37);
 38
 39DECLARE_EVENT_CLASS(session_only_evt,
 40	TP_PROTO(struct l2tp_session *session),
 41	TP_ARGS(session),
 42	TP_STRUCT__entry(
 43		__array(char, name, L2TP_SESSION_NAME_MAX)
 44	),
 45	TP_fast_assign(
 46		memcpy(__entry->name, session->name, L2TP_SESSION_NAME_MAX);
 47	),
 48	TP_printk("%s", __entry->name)
 49);
 50
 51TRACE_EVENT(register_tunnel,
 52	TP_PROTO(struct l2tp_tunnel *tunnel),
 53	TP_ARGS(tunnel),
 54	TP_STRUCT__entry(
 55		__array(char, name, L2TP_TUNNEL_NAME_MAX)
 56		__field(int, fd)
 57		__field(u32, tid)
 58		__field(u32, ptid)
 59		__field(int, version)
 60		__field(enum l2tp_encap_type, encap)
 61	),
 62	TP_fast_assign(
 63		memcpy(__entry->name, tunnel->name, L2TP_TUNNEL_NAME_MAX);
 64		__entry->fd = tunnel->fd;
 65		__entry->tid = tunnel->tunnel_id;
 66		__entry->ptid = tunnel->peer_tunnel_id;
 67		__entry->version = tunnel->version;
 68		__entry->encap = tunnel->encap;
 69	),
 70	TP_printk("%s: type=%s encap=%s version=L2TPv%d tid=%u ptid=%u fd=%d",
 71		__entry->name,
 72		__entry->fd > 0 ? "managed" : "unmanaged",
 73		show_encap_type_name(__entry->encap),
 74		__entry->version,
 75		__entry->tid,
 76		__entry->ptid,
 77		__entry->fd)
 78);
 79
 80DEFINE_EVENT(tunnel_only_evt, delete_tunnel,
 81	TP_PROTO(struct l2tp_tunnel *tunnel),
 82	TP_ARGS(tunnel)
 83);
 84
 85DEFINE_EVENT(tunnel_only_evt, free_tunnel,
 86	TP_PROTO(struct l2tp_tunnel *tunnel),
 87	TP_ARGS(tunnel)
 88);
 89
 90TRACE_EVENT(register_session,
 91	TP_PROTO(struct l2tp_session *session),
 92	TP_ARGS(session),
 93	TP_STRUCT__entry(
 94		__array(char, name, L2TP_SESSION_NAME_MAX)
 95		__field(u32, tid)
 96		__field(u32, ptid)
 97		__field(u32, sid)
 98		__field(u32, psid)
 99		__field(enum l2tp_pwtype, pwtype)
100	),
101	TP_fast_assign(
102		memcpy(__entry->name, session->name, L2TP_SESSION_NAME_MAX);
103		__entry->tid = session->tunnel ? session->tunnel->tunnel_id : 0;
104		__entry->ptid = session->tunnel ? session->tunnel->peer_tunnel_id : 0;
105		__entry->sid = session->session_id;
106		__entry->psid = session->peer_session_id;
107		__entry->pwtype = session->pwtype;
108	),
109	TP_printk("%s: pseudowire=%s sid=%u psid=%u tid=%u ptid=%u",
110		__entry->name,
111		show_pw_type_name(__entry->pwtype),
112		__entry->sid,
113		__entry->psid,
114		__entry->sid,
115		__entry->psid)
116);
117
118DEFINE_EVENT(session_only_evt, delete_session,
119	TP_PROTO(struct l2tp_session *session),
120	TP_ARGS(session)
121);
122
123DEFINE_EVENT(session_only_evt, free_session,
124	TP_PROTO(struct l2tp_session *session),
125	TP_ARGS(session)
126);
127
128DEFINE_EVENT(session_only_evt, session_seqnum_lns_enable,
129	TP_PROTO(struct l2tp_session *session),
130	TP_ARGS(session)
131);
132
133DEFINE_EVENT(session_only_evt, session_seqnum_lns_disable,
134	TP_PROTO(struct l2tp_session *session),
135	TP_ARGS(session)
136);
137
138DECLARE_EVENT_CLASS(session_seqnum_evt,
139	TP_PROTO(struct l2tp_session *session),
140	TP_ARGS(session),
141	TP_STRUCT__entry(
142		__array(char, name, L2TP_SESSION_NAME_MAX)
143		__field(u32, ns)
144		__field(u32, nr)
145	),
146	TP_fast_assign(
147		memcpy(__entry->name, session->name, L2TP_SESSION_NAME_MAX);
148		__entry->ns = session->ns;
149		__entry->nr = session->nr;
150	),
151	TP_printk("%s: ns=%u nr=%u",
152		__entry->name,
153		__entry->ns,
154		__entry->nr)
155);
156
157DEFINE_EVENT(session_seqnum_evt, session_seqnum_update,
158	TP_PROTO(struct l2tp_session *session),
159	TP_ARGS(session)
160);
161
162DEFINE_EVENT(session_seqnum_evt, session_seqnum_reset,
163	TP_PROTO(struct l2tp_session *session),
164	TP_ARGS(session)
165);
166
167DECLARE_EVENT_CLASS(session_pkt_discard_evt,
168	TP_PROTO(struct l2tp_session *session, u32 pkt_ns),
169	TP_ARGS(session, pkt_ns),
170	TP_STRUCT__entry(
171		__array(char, name, L2TP_SESSION_NAME_MAX)
172		__field(u32, pkt_ns)
173		__field(u32, my_nr)
174		__field(u32, reorder_q_len)
175	),
176	TP_fast_assign(
177		memcpy(__entry->name, session->name, L2TP_SESSION_NAME_MAX);
178		__entry->pkt_ns = pkt_ns,
179		__entry->my_nr = session->nr;
180		__entry->reorder_q_len = skb_queue_len(&session->reorder_q);
181	),
182	TP_printk("%s: pkt_ns=%u my_nr=%u reorder_q_len=%u",
183		__entry->name,
184		__entry->pkt_ns,
185		__entry->my_nr,
186		__entry->reorder_q_len)
187);
188
189DEFINE_EVENT(session_pkt_discard_evt, session_pkt_expired,
190	TP_PROTO(struct l2tp_session *session, u32 pkt_ns),
191	TP_ARGS(session, pkt_ns)
192);
193
194DEFINE_EVENT(session_pkt_discard_evt, session_pkt_outside_rx_window,
195	TP_PROTO(struct l2tp_session *session, u32 pkt_ns),
196	TP_ARGS(session, pkt_ns)
197);
198
199DEFINE_EVENT(session_pkt_discard_evt, session_pkt_oos,
200	TP_PROTO(struct l2tp_session *session, u32 pkt_ns),
201	TP_ARGS(session, pkt_ns)
202);
203
204#endif /* _TRACE_L2TP_H */
205
206/* This part must be outside protection */
207#undef TRACE_INCLUDE_PATH
208#define TRACE_INCLUDE_PATH .
209#undef TRACE_INCLUDE_FILE
210#define TRACE_INCLUDE_FILE trace
211#include <trace/define_trace.h>