142 lines
3.7 KiB
C
142 lines
3.7 KiB
C
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||
|
/*
|
||
|
* Tracepoints for Thunderbolt/USB4 networking driver
|
||
|
*
|
||
|
* Copyright (C) 2023, Intel Corporation
|
||
|
* Author: Mika Westerberg <mika.westerberg@linux.intel.com>
|
||
|
*/
|
||
|
|
||
|
#undef TRACE_SYSTEM
|
||
|
#define TRACE_SYSTEM thunderbolt_net
|
||
|
|
||
|
#if !defined(__TRACE_THUNDERBOLT_NET_H) || defined(TRACE_HEADER_MULTI_READ)
|
||
|
#define __TRACE_THUNDERBOLT_NET_H
|
||
|
|
||
|
#include <linux/dma-direction.h>
|
||
|
#include <linux/skbuff.h>
|
||
|
#include <linux/tracepoint.h>
|
||
|
|
||
|
#define DMA_DATA_DIRECTION_NAMES \
|
||
|
{ DMA_BIDIRECTIONAL, "DMA_BIDIRECTIONAL" }, \
|
||
|
{ DMA_TO_DEVICE, "DMA_TO_DEVICE" }, \
|
||
|
{ DMA_FROM_DEVICE, "DMA_FROM_DEVICE" }, \
|
||
|
{ DMA_NONE, "DMA_NONE" }
|
||
|
|
||
|
DECLARE_EVENT_CLASS(tbnet_frame,
|
||
|
TP_PROTO(unsigned int index, const void *page, dma_addr_t phys,
|
||
|
enum dma_data_direction dir),
|
||
|
TP_ARGS(index, page, phys, dir),
|
||
|
TP_STRUCT__entry(
|
||
|
__field(unsigned int, index)
|
||
|
__field(const void *, page)
|
||
|
__field(dma_addr_t, phys)
|
||
|
__field(enum dma_data_direction, dir)
|
||
|
),
|
||
|
TP_fast_assign(
|
||
|
__entry->index = index;
|
||
|
__entry->page = page;
|
||
|
__entry->phys = phys;
|
||
|
__entry->dir = dir;
|
||
|
),
|
||
|
TP_printk("index=%u page=%p phys=%pad dir=%s",
|
||
|
__entry->index, __entry->page, &__entry->phys,
|
||
|
__print_symbolic(__entry->dir, DMA_DATA_DIRECTION_NAMES))
|
||
|
);
|
||
|
|
||
|
DEFINE_EVENT(tbnet_frame, tbnet_alloc_rx_frame,
|
||
|
TP_PROTO(unsigned int index, const void *page, dma_addr_t phys,
|
||
|
enum dma_data_direction dir),
|
||
|
TP_ARGS(index, page, phys, dir)
|
||
|
);
|
||
|
|
||
|
DEFINE_EVENT(tbnet_frame, tbnet_alloc_tx_frame,
|
||
|
TP_PROTO(unsigned int index, const void *page, dma_addr_t phys,
|
||
|
enum dma_data_direction dir),
|
||
|
TP_ARGS(index, page, phys, dir)
|
||
|
);
|
||
|
|
||
|
DEFINE_EVENT(tbnet_frame, tbnet_free_frame,
|
||
|
TP_PROTO(unsigned int index, const void *page, dma_addr_t phys,
|
||
|
enum dma_data_direction dir),
|
||
|
TP_ARGS(index, page, phys, dir)
|
||
|
);
|
||
|
|
||
|
DECLARE_EVENT_CLASS(tbnet_ip_frame,
|
||
|
TP_PROTO(__le32 size, __le16 id, __le16 index, __le32 count),
|
||
|
TP_ARGS(size, id, index, count),
|
||
|
TP_STRUCT__entry(
|
||
|
__field(u32, size)
|
||
|
__field(u16, id)
|
||
|
__field(u16, index)
|
||
|
__field(u32, count)
|
||
|
),
|
||
|
TP_fast_assign(
|
||
|
__entry->size = le32_to_cpu(size);
|
||
|
__entry->id = le16_to_cpu(id);
|
||
|
__entry->index = le16_to_cpu(index);
|
||
|
__entry->count = le32_to_cpu(count);
|
||
|
),
|
||
|
TP_printk("id=%u size=%u index=%u count=%u",
|
||
|
__entry->id, __entry->size, __entry->index, __entry->count)
|
||
|
);
|
||
|
|
||
|
DEFINE_EVENT(tbnet_ip_frame, tbnet_rx_ip_frame,
|
||
|
TP_PROTO(__le32 size, __le16 id, __le16 index, __le32 count),
|
||
|
TP_ARGS(size, id, index, count)
|
||
|
);
|
||
|
|
||
|
DEFINE_EVENT(tbnet_ip_frame, tbnet_invalid_rx_ip_frame,
|
||
|
TP_PROTO(__le32 size, __le16 id, __le16 index, __le32 count),
|
||
|
TP_ARGS(size, id, index, count)
|
||
|
);
|
||
|
|
||
|
DEFINE_EVENT(tbnet_ip_frame, tbnet_tx_ip_frame,
|
||
|
TP_PROTO(__le32 size, __le16 id, __le16 index, __le32 count),
|
||
|
TP_ARGS(size, id, index, count)
|
||
|
);
|
||
|
|
||
|
DECLARE_EVENT_CLASS(tbnet_skb,
|
||
|
TP_PROTO(const struct sk_buff *skb),
|
||
|
TP_ARGS(skb),
|
||
|
TP_STRUCT__entry(
|
||
|
__field(const void *, addr)
|
||
|
__field(unsigned int, len)
|
||
|
__field(unsigned int, data_len)
|
||
|
__field(unsigned int, nr_frags)
|
||
|
),
|
||
|
TP_fast_assign(
|
||
|
__entry->addr = skb;
|
||
|
__entry->len = skb->len;
|
||
|
__entry->data_len = skb->data_len;
|
||
|
__entry->nr_frags = skb_shinfo(skb)->nr_frags;
|
||
|
),
|
||
|
TP_printk("skb=%p len=%u data_len=%u nr_frags=%u",
|
||
|
__entry->addr, __entry->len, __entry->data_len,
|
||
|
__entry->nr_frags)
|
||
|
);
|
||
|
|
||
|
DEFINE_EVENT(tbnet_skb, tbnet_rx_skb,
|
||
|
TP_PROTO(const struct sk_buff *skb),
|
||
|
TP_ARGS(skb)
|
||
|
);
|
||
|
|
||
|
DEFINE_EVENT(tbnet_skb, tbnet_tx_skb,
|
||
|
TP_PROTO(const struct sk_buff *skb),
|
||
|
TP_ARGS(skb)
|
||
|
);
|
||
|
|
||
|
DEFINE_EVENT(tbnet_skb, tbnet_consume_skb,
|
||
|
TP_PROTO(const struct sk_buff *skb),
|
||
|
TP_ARGS(skb)
|
||
|
);
|
||
|
|
||
|
#endif /* _TRACE_THUNDERBOLT_NET_H */
|
||
|
|
||
|
#undef TRACE_INCLUDE_PATH
|
||
|
#define TRACE_INCLUDE_PATH .
|
||
|
|
||
|
#undef TRACE_INCLUDE_FILE
|
||
|
#define TRACE_INCLUDE_FILE trace
|
||
|
|
||
|
#include <trace/define_trace.h>
|