neigh.h 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. #undef TRACE_SYSTEM
  2. #define TRACE_SYSTEM neigh
  3. #if !defined(_TRACE_NEIGH_H) || defined(TRACE_HEADER_MULTI_READ)
  4. #define _TRACE_NEIGH_H
  5. #include <linux/skbuff.h>
  6. #include <linux/netdevice.h>
  7. #include <linux/tracepoint.h>
  8. #include <net/neighbour.h>
  9. #define neigh_state_str(state) \
  10. __print_symbolic(state, \
  11. { NUD_INCOMPLETE, "incomplete" }, \
  12. { NUD_REACHABLE, "reachable" }, \
  13. { NUD_STALE, "stale" }, \
  14. { NUD_DELAY, "delay" }, \
  15. { NUD_PROBE, "probe" }, \
  16. { NUD_FAILED, "failed" }, \
  17. { NUD_NOARP, "noarp" }, \
  18. { NUD_PERMANENT, "permanent"})
  19. TRACE_EVENT(neigh_create,
  20. TP_PROTO(struct neigh_table *tbl, struct net_device *dev,
  21. const void *pkey, const struct neighbour *n,
  22. bool exempt_from_gc),
  23. TP_ARGS(tbl, dev, pkey, n, exempt_from_gc),
  24. TP_STRUCT__entry(
  25. __field(u32, family)
  26. __string(dev, dev ? dev->name : "NULL")
  27. __field(int, entries)
  28. __field(u8, created)
  29. __field(u8, gc_exempt)
  30. __array(u8, primary_key4, 4)
  31. __array(u8, primary_key6, 16)
  32. ),
  33. TP_fast_assign(
  34. __be32 *p32;
  35. __entry->family = tbl->family;
  36. __assign_str(dev);
  37. __entry->entries = atomic_read(&tbl->gc_entries);
  38. __entry->created = n != NULL;
  39. __entry->gc_exempt = exempt_from_gc;
  40. p32 = (__be32 *)__entry->primary_key4;
  41. if (tbl->family == AF_INET)
  42. *p32 = *(__be32 *)pkey;
  43. else
  44. *p32 = 0;
  45. #if IS_ENABLED(CONFIG_IPV6)
  46. if (tbl->family == AF_INET6) {
  47. struct in6_addr *pin6;
  48. pin6 = (struct in6_addr *)__entry->primary_key6;
  49. *pin6 = *(struct in6_addr *)pkey;
  50. }
  51. #endif
  52. ),
  53. TP_printk("family %d dev %s entries %d primary_key4 %pI4 primary_key6 %pI6c created %d gc_exempt %d",
  54. __entry->family, __get_str(dev), __entry->entries,
  55. __entry->primary_key4, __entry->primary_key6,
  56. __entry->created, __entry->gc_exempt)
  57. );
  58. TRACE_EVENT(neigh_update,
  59. TP_PROTO(struct neighbour *n, const u8 *lladdr, u8 new,
  60. u32 flags, u32 nlmsg_pid),
  61. TP_ARGS(n, lladdr, new, flags, nlmsg_pid),
  62. TP_STRUCT__entry(
  63. __field(u32, family)
  64. __string(dev, (n->dev ? n->dev->name : "NULL"))
  65. __array(u8, lladdr, MAX_ADDR_LEN)
  66. __field(u8, lladdr_len)
  67. __field(u8, flags)
  68. __field(u8, nud_state)
  69. __field(u8, type)
  70. __field(u8, dead)
  71. __field(int, refcnt)
  72. __array(__u8, primary_key4, 4)
  73. __array(__u8, primary_key6, 16)
  74. __field(unsigned long, confirmed)
  75. __field(unsigned long, updated)
  76. __field(unsigned long, used)
  77. __array(u8, new_lladdr, MAX_ADDR_LEN)
  78. __field(u8, new_state)
  79. __field(u32, update_flags)
  80. __field(u32, pid)
  81. ),
  82. TP_fast_assign(
  83. int lladdr_len = (n->dev ? n->dev->addr_len : MAX_ADDR_LEN);
  84. struct in6_addr *pin6;
  85. __be32 *p32;
  86. __entry->family = n->tbl->family;
  87. __assign_str(dev);
  88. __entry->lladdr_len = lladdr_len;
  89. memcpy(__entry->lladdr, n->ha, lladdr_len);
  90. __entry->flags = n->flags;
  91. __entry->nud_state = n->nud_state;
  92. __entry->type = n->type;
  93. __entry->dead = n->dead;
  94. __entry->refcnt = refcount_read(&n->refcnt);
  95. pin6 = (struct in6_addr *)__entry->primary_key6;
  96. p32 = (__be32 *)__entry->primary_key4;
  97. if (n->tbl->family == AF_INET)
  98. *p32 = *(__be32 *)n->primary_key;
  99. else
  100. *p32 = 0;
  101. #if IS_ENABLED(CONFIG_IPV6)
  102. if (n->tbl->family == AF_INET6) {
  103. pin6 = (struct in6_addr *)__entry->primary_key6;
  104. *pin6 = *(struct in6_addr *)n->primary_key;
  105. } else
  106. #endif
  107. {
  108. ipv6_addr_set_v4mapped(*p32, pin6);
  109. }
  110. __entry->confirmed = n->confirmed;
  111. __entry->updated = n->updated;
  112. __entry->used = n->used;
  113. if (lladdr)
  114. memcpy(__entry->new_lladdr, lladdr, lladdr_len);
  115. __entry->new_state = new;
  116. __entry->update_flags = flags;
  117. __entry->pid = nlmsg_pid;
  118. ),
  119. TP_printk("family %d dev %s lladdr %s flags %02x nud_state %s type %02x "
  120. "dead %d refcnt %d primary_key4 %pI4 primary_key6 %pI6c "
  121. "confirmed %lu updated %lu used %lu new_lladdr %s "
  122. "new_state %s update_flags %02x pid %d",
  123. __entry->family, __get_str(dev),
  124. __print_hex_str(__entry->lladdr, __entry->lladdr_len),
  125. __entry->flags, neigh_state_str(__entry->nud_state),
  126. __entry->type, __entry->dead, __entry->refcnt,
  127. __entry->primary_key4, __entry->primary_key6,
  128. __entry->confirmed, __entry->updated, __entry->used,
  129. __print_hex_str(__entry->new_lladdr, __entry->lladdr_len),
  130. neigh_state_str(__entry->new_state),
  131. __entry->update_flags, __entry->pid)
  132. );
  133. DECLARE_EVENT_CLASS(neigh__update,
  134. TP_PROTO(struct neighbour *n, int err),
  135. TP_ARGS(n, err),
  136. TP_STRUCT__entry(
  137. __field(u32, family)
  138. __string(dev, (n->dev ? n->dev->name : "NULL"))
  139. __array(u8, lladdr, MAX_ADDR_LEN)
  140. __field(u8, lladdr_len)
  141. __field(u8, flags)
  142. __field(u8, nud_state)
  143. __field(u8, type)
  144. __field(u8, dead)
  145. __field(int, refcnt)
  146. __array(__u8, primary_key4, 4)
  147. __array(__u8, primary_key6, 16)
  148. __field(unsigned long, confirmed)
  149. __field(unsigned long, updated)
  150. __field(unsigned long, used)
  151. __field(u32, err)
  152. ),
  153. TP_fast_assign(
  154. int lladdr_len = (n->dev ? n->dev->addr_len : MAX_ADDR_LEN);
  155. struct in6_addr *pin6;
  156. __be32 *p32;
  157. __entry->family = n->tbl->family;
  158. __assign_str(dev);
  159. __entry->lladdr_len = lladdr_len;
  160. memcpy(__entry->lladdr, n->ha, lladdr_len);
  161. __entry->flags = n->flags;
  162. __entry->nud_state = n->nud_state;
  163. __entry->type = n->type;
  164. __entry->dead = n->dead;
  165. __entry->refcnt = refcount_read(&n->refcnt);
  166. pin6 = (struct in6_addr *)__entry->primary_key6;
  167. p32 = (__be32 *)__entry->primary_key4;
  168. if (n->tbl->family == AF_INET)
  169. *p32 = *(__be32 *)n->primary_key;
  170. else
  171. *p32 = 0;
  172. #if IS_ENABLED(CONFIG_IPV6)
  173. if (n->tbl->family == AF_INET6) {
  174. pin6 = (struct in6_addr *)__entry->primary_key6;
  175. *pin6 = *(struct in6_addr *)n->primary_key;
  176. } else
  177. #endif
  178. {
  179. ipv6_addr_set_v4mapped(*p32, pin6);
  180. }
  181. __entry->confirmed = n->confirmed;
  182. __entry->updated = n->updated;
  183. __entry->used = n->used;
  184. __entry->err = err;
  185. ),
  186. TP_printk("family %d dev %s lladdr %s flags %02x nud_state %s type %02x "
  187. "dead %d refcnt %d primary_key4 %pI4 primary_key6 %pI6c "
  188. "confirmed %lu updated %lu used %lu err %d",
  189. __entry->family, __get_str(dev),
  190. __print_hex_str(__entry->lladdr, __entry->lladdr_len),
  191. __entry->flags, neigh_state_str(__entry->nud_state),
  192. __entry->type, __entry->dead, __entry->refcnt,
  193. __entry->primary_key4, __entry->primary_key6,
  194. __entry->confirmed, __entry->updated, __entry->used,
  195. __entry->err)
  196. );
  197. DEFINE_EVENT(neigh__update, neigh_update_done,
  198. TP_PROTO(struct neighbour *neigh, int err),
  199. TP_ARGS(neigh, err)
  200. );
  201. DEFINE_EVENT(neigh__update, neigh_timer_handler,
  202. TP_PROTO(struct neighbour *neigh, int err),
  203. TP_ARGS(neigh, err)
  204. );
  205. DEFINE_EVENT(neigh__update, neigh_event_send_done,
  206. TP_PROTO(struct neighbour *neigh, int err),
  207. TP_ARGS(neigh, err)
  208. );
  209. DEFINE_EVENT(neigh__update, neigh_event_send_dead,
  210. TP_PROTO(struct neighbour *neigh, int err),
  211. TP_ARGS(neigh, err)
  212. );
  213. DEFINE_EVENT(neigh__update, neigh_cleanup_and_release,
  214. TP_PROTO(struct neighbour *neigh, int rc),
  215. TP_ARGS(neigh, rc)
  216. );
  217. #endif /* _TRACE_NEIGH_H */
  218. /* This part must be outside protection */
  219. #include <trace/define_trace.h>