123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211 |
- /* SPDX-License-Identifier: GPL-2.0-only */
- #undef TRACE_SYSTEM
- #define TRACE_SYSTEM l2tp
- #if !defined(_TRACE_L2TP_H) || defined(TRACE_HEADER_MULTI_READ)
- #define _TRACE_L2TP_H
- #include <linux/tracepoint.h>
- #include <linux/l2tp.h>
- #include "l2tp_core.h"
- #define encap_type_name(e) { L2TP_ENCAPTYPE_##e, #e }
- #define show_encap_type_name(val) \
- __print_symbolic(val, \
- encap_type_name(UDP), \
- encap_type_name(IP))
- #define pw_type_name(p) { L2TP_PWTYPE_##p, #p }
- #define show_pw_type_name(val) \
- __print_symbolic(val, \
- pw_type_name(ETH_VLAN), \
- pw_type_name(ETH), \
- pw_type_name(PPP), \
- pw_type_name(PPP_AC), \
- pw_type_name(IP))
- DECLARE_EVENT_CLASS(tunnel_only_evt,
- TP_PROTO(struct l2tp_tunnel *tunnel),
- TP_ARGS(tunnel),
- TP_STRUCT__entry(
- __array(char, name, L2TP_TUNNEL_NAME_MAX)
- ),
- TP_fast_assign(
- memcpy(__entry->name, tunnel->name, L2TP_TUNNEL_NAME_MAX);
- ),
- TP_printk("%s", __entry->name)
- );
- DECLARE_EVENT_CLASS(session_only_evt,
- TP_PROTO(struct l2tp_session *session),
- TP_ARGS(session),
- TP_STRUCT__entry(
- __array(char, name, L2TP_SESSION_NAME_MAX)
- ),
- TP_fast_assign(
- memcpy(__entry->name, session->name, L2TP_SESSION_NAME_MAX);
- ),
- TP_printk("%s", __entry->name)
- );
- TRACE_EVENT(register_tunnel,
- TP_PROTO(struct l2tp_tunnel *tunnel),
- TP_ARGS(tunnel),
- TP_STRUCT__entry(
- __array(char, name, L2TP_TUNNEL_NAME_MAX)
- __field(int, fd)
- __field(u32, tid)
- __field(u32, ptid)
- __field(int, version)
- __field(enum l2tp_encap_type, encap)
- ),
- TP_fast_assign(
- memcpy(__entry->name, tunnel->name, L2TP_TUNNEL_NAME_MAX);
- __entry->fd = tunnel->fd;
- __entry->tid = tunnel->tunnel_id;
- __entry->ptid = tunnel->peer_tunnel_id;
- __entry->version = tunnel->version;
- __entry->encap = tunnel->encap;
- ),
- TP_printk("%s: type=%s encap=%s version=L2TPv%d tid=%u ptid=%u fd=%d",
- __entry->name,
- __entry->fd > 0 ? "managed" : "unmanaged",
- show_encap_type_name(__entry->encap),
- __entry->version,
- __entry->tid,
- __entry->ptid,
- __entry->fd)
- );
- DEFINE_EVENT(tunnel_only_evt, delete_tunnel,
- TP_PROTO(struct l2tp_tunnel *tunnel),
- TP_ARGS(tunnel)
- );
- DEFINE_EVENT(tunnel_only_evt, free_tunnel,
- TP_PROTO(struct l2tp_tunnel *tunnel),
- TP_ARGS(tunnel)
- );
- TRACE_EVENT(register_session,
- TP_PROTO(struct l2tp_session *session),
- TP_ARGS(session),
- TP_STRUCT__entry(
- __array(char, name, L2TP_SESSION_NAME_MAX)
- __field(u32, tid)
- __field(u32, ptid)
- __field(u32, sid)
- __field(u32, psid)
- __field(enum l2tp_pwtype, pwtype)
- ),
- TP_fast_assign(
- memcpy(__entry->name, session->name, L2TP_SESSION_NAME_MAX);
- __entry->tid = session->tunnel ? session->tunnel->tunnel_id : 0;
- __entry->ptid = session->tunnel ? session->tunnel->peer_tunnel_id : 0;
- __entry->sid = session->session_id;
- __entry->psid = session->peer_session_id;
- __entry->pwtype = session->pwtype;
- ),
- TP_printk("%s: pseudowire=%s sid=%u psid=%u tid=%u ptid=%u",
- __entry->name,
- show_pw_type_name(__entry->pwtype),
- __entry->sid,
- __entry->psid,
- __entry->sid,
- __entry->psid)
- );
- DEFINE_EVENT(session_only_evt, delete_session,
- TP_PROTO(struct l2tp_session *session),
- TP_ARGS(session)
- );
- DEFINE_EVENT(session_only_evt, free_session,
- TP_PROTO(struct l2tp_session *session),
- TP_ARGS(session)
- );
- DEFINE_EVENT(session_only_evt, session_seqnum_lns_enable,
- TP_PROTO(struct l2tp_session *session),
- TP_ARGS(session)
- );
- DEFINE_EVENT(session_only_evt, session_seqnum_lns_disable,
- TP_PROTO(struct l2tp_session *session),
- TP_ARGS(session)
- );
- DECLARE_EVENT_CLASS(session_seqnum_evt,
- TP_PROTO(struct l2tp_session *session),
- TP_ARGS(session),
- TP_STRUCT__entry(
- __array(char, name, L2TP_SESSION_NAME_MAX)
- __field(u32, ns)
- __field(u32, nr)
- ),
- TP_fast_assign(
- memcpy(__entry->name, session->name, L2TP_SESSION_NAME_MAX);
- __entry->ns = session->ns;
- __entry->nr = session->nr;
- ),
- TP_printk("%s: ns=%u nr=%u",
- __entry->name,
- __entry->ns,
- __entry->nr)
- );
- DEFINE_EVENT(session_seqnum_evt, session_seqnum_update,
- TP_PROTO(struct l2tp_session *session),
- TP_ARGS(session)
- );
- DEFINE_EVENT(session_seqnum_evt, session_seqnum_reset,
- TP_PROTO(struct l2tp_session *session),
- TP_ARGS(session)
- );
- DECLARE_EVENT_CLASS(session_pkt_discard_evt,
- TP_PROTO(struct l2tp_session *session, u32 pkt_ns),
- TP_ARGS(session, pkt_ns),
- TP_STRUCT__entry(
- __array(char, name, L2TP_SESSION_NAME_MAX)
- __field(u32, pkt_ns)
- __field(u32, my_nr)
- __field(u32, reorder_q_len)
- ),
- TP_fast_assign(
- memcpy(__entry->name, session->name, L2TP_SESSION_NAME_MAX);
- __entry->pkt_ns = pkt_ns,
- __entry->my_nr = session->nr;
- __entry->reorder_q_len = skb_queue_len(&session->reorder_q);
- ),
- TP_printk("%s: pkt_ns=%u my_nr=%u reorder_q_len=%u",
- __entry->name,
- __entry->pkt_ns,
- __entry->my_nr,
- __entry->reorder_q_len)
- );
- DEFINE_EVENT(session_pkt_discard_evt, session_pkt_expired,
- TP_PROTO(struct l2tp_session *session, u32 pkt_ns),
- TP_ARGS(session, pkt_ns)
- );
- DEFINE_EVENT(session_pkt_discard_evt, session_pkt_outside_rx_window,
- TP_PROTO(struct l2tp_session *session, u32 pkt_ns),
- TP_ARGS(session, pkt_ns)
- );
- DEFINE_EVENT(session_pkt_discard_evt, session_pkt_oos,
- TP_PROTO(struct l2tp_session *session, u32 pkt_ns),
- TP_ARGS(session, pkt_ns)
- );
- #endif /* _TRACE_L2TP_H */
- /* This part must be outside protection */
- #undef TRACE_INCLUDE_PATH
- #define TRACE_INCLUDE_PATH .
- #undef TRACE_INCLUDE_FILE
- #define TRACE_INCLUDE_FILE trace
- #include <trace/define_trace.h>
|