skb.h 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #undef TRACE_SYSTEM
  3. #define TRACE_SYSTEM skb
  4. #if !defined(_TRACE_SKB_H) || defined(TRACE_HEADER_MULTI_READ)
  5. #define _TRACE_SKB_H
  6. #include <linux/skbuff.h>
  7. #include <linux/netdevice.h>
  8. #include <linux/tracepoint.h>
  9. #undef FN
  10. #define FN(reason) TRACE_DEFINE_ENUM(SKB_DROP_REASON_##reason);
  11. DEFINE_DROP_REASON(FN, FN)
  12. #undef FN
  13. #undef FNe
  14. #define FN(reason) { SKB_DROP_REASON_##reason, #reason },
  15. #define FNe(reason) { SKB_DROP_REASON_##reason, #reason }
  16. /*
  17. * Tracepoint for free an sk_buff:
  18. */
  19. TRACE_EVENT(kfree_skb,
  20. TP_PROTO(struct sk_buff *skb, void *location,
  21. enum skb_drop_reason reason, struct sock *rx_sk),
  22. TP_ARGS(skb, location, reason, rx_sk),
  23. TP_STRUCT__entry(
  24. __field(void *, skbaddr)
  25. __field(void *, location)
  26. __field(void *, rx_sk)
  27. __field(unsigned short, protocol)
  28. __field(enum skb_drop_reason, reason)
  29. ),
  30. TP_fast_assign(
  31. __entry->skbaddr = skb;
  32. __entry->location = location;
  33. __entry->rx_sk = rx_sk;
  34. __entry->protocol = ntohs(skb->protocol);
  35. __entry->reason = reason;
  36. ),
  37. TP_printk("skbaddr=%p rx_sk=%p protocol=%u location=%pS reason: %s",
  38. __entry->skbaddr, __entry->rx_sk, __entry->protocol,
  39. __entry->location,
  40. __print_symbolic(__entry->reason,
  41. DEFINE_DROP_REASON(FN, FNe)))
  42. );
  43. #undef FN
  44. #undef FNe
  45. TRACE_EVENT(consume_skb,
  46. TP_PROTO(struct sk_buff *skb, void *location),
  47. TP_ARGS(skb, location),
  48. TP_STRUCT__entry(
  49. __field( void *, skbaddr)
  50. __field( void *, location)
  51. ),
  52. TP_fast_assign(
  53. __entry->skbaddr = skb;
  54. __entry->location = location;
  55. ),
  56. TP_printk("skbaddr=%p location=%pS", __entry->skbaddr, __entry->location)
  57. );
  58. TRACE_EVENT(skb_copy_datagram_iovec,
  59. TP_PROTO(const struct sk_buff *skb, int len),
  60. TP_ARGS(skb, len),
  61. TP_STRUCT__entry(
  62. __field( const void *, skbaddr )
  63. __field( int, len )
  64. ),
  65. TP_fast_assign(
  66. __entry->skbaddr = skb;
  67. __entry->len = len;
  68. ),
  69. TP_printk("skbaddr=%p len=%d", __entry->skbaddr, __entry->len)
  70. );
  71. #endif /* _TRACE_SKB_H */
  72. /* This part must be outside protection */
  73. #include <trace/define_trace.h>