2 #define TRACE_SYSTEM qdisc
4 #if !defined(_TRACE_QDISC_H) || defined(TRACE_HEADER_MULTI_READ)
7 #include <linux/skbuff.h>
8 #include <linux/netdevice.h>
9 #include <linux/tracepoint.h>
10 #include <linux/ftrace.h>
11 #include <linux/pkt_sched.h>
12 #include <net/sch_generic.h>
14 TRACE_EVENT(qdisc_dequeue
,
16 TP_PROTO(struct Qdisc
*qdisc
, const struct netdev_queue
*txq
,
17 int packets
, struct sk_buff
*skb
),
19 TP_ARGS(qdisc
, txq
, packets
, skb
),
22 __field( struct Qdisc
*, qdisc
)
23 __field(const struct netdev_queue
*, txq
)
24 __field( int, packets
)
25 __field( void *, skbaddr
)
26 __field( int, ifindex
)
27 __field( u32
, handle
)
28 __field( u32
, parent
)
29 __field( unsigned long, txq_state
)
32 /* skb==NULL indicate packets dequeued was 0, even when packets==1 */
34 __entry
->qdisc
= qdisc
;
36 __entry
->packets
= skb
? packets
: 0;
37 __entry
->skbaddr
= skb
;
38 __entry
->ifindex
= txq
->dev
? txq
->dev
->ifindex
: 0;
39 __entry
->handle
= qdisc
->handle
;
40 __entry
->parent
= qdisc
->parent
;
41 __entry
->txq_state
= txq
->state
;
44 TP_printk("dequeue ifindex=%d qdisc handle=0x%X parent=0x%X txq_state=0x%lX packets=%d skbaddr=%p",
45 __entry
->ifindex
, __entry
->handle
, __entry
->parent
,
46 __entry
->txq_state
, __entry
->packets
, __entry
->skbaddr
)
49 TRACE_EVENT(qdisc_enqueue
,
51 TP_PROTO(struct Qdisc
*qdisc
, const struct netdev_queue
*txq
, struct sk_buff
*skb
),
53 TP_ARGS(qdisc
, txq
, skb
),
56 __field(struct Qdisc
*, qdisc
)
57 __field(const struct netdev_queue
*, txq
)
58 __field(void *, skbaddr
)
65 __entry
->qdisc
= qdisc
;
67 __entry
->skbaddr
= skb
;
68 __entry
->ifindex
= txq
->dev
? txq
->dev
->ifindex
: 0;
69 __entry
->handle
= qdisc
->handle
;
70 __entry
->parent
= qdisc
->parent
;
73 TP_printk("enqueue ifindex=%d qdisc handle=0x%X parent=0x%X skbaddr=%p",
74 __entry
->ifindex
, __entry
->handle
, __entry
->parent
, __entry
->skbaddr
)
77 TRACE_EVENT(qdisc_reset
,
79 TP_PROTO(struct Qdisc
*q
),
84 __string( dev
, qdisc_dev(q
) ? qdisc_dev(q
)->name
: "(null)" )
85 __string( kind
, q
->ops
->id
)
86 __field( u32
, parent
)
87 __field( u32
, handle
)
93 __entry
->parent
= q
->parent
;
94 __entry
->handle
= q
->handle
;
97 TP_printk("dev=%s kind=%s parent=%x:%x handle=%x:%x", __get_str(dev
),
98 __get_str(kind
), TC_H_MAJ(__entry
->parent
) >> 16, TC_H_MIN(__entry
->parent
),
99 TC_H_MAJ(__entry
->handle
) >> 16, TC_H_MIN(__entry
->handle
))
102 TRACE_EVENT(qdisc_destroy
,
104 TP_PROTO(struct Qdisc
*q
),
109 __string( dev
, qdisc_dev(q
)->name
)
110 __string( kind
, q
->ops
->id
)
111 __field( u32
, parent
)
112 __field( u32
, handle
)
118 __entry
->parent
= q
->parent
;
119 __entry
->handle
= q
->handle
;
122 TP_printk("dev=%s kind=%s parent=%x:%x handle=%x:%x", __get_str(dev
),
123 __get_str(kind
), TC_H_MAJ(__entry
->parent
) >> 16, TC_H_MIN(__entry
->parent
),
124 TC_H_MAJ(__entry
->handle
) >> 16, TC_H_MIN(__entry
->handle
))
127 TRACE_EVENT(qdisc_create
,
129 TP_PROTO(const struct Qdisc_ops
*ops
, struct net_device
*dev
, u32 parent
),
131 TP_ARGS(ops
, dev
, parent
),
134 __string( dev
, dev
->name
)
135 __string( kind
, ops
->id
)
136 __field( u32
, parent
)
142 __entry
->parent
= parent
;
145 TP_printk("dev=%s kind=%s parent=%x:%x",
146 __get_str(dev
), __get_str(kind
),
147 TC_H_MAJ(__entry
->parent
) >> 16, TC_H_MIN(__entry
->parent
))
150 #endif /* _TRACE_QDISC_H */
152 /* This part must be outside protection */
153 #include <trace/define_trace.h>