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