]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/blob - net/mac802154/trace.h
Merge tag 'hsi-for-4.15' of git://git.kernel.org/pub/scm/linux/kernel/git/sre/linux-hsi
[mirror_ubuntu-bionic-kernel.git] / net / mac802154 / trace.h
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /* Based on net/mac80211/trace.h */
3
4 #undef TRACE_SYSTEM
5 #define TRACE_SYSTEM mac802154
6
7 #if !defined(__MAC802154_DRIVER_TRACE) || defined(TRACE_HEADER_MULTI_READ)
8 #define __MAC802154_DRIVER_TRACE
9
10 #include <linux/tracepoint.h>
11
12 #include <net/mac802154.h>
13 #include "ieee802154_i.h"
14
15 #define MAXNAME 32
16 #define LOCAL_ENTRY __array(char, wpan_phy_name, MAXNAME)
17 #define LOCAL_ASSIGN strlcpy(__entry->wpan_phy_name, \
18 wpan_phy_name(local->hw.phy), MAXNAME)
19 #define LOCAL_PR_FMT "%s"
20 #define LOCAL_PR_ARG __entry->wpan_phy_name
21
22 #define CCA_ENTRY __field(enum nl802154_cca_modes, cca_mode) \
23 __field(enum nl802154_cca_opts, cca_opt)
24 #define CCA_ASSIGN \
25 do { \
26 (__entry->cca_mode) = cca->mode; \
27 (__entry->cca_opt) = cca->opt; \
28 } while (0)
29 #define CCA_PR_FMT "cca_mode: %d, cca_opt: %d"
30 #define CCA_PR_ARG __entry->cca_mode, __entry->cca_opt
31
32 #define BOOL_TO_STR(bo) (bo) ? "true" : "false"
33
34 /* Tracing for driver callbacks */
35
36 DECLARE_EVENT_CLASS(local_only_evt,
37 TP_PROTO(struct ieee802154_local *local),
38 TP_ARGS(local),
39 TP_STRUCT__entry(
40 LOCAL_ENTRY
41 ),
42 TP_fast_assign(
43 LOCAL_ASSIGN;
44 ),
45 TP_printk(LOCAL_PR_FMT, LOCAL_PR_ARG)
46 );
47
48 DEFINE_EVENT(local_only_evt, 802154_drv_return_void,
49 TP_PROTO(struct ieee802154_local *local),
50 TP_ARGS(local)
51 );
52
53 TRACE_EVENT(802154_drv_return_int,
54 TP_PROTO(struct ieee802154_local *local, int ret),
55 TP_ARGS(local, ret),
56 TP_STRUCT__entry(
57 LOCAL_ENTRY
58 __field(int, ret)
59 ),
60 TP_fast_assign(
61 LOCAL_ASSIGN;
62 __entry->ret = ret;
63 ),
64 TP_printk(LOCAL_PR_FMT ", returned: %d", LOCAL_PR_ARG,
65 __entry->ret)
66 );
67
68 DEFINE_EVENT(local_only_evt, 802154_drv_start,
69 TP_PROTO(struct ieee802154_local *local),
70 TP_ARGS(local)
71 );
72
73 DEFINE_EVENT(local_only_evt, 802154_drv_stop,
74 TP_PROTO(struct ieee802154_local *local),
75 TP_ARGS(local)
76 );
77
78 TRACE_EVENT(802154_drv_set_channel,
79 TP_PROTO(struct ieee802154_local *local, u8 page, u8 channel),
80 TP_ARGS(local, page, channel),
81 TP_STRUCT__entry(
82 LOCAL_ENTRY
83 __field(u8, page)
84 __field(u8, channel)
85 ),
86 TP_fast_assign(
87 LOCAL_ASSIGN;
88 __entry->page = page;
89 __entry->channel = channel;
90 ),
91 TP_printk(LOCAL_PR_FMT ", page: %d, channel: %d", LOCAL_PR_ARG,
92 __entry->page, __entry->channel)
93 );
94
95 TRACE_EVENT(802154_drv_set_cca_mode,
96 TP_PROTO(struct ieee802154_local *local,
97 const struct wpan_phy_cca *cca),
98 TP_ARGS(local, cca),
99 TP_STRUCT__entry(
100 LOCAL_ENTRY
101 CCA_ENTRY
102 ),
103 TP_fast_assign(
104 LOCAL_ASSIGN;
105 CCA_ASSIGN;
106 ),
107 TP_printk(LOCAL_PR_FMT ", " CCA_PR_FMT, LOCAL_PR_ARG,
108 CCA_PR_ARG)
109 );
110
111 TRACE_EVENT(802154_drv_set_cca_ed_level,
112 TP_PROTO(struct ieee802154_local *local, s32 mbm),
113 TP_ARGS(local, mbm),
114 TP_STRUCT__entry(
115 LOCAL_ENTRY
116 __field(s32, mbm)
117 ),
118 TP_fast_assign(
119 LOCAL_ASSIGN;
120 __entry->mbm = mbm;
121 ),
122 TP_printk(LOCAL_PR_FMT ", ed level: %d", LOCAL_PR_ARG,
123 __entry->mbm)
124 );
125
126 TRACE_EVENT(802154_drv_set_tx_power,
127 TP_PROTO(struct ieee802154_local *local, s32 power),
128 TP_ARGS(local, power),
129 TP_STRUCT__entry(
130 LOCAL_ENTRY
131 __field(s32, power)
132 ),
133 TP_fast_assign(
134 LOCAL_ASSIGN;
135 __entry->power = power;
136 ),
137 TP_printk(LOCAL_PR_FMT ", mbm: %d", LOCAL_PR_ARG,
138 __entry->power)
139 );
140
141 TRACE_EVENT(802154_drv_set_lbt_mode,
142 TP_PROTO(struct ieee802154_local *local, bool mode),
143 TP_ARGS(local, mode),
144 TP_STRUCT__entry(
145 LOCAL_ENTRY
146 __field(bool, mode)
147 ),
148 TP_fast_assign(
149 LOCAL_ASSIGN;
150 __entry->mode = mode;
151 ),
152 TP_printk(LOCAL_PR_FMT ", lbt mode: %s", LOCAL_PR_ARG,
153 BOOL_TO_STR(__entry->mode))
154 );
155
156 TRACE_EVENT(802154_drv_set_short_addr,
157 TP_PROTO(struct ieee802154_local *local, __le16 short_addr),
158 TP_ARGS(local, short_addr),
159 TP_STRUCT__entry(
160 LOCAL_ENTRY
161 __field(__le16, short_addr)
162 ),
163 TP_fast_assign(
164 LOCAL_ASSIGN;
165 __entry->short_addr = short_addr;
166 ),
167 TP_printk(LOCAL_PR_FMT ", short addr: 0x%04x", LOCAL_PR_ARG,
168 le16_to_cpu(__entry->short_addr))
169 );
170
171 TRACE_EVENT(802154_drv_set_pan_id,
172 TP_PROTO(struct ieee802154_local *local, __le16 pan_id),
173 TP_ARGS(local, pan_id),
174 TP_STRUCT__entry(
175 LOCAL_ENTRY
176 __field(__le16, pan_id)
177 ),
178 TP_fast_assign(
179 LOCAL_ASSIGN;
180 __entry->pan_id = pan_id;
181 ),
182 TP_printk(LOCAL_PR_FMT ", pan id: 0x%04x", LOCAL_PR_ARG,
183 le16_to_cpu(__entry->pan_id))
184 );
185
186 TRACE_EVENT(802154_drv_set_extended_addr,
187 TP_PROTO(struct ieee802154_local *local, __le64 extended_addr),
188 TP_ARGS(local, extended_addr),
189 TP_STRUCT__entry(
190 LOCAL_ENTRY
191 __field(__le64, extended_addr)
192 ),
193 TP_fast_assign(
194 LOCAL_ASSIGN;
195 __entry->extended_addr = extended_addr;
196 ),
197 TP_printk(LOCAL_PR_FMT ", extended addr: 0x%llx", LOCAL_PR_ARG,
198 le64_to_cpu(__entry->extended_addr))
199 );
200
201 TRACE_EVENT(802154_drv_set_pan_coord,
202 TP_PROTO(struct ieee802154_local *local, bool is_coord),
203 TP_ARGS(local, is_coord),
204 TP_STRUCT__entry(
205 LOCAL_ENTRY
206 __field(bool, is_coord)
207 ),
208 TP_fast_assign(
209 LOCAL_ASSIGN;
210 __entry->is_coord = is_coord;
211 ),
212 TP_printk(LOCAL_PR_FMT ", is_coord: %s", LOCAL_PR_ARG,
213 BOOL_TO_STR(__entry->is_coord))
214 );
215
216 TRACE_EVENT(802154_drv_set_csma_params,
217 TP_PROTO(struct ieee802154_local *local, u8 min_be, u8 max_be,
218 u8 max_csma_backoffs),
219 TP_ARGS(local, min_be, max_be, max_csma_backoffs),
220 TP_STRUCT__entry(
221 LOCAL_ENTRY
222 __field(u8, min_be)
223 __field(u8, max_be)
224 __field(u8, max_csma_backoffs)
225 ),
226 TP_fast_assign(
227 LOCAL_ASSIGN,
228 __entry->min_be = min_be;
229 __entry->max_be = max_be;
230 __entry->max_csma_backoffs = max_csma_backoffs;
231 ),
232 TP_printk(LOCAL_PR_FMT ", min be: %d, max be: %d, max csma backoffs: %d",
233 LOCAL_PR_ARG, __entry->min_be, __entry->max_be,
234 __entry->max_csma_backoffs)
235 );
236
237 TRACE_EVENT(802154_drv_set_max_frame_retries,
238 TP_PROTO(struct ieee802154_local *local, s8 max_frame_retries),
239 TP_ARGS(local, max_frame_retries),
240 TP_STRUCT__entry(
241 LOCAL_ENTRY
242 __field(s8, max_frame_retries)
243 ),
244 TP_fast_assign(
245 LOCAL_ASSIGN;
246 __entry->max_frame_retries = max_frame_retries;
247 ),
248 TP_printk(LOCAL_PR_FMT ", max frame retries: %d", LOCAL_PR_ARG,
249 __entry->max_frame_retries)
250 );
251
252 TRACE_EVENT(802154_drv_set_promiscuous_mode,
253 TP_PROTO(struct ieee802154_local *local, bool on),
254 TP_ARGS(local, on),
255 TP_STRUCT__entry(
256 LOCAL_ENTRY
257 __field(bool, on)
258 ),
259 TP_fast_assign(
260 LOCAL_ASSIGN;
261 __entry->on = on;
262 ),
263 TP_printk(LOCAL_PR_FMT ", promiscuous mode: %s", LOCAL_PR_ARG,
264 BOOL_TO_STR(__entry->on))
265 );
266
267 #endif /* !__MAC802154_DRIVER_TRACE || TRACE_HEADER_MULTI_READ */
268
269 #undef TRACE_INCLUDE_PATH
270 #define TRACE_INCLUDE_PATH .
271 #undef TRACE_INCLUDE_FILE
272 #define TRACE_INCLUDE_FILE trace
273 #include <trace/define_trace.h>