| /* 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> |