Skip to content

Commit d87d04a

Browse files
Ben Hutchingsdavem330
authored andcommitted
net: Add net_dev_start_xmit trace event, exposing more skb fields
The existing net/net_dev_xmit trace event provides little information about the skb that has been passed to the driver, and it is not simple to add more since the skb may already have been freed at the point the event is emitted. Add a separate trace event before the skb is passed to the driver, including most fields that are likely to be interesting for debugging driver datapath behaviour. Signed-off-by: Ben Hutchings <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 2056766 commit d87d04a

File tree

2 files changed

+60
-0
lines changed

2 files changed

+60
-0
lines changed

include/trace/events/net.h

Lines changed: 58 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -6,9 +6,67 @@
66

77
#include <linux/skbuff.h>
88
#include <linux/netdevice.h>
9+
#include <linux/if_vlan.h>
910
#include <linux/ip.h>
1011
#include <linux/tracepoint.h>
1112

13+
TRACE_EVENT(net_dev_start_xmit,
14+
15+
TP_PROTO(const struct sk_buff *skb, const struct net_device *dev),
16+
17+
TP_ARGS(skb, dev),
18+
19+
TP_STRUCT__entry(
20+
__string( name, dev->name )
21+
__field( u16, queue_mapping )
22+
__field( const void *, skbaddr )
23+
__field( bool, vlan_tagged )
24+
__field( u16, vlan_proto )
25+
__field( u16, vlan_tci )
26+
__field( u16, protocol )
27+
__field( u8, ip_summed )
28+
__field( unsigned int, len )
29+
__field( unsigned int, data_len )
30+
__field( int, network_offset )
31+
__field( bool, transport_offset_valid)
32+
__field( int, transport_offset)
33+
__field( u8, tx_flags )
34+
__field( u16, gso_size )
35+
__field( u16, gso_segs )
36+
__field( u16, gso_type )
37+
),
38+
39+
TP_fast_assign(
40+
__assign_str(name, dev->name);
41+
__entry->queue_mapping = skb->queue_mapping;
42+
__entry->skbaddr = skb;
43+
__entry->vlan_tagged = vlan_tx_tag_present(skb);
44+
__entry->vlan_proto = ntohs(skb->vlan_proto);
45+
__entry->vlan_tci = vlan_tx_tag_get(skb);
46+
__entry->protocol = ntohs(skb->protocol);
47+
__entry->ip_summed = skb->ip_summed;
48+
__entry->len = skb->len;
49+
__entry->data_len = skb->data_len;
50+
__entry->network_offset = skb_network_offset(skb);
51+
__entry->transport_offset_valid =
52+
skb_transport_header_was_set(skb);
53+
__entry->transport_offset = skb_transport_offset(skb);
54+
__entry->tx_flags = skb_shinfo(skb)->tx_flags;
55+
__entry->gso_size = skb_shinfo(skb)->gso_size;
56+
__entry->gso_segs = skb_shinfo(skb)->gso_segs;
57+
__entry->gso_type = skb_shinfo(skb)->gso_type;
58+
),
59+
60+
TP_printk("dev=%s queue_mapping=%u skbaddr=%p vlan_tagged=%d vlan_proto=0x%04x vlan_tci=0x%04x protocol=0x%04x ip_summed=%d len=%u data_len=%u network_offset=%d transport_offset_valid=%d transport_offset=%d tx_flags=%d gso_size=%d gso_segs=%d gso_type=%#x",
61+
__get_str(name), __entry->queue_mapping, __entry->skbaddr,
62+
__entry->vlan_tagged, __entry->vlan_proto, __entry->vlan_tci,
63+
__entry->protocol, __entry->ip_summed, __entry->len,
64+
__entry->data_len,
65+
__entry->network_offset, __entry->transport_offset_valid,
66+
__entry->transport_offset, __entry->tx_flags,
67+
__entry->gso_size, __entry->gso_segs, __entry->gso_type)
68+
);
69+
1270
TRACE_EVENT(net_dev_xmit,
1371

1472
TP_PROTO(struct sk_buff *skb,

net/core/dev.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2596,6 +2596,7 @@ int dev_hard_start_xmit(struct sk_buff *skb, struct net_device *dev,
25962596
dev_queue_xmit_nit(skb, dev);
25972597

25982598
skb_len = skb->len;
2599+
trace_net_dev_start_xmit(skb, dev);
25992600
rc = ops->ndo_start_xmit(skb, dev);
26002601
trace_net_dev_xmit(skb, rc, dev, skb_len);
26012602
if (rc == NETDEV_TX_OK)
@@ -2614,6 +2615,7 @@ int dev_hard_start_xmit(struct sk_buff *skb, struct net_device *dev,
26142615
dev_queue_xmit_nit(nskb, dev);
26152616

26162617
skb_len = nskb->len;
2618+
trace_net_dev_start_xmit(nskb, dev);
26172619
rc = ops->ndo_start_xmit(nskb, dev);
26182620
trace_net_dev_xmit(nskb, rc, dev, skb_len);
26192621
if (unlikely(rc != NETDEV_TX_OK)) {

0 commit comments

Comments
 (0)