Merge branch master from git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
[linux-2.6-microblaze.git] / include / trace / events / neigh.h
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>