linux/net/smc/smc_tracepoint.h
Tony Lu a3a0e81b6f net/smc: Introduce tracepoint for smcr link down
SMC-R link down event is important to help us find links' issues, we
should track this event, especially in the single nic mode, which means
upper layer connection would be shut down. Then find out the direct
link-down reason in time, not only increased the counter, also the
location of the code who triggered this event.

Signed-off-by: Tony Lu <tonylu@linux.alibaba.com>
Reviewed-by: Wen Gu <guwen@linux.alibaba.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2021-11-01 13:39:14 +00:00

117 lines
2.5 KiB
C

/* SPDX-License-Identifier: GPL-2.0 */
#undef TRACE_SYSTEM
#define TRACE_SYSTEM smc
#if !defined(_TRACE_SMC_H) || defined(TRACE_HEADER_MULTI_READ)
#define _TRACE_SMC_H
#include <linux/ipv6.h>
#include <linux/tcp.h>
#include <linux/tracepoint.h>
#include <net/ipv6.h>
#include "smc.h"
#include "smc_core.h"
TRACE_EVENT(smc_switch_to_fallback,
TP_PROTO(const struct smc_sock *smc, int fallback_rsn),
TP_ARGS(smc, fallback_rsn),
TP_STRUCT__entry(
__field(const void *, sk)
__field(const void *, clcsk)
__field(int, fallback_rsn)
),
TP_fast_assign(
const struct sock *sk = &smc->sk;
const struct sock *clcsk = smc->clcsock->sk;
__entry->sk = sk;
__entry->clcsk = clcsk;
__entry->fallback_rsn = fallback_rsn;
),
TP_printk("sk=%p clcsk=%p fallback_rsn=%d",
__entry->sk, __entry->clcsk, __entry->fallback_rsn)
);
DECLARE_EVENT_CLASS(smc_msg_event,
TP_PROTO(const struct smc_sock *smc, size_t len),
TP_ARGS(smc, len),
TP_STRUCT__entry(
__field(const void *, smc)
__field(size_t, len)
__string(name, smc->conn.lnk->ibname)
),
TP_fast_assign(
__entry->smc = smc;
__entry->len = len;
__assign_str(name, smc->conn.lnk->ibname);
),
TP_printk("smc=%p len=%zu dev=%s",
__entry->smc, __entry->len,
__get_str(name))
);
DEFINE_EVENT(smc_msg_event, smc_tx_sendmsg,
TP_PROTO(const struct smc_sock *smc, size_t len),
TP_ARGS(smc, len)
);
DEFINE_EVENT(smc_msg_event, smc_rx_recvmsg,
TP_PROTO(const struct smc_sock *smc, size_t len),
TP_ARGS(smc, len)
);
TRACE_EVENT(smcr_link_down,
TP_PROTO(const struct smc_link *lnk, void *location),
TP_ARGS(lnk, location),
TP_STRUCT__entry(
__field(const void *, lnk)
__field(const void *, lgr)
__field(int, state)
__string(name, lnk->ibname)
__field(void *, location)
),
TP_fast_assign(
const struct smc_link_group *lgr = lnk->lgr;
__entry->lnk = lnk;
__entry->lgr = lgr;
__entry->state = lnk->state;
__assign_str(name, lnk->ibname);
__entry->location = location;
),
TP_printk("lnk=%p lgr=%p state=%d dev=%s location=%p",
__entry->lnk, __entry->lgr,
__entry->state, __get_str(name),
__entry->location)
);
#endif /* _TRACE_SMC_H */
#undef TRACE_INCLUDE_PATH
#define TRACE_INCLUDE_PATH .
#undef TRACE_INCLUDE_FILE
#define TRACE_INCLUDE_FILE smc_tracepoint
#include <trace/define_trace.h>