blob: d3053bd8ae7312656b04fe97063f50c7c8938a24 [file] [log] [blame]
Steve Frencheccb4422018-05-17 21:16:55 -05001/* SPDX-License-Identifier: GPL-2.0 */
2/*
3 * Copyright (C) 2018, Microsoft Corporation.
4 *
5 * Author(s): Steve French <stfrench@microsoft.com>
Steve Frencheccb4422018-05-17 21:16:55 -05006 */
7#undef TRACE_SYSTEM
8#define TRACE_SYSTEM cifs
9
10#if !defined(_CIFS_TRACE_H) || defined(TRACE_HEADER_MULTI_READ)
11#define _CIFS_TRACE_H
12
13#include <linux/tracepoint.h>
Steve Frenchd7171cd2021-11-04 15:56:37 -050014#include <linux/net.h>
15#include <linux/inet.h>
Steve Frencheccb4422018-05-17 21:16:55 -050016
Shyam Prasad Neb068812021-05-21 06:35:52 +000017/*
18 * Please use this 3-part article as a reference for writing new tracepoints:
19 * https://lwn.net/Articles/379903/
20 */
21
Steve Frencheccb4422018-05-17 21:16:55 -050022/* For logging errors in read or write */
23DECLARE_EVENT_CLASS(smb3_rw_err_class,
24 TP_PROTO(unsigned int xid,
25 __u64 fid,
26 __u32 tid,
27 __u64 sesid,
28 __u64 offset,
29 __u32 len,
30 int rc),
31 TP_ARGS(xid, fid, tid, sesid, offset, len, rc),
32 TP_STRUCT__entry(
33 __field(unsigned int, xid)
34 __field(__u64, fid)
35 __field(__u32, tid)
36 __field(__u64, sesid)
37 __field(__u64, offset)
38 __field(__u32, len)
39 __field(int, rc)
40 ),
41 TP_fast_assign(
42 __entry->xid = xid;
43 __entry->fid = fid;
44 __entry->tid = tid;
45 __entry->sesid = sesid;
46 __entry->offset = offset;
47 __entry->len = len;
48 __entry->rc = rc;
49 ),
Steve Frenchd683bcd2018-05-19 02:28:53 -050050 TP_printk("\txid=%u sid=0x%llx tid=0x%x fid=0x%llx offset=0x%llx len=0x%x rc=%d",
51 __entry->xid, __entry->sesid, __entry->tid, __entry->fid,
Steve Frencheccb4422018-05-17 21:16:55 -050052 __entry->offset, __entry->len, __entry->rc)
53)
54
55#define DEFINE_SMB3_RW_ERR_EVENT(name) \
56DEFINE_EVENT(smb3_rw_err_class, smb3_##name, \
57 TP_PROTO(unsigned int xid, \
58 __u64 fid, \
59 __u32 tid, \
60 __u64 sesid, \
61 __u64 offset, \
62 __u32 len, \
63 int rc), \
64 TP_ARGS(xid, fid, tid, sesid, offset, len, rc))
65
66DEFINE_SMB3_RW_ERR_EVENT(write_err);
67DEFINE_SMB3_RW_ERR_EVENT(read_err);
Steve Frenchadb3b4e2019-02-25 13:51:11 -060068DEFINE_SMB3_RW_ERR_EVENT(query_dir_err);
Steve French779ede02019-03-13 01:41:49 -050069DEFINE_SMB3_RW_ERR_EVENT(zero_err);
70DEFINE_SMB3_RW_ERR_EVENT(falloc_err);
Steve Frencheccb4422018-05-17 21:16:55 -050071
72
73/* For logging successful read or write */
74DECLARE_EVENT_CLASS(smb3_rw_done_class,
75 TP_PROTO(unsigned int xid,
76 __u64 fid,
77 __u32 tid,
78 __u64 sesid,
79 __u64 offset,
80 __u32 len),
81 TP_ARGS(xid, fid, tid, sesid, offset, len),
82 TP_STRUCT__entry(
83 __field(unsigned int, xid)
84 __field(__u64, fid)
85 __field(__u32, tid)
86 __field(__u64, sesid)
87 __field(__u64, offset)
88 __field(__u32, len)
89 ),
90 TP_fast_assign(
91 __entry->xid = xid;
92 __entry->fid = fid;
93 __entry->tid = tid;
94 __entry->sesid = sesid;
95 __entry->offset = offset;
96 __entry->len = len;
97 ),
Steve Frenchd683bcd2018-05-19 02:28:53 -050098 TP_printk("xid=%u sid=0x%llx tid=0x%x fid=0x%llx offset=0x%llx len=0x%x",
99 __entry->xid, __entry->sesid, __entry->tid, __entry->fid,
Steve Frencheccb4422018-05-17 21:16:55 -0500100 __entry->offset, __entry->len)
101)
102
103#define DEFINE_SMB3_RW_DONE_EVENT(name) \
104DEFINE_EVENT(smb3_rw_done_class, smb3_##name, \
105 TP_PROTO(unsigned int xid, \
106 __u64 fid, \
107 __u32 tid, \
108 __u64 sesid, \
109 __u64 offset, \
110 __u32 len), \
111 TP_ARGS(xid, fid, tid, sesid, offset, len))
112
Steve Frenchd323c2462019-02-25 00:52:43 -0600113DEFINE_SMB3_RW_DONE_EVENT(write_enter);
114DEFINE_SMB3_RW_DONE_EVENT(read_enter);
115DEFINE_SMB3_RW_DONE_EVENT(query_dir_enter);
Steve French779ede02019-03-13 01:41:49 -0500116DEFINE_SMB3_RW_DONE_EVENT(zero_enter);
117DEFINE_SMB3_RW_DONE_EVENT(falloc_enter);
Steve Frencheccb4422018-05-17 21:16:55 -0500118DEFINE_SMB3_RW_DONE_EVENT(write_done);
119DEFINE_SMB3_RW_DONE_EVENT(read_done);
Steve Frenchadb3b4e2019-02-25 13:51:11 -0600120DEFINE_SMB3_RW_DONE_EVENT(query_dir_done);
Steve French779ede02019-03-13 01:41:49 -0500121DEFINE_SMB3_RW_DONE_EVENT(zero_done);
122DEFINE_SMB3_RW_DONE_EVENT(falloc_done);
Steve Frencheccb4422018-05-17 21:16:55 -0500123
Steve French7c05eae2022-06-15 22:40:23 -0500124/* For logging successful set EOF (truncate) */
125DECLARE_EVENT_CLASS(smb3_eof_class,
126 TP_PROTO(unsigned int xid,
127 __u64 fid,
128 __u32 tid,
129 __u64 sesid,
130 __u64 offset),
131 TP_ARGS(xid, fid, tid, sesid, offset),
132 TP_STRUCT__entry(
133 __field(unsigned int, xid)
134 __field(__u64, fid)
135 __field(__u32, tid)
136 __field(__u64, sesid)
137 __field(__u64, offset)
138 ),
139 TP_fast_assign(
140 __entry->xid = xid;
141 __entry->fid = fid;
142 __entry->tid = tid;
143 __entry->sesid = sesid;
144 __entry->offset = offset;
145 ),
146 TP_printk("xid=%u sid=0x%llx tid=0x%x fid=0x%llx offset=0x%llx",
147 __entry->xid, __entry->sesid, __entry->tid, __entry->fid,
148 __entry->offset)
149)
150
151#define DEFINE_SMB3_EOF_EVENT(name) \
152DEFINE_EVENT(smb3_eof_class, smb3_##name, \
153 TP_PROTO(unsigned int xid, \
154 __u64 fid, \
155 __u32 tid, \
156 __u64 sesid, \
157 __u64 offset), \
158 TP_ARGS(xid, fid, tid, sesid, offset))
159
160DEFINE_SMB3_EOF_EVENT(set_eof);
161
Steve Frencheccb4422018-05-17 21:16:55 -0500162/*
163 * For handle based calls other than read and write, and get/set info
164 */
Steve Frenchf90f9792019-09-03 18:35:42 -0500165DECLARE_EVENT_CLASS(smb3_fd_class,
166 TP_PROTO(unsigned int xid,
167 __u64 fid,
168 __u32 tid,
169 __u64 sesid),
170 TP_ARGS(xid, fid, tid, sesid),
171 TP_STRUCT__entry(
172 __field(unsigned int, xid)
173 __field(__u64, fid)
174 __field(__u32, tid)
175 __field(__u64, sesid)
176 ),
177 TP_fast_assign(
178 __entry->xid = xid;
179 __entry->fid = fid;
180 __entry->tid = tid;
181 __entry->sesid = sesid;
182 ),
183 TP_printk("\txid=%u sid=0x%llx tid=0x%x fid=0x%llx",
184 __entry->xid, __entry->sesid, __entry->tid, __entry->fid)
185)
186
187#define DEFINE_SMB3_FD_EVENT(name) \
188DEFINE_EVENT(smb3_fd_class, smb3_##name, \
189 TP_PROTO(unsigned int xid, \
190 __u64 fid, \
191 __u32 tid, \
192 __u64 sesid), \
193 TP_ARGS(xid, fid, tid, sesid))
194
195DEFINE_SMB3_FD_EVENT(flush_enter);
196DEFINE_SMB3_FD_EVENT(flush_done);
197DEFINE_SMB3_FD_EVENT(close_enter);
198DEFINE_SMB3_FD_EVENT(close_done);
Steve French35a2b532022-05-22 00:41:41 -0500199DEFINE_SMB3_FD_EVENT(oplock_not_found);
Steve Frenchf90f9792019-09-03 18:35:42 -0500200
Steve Frencheccb4422018-05-17 21:16:55 -0500201DECLARE_EVENT_CLASS(smb3_fd_err_class,
202 TP_PROTO(unsigned int xid,
203 __u64 fid,
204 __u32 tid,
205 __u64 sesid,
206 int rc),
207 TP_ARGS(xid, fid, tid, sesid, rc),
208 TP_STRUCT__entry(
209 __field(unsigned int, xid)
210 __field(__u64, fid)
211 __field(__u32, tid)
212 __field(__u64, sesid)
213 __field(int, rc)
214 ),
215 TP_fast_assign(
216 __entry->xid = xid;
217 __entry->fid = fid;
218 __entry->tid = tid;
219 __entry->sesid = sesid;
220 __entry->rc = rc;
221 ),
Steve Frenchd683bcd2018-05-19 02:28:53 -0500222 TP_printk("\txid=%u sid=0x%llx tid=0x%x fid=0x%llx rc=%d",
223 __entry->xid, __entry->sesid, __entry->tid, __entry->fid,
Steve Frencheccb4422018-05-17 21:16:55 -0500224 __entry->rc)
225)
226
227#define DEFINE_SMB3_FD_ERR_EVENT(name) \
228DEFINE_EVENT(smb3_fd_err_class, smb3_##name, \
229 TP_PROTO(unsigned int xid, \
230 __u64 fid, \
231 __u32 tid, \
232 __u64 sesid, \
233 int rc), \
234 TP_ARGS(xid, fid, tid, sesid, rc))
235
236DEFINE_SMB3_FD_ERR_EVENT(flush_err);
237DEFINE_SMB3_FD_ERR_EVENT(lock_err);
238DEFINE_SMB3_FD_ERR_EVENT(close_err);
239
240/*
241 * For handle based query/set info calls
242 */
Steve Frenchd42043a2019-02-26 21:58:30 -0600243DECLARE_EVENT_CLASS(smb3_inf_enter_class,
244 TP_PROTO(unsigned int xid,
245 __u64 fid,
246 __u32 tid,
247 __u64 sesid,
248 __u8 infclass,
249 __u32 type),
250 TP_ARGS(xid, fid, tid, sesid, infclass, type),
251 TP_STRUCT__entry(
252 __field(unsigned int, xid)
253 __field(__u64, fid)
254 __field(__u32, tid)
255 __field(__u64, sesid)
256 __field(__u8, infclass)
257 __field(__u32, type)
258 ),
259 TP_fast_assign(
260 __entry->xid = xid;
261 __entry->fid = fid;
262 __entry->tid = tid;
263 __entry->sesid = sesid;
264 __entry->infclass = infclass;
265 __entry->type = type;
266 ),
267 TP_printk("xid=%u sid=0x%llx tid=0x%x fid=0x%llx class=%u type=0x%x",
268 __entry->xid, __entry->sesid, __entry->tid, __entry->fid,
269 __entry->infclass, __entry->type)
270)
271
272#define DEFINE_SMB3_INF_ENTER_EVENT(name) \
273DEFINE_EVENT(smb3_inf_enter_class, smb3_##name, \
274 TP_PROTO(unsigned int xid, \
275 __u64 fid, \
276 __u32 tid, \
277 __u64 sesid, \
278 __u8 infclass, \
279 __u32 type), \
280 TP_ARGS(xid, fid, tid, sesid, infclass, type))
281
282DEFINE_SMB3_INF_ENTER_EVENT(query_info_enter);
283DEFINE_SMB3_INF_ENTER_EVENT(query_info_done);
Steve Frenchc3498182019-09-15 22:38:52 -0500284DEFINE_SMB3_INF_ENTER_EVENT(notify_enter);
285DEFINE_SMB3_INF_ENTER_EVENT(notify_done);
Steve Frenchd42043a2019-02-26 21:58:30 -0600286
Steve Frencheccb4422018-05-17 21:16:55 -0500287DECLARE_EVENT_CLASS(smb3_inf_err_class,
288 TP_PROTO(unsigned int xid,
289 __u64 fid,
290 __u32 tid,
291 __u64 sesid,
292 __u8 infclass,
293 __u32 type,
294 int rc),
295 TP_ARGS(xid, fid, tid, sesid, infclass, type, rc),
296 TP_STRUCT__entry(
297 __field(unsigned int, xid)
298 __field(__u64, fid)
299 __field(__u32, tid)
300 __field(__u64, sesid)
301 __field(__u8, infclass)
302 __field(__u32, type)
303 __field(int, rc)
304 ),
305 TP_fast_assign(
306 __entry->xid = xid;
307 __entry->fid = fid;
308 __entry->tid = tid;
309 __entry->sesid = sesid;
310 __entry->infclass = infclass;
311 __entry->type = type;
312 __entry->rc = rc;
313 ),
Steve Frenchd683bcd2018-05-19 02:28:53 -0500314 TP_printk("xid=%u sid=0x%llx tid=0x%x fid=0x%llx class=%u type=0x%x rc=%d",
315 __entry->xid, __entry->sesid, __entry->tid, __entry->fid,
Steve Frencheccb4422018-05-17 21:16:55 -0500316 __entry->infclass, __entry->type, __entry->rc)
317)
318
319#define DEFINE_SMB3_INF_ERR_EVENT(name) \
320DEFINE_EVENT(smb3_inf_err_class, smb3_##name, \
321 TP_PROTO(unsigned int xid, \
322 __u64 fid, \
323 __u32 tid, \
324 __u64 sesid, \
325 __u8 infclass, \
326 __u32 type, \
327 int rc), \
328 TP_ARGS(xid, fid, tid, sesid, infclass, type, rc))
329
330DEFINE_SMB3_INF_ERR_EVENT(query_info_err);
331DEFINE_SMB3_INF_ERR_EVENT(set_info_err);
Steve Frenchc3498182019-09-15 22:38:52 -0500332DEFINE_SMB3_INF_ERR_EVENT(notify_err);
Steve Frencheccb4422018-05-17 21:16:55 -0500333DEFINE_SMB3_INF_ERR_EVENT(fsctl_err);
334
Steve French81915762019-03-13 00:02:47 -0500335DECLARE_EVENT_CLASS(smb3_inf_compound_enter_class,
336 TP_PROTO(unsigned int xid,
337 __u32 tid,
338 __u64 sesid,
339 const char *full_path),
340 TP_ARGS(xid, tid, sesid, full_path),
341 TP_STRUCT__entry(
342 __field(unsigned int, xid)
343 __field(__u32, tid)
344 __field(__u64, sesid)
345 __string(path, full_path)
346 ),
347 TP_fast_assign(
348 __entry->xid = xid;
349 __entry->tid = tid;
350 __entry->sesid = sesid;
351 __assign_str(path, full_path);
352 ),
353 TP_printk("xid=%u sid=0x%llx tid=0x%x path=%s",
354 __entry->xid, __entry->sesid, __entry->tid,
355 __get_str(path))
356)
357
358#define DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(name) \
359DEFINE_EVENT(smb3_inf_compound_enter_class, smb3_##name, \
360 TP_PROTO(unsigned int xid, \
361 __u32 tid, \
362 __u64 sesid, \
363 const char *full_path), \
364 TP_ARGS(xid, tid, sesid, full_path))
365
366DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(query_info_compound_enter);
Steve Frenche4bd7c42020-06-11 23:02:33 -0500367DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(posix_query_info_compound_enter);
Steve French81915762019-03-13 00:02:47 -0500368DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(hardlink_enter);
369DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(rename_enter);
370DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(rmdir_enter);
371DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(set_eof_enter);
372DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(set_info_compound_enter);
373DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(delete_enter);
374DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(mkdir_enter);
Steve French68e14562022-09-21 14:05:53 -0500375DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(tdis_enter);
Steve French81915762019-03-13 00:02:47 -0500376
377
378DECLARE_EVENT_CLASS(smb3_inf_compound_done_class,
379 TP_PROTO(unsigned int xid,
380 __u32 tid,
381 __u64 sesid),
382 TP_ARGS(xid, tid, sesid),
383 TP_STRUCT__entry(
384 __field(unsigned int, xid)
385 __field(__u32, tid)
386 __field(__u64, sesid)
387 ),
388 TP_fast_assign(
389 __entry->xid = xid;
390 __entry->tid = tid;
391 __entry->sesid = sesid;
392 ),
393 TP_printk("xid=%u sid=0x%llx tid=0x%x",
394 __entry->xid, __entry->sesid, __entry->tid)
395)
396
397#define DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(name) \
398DEFINE_EVENT(smb3_inf_compound_done_class, smb3_##name, \
399 TP_PROTO(unsigned int xid, \
400 __u32 tid, \
401 __u64 sesid), \
402 TP_ARGS(xid, tid, sesid))
403
404DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(query_info_compound_done);
Steve Frenche4bd7c42020-06-11 23:02:33 -0500405DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(posix_query_info_compound_done);
Steve French81915762019-03-13 00:02:47 -0500406DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(hardlink_done);
407DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(rename_done);
408DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(rmdir_done);
409DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(set_eof_done);
410DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(set_info_compound_done);
411DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(delete_done);
412DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(mkdir_done);
Steve French68e14562022-09-21 14:05:53 -0500413DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(tdis_done);
Steve French81915762019-03-13 00:02:47 -0500414
415
416DECLARE_EVENT_CLASS(smb3_inf_compound_err_class,
417 TP_PROTO(unsigned int xid,
418 __u32 tid,
419 __u64 sesid,
420 int rc),
421 TP_ARGS(xid, tid, sesid, rc),
422 TP_STRUCT__entry(
423 __field(unsigned int, xid)
424 __field(__u32, tid)
425 __field(__u64, sesid)
426 __field(int, rc)
427 ),
428 TP_fast_assign(
429 __entry->xid = xid;
430 __entry->tid = tid;
431 __entry->sesid = sesid;
432 __entry->rc = rc;
433 ),
434 TP_printk("xid=%u sid=0x%llx tid=0x%x rc=%d",
435 __entry->xid, __entry->sesid, __entry->tid,
436 __entry->rc)
437)
438
439#define DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(name) \
440DEFINE_EVENT(smb3_inf_compound_err_class, smb3_##name, \
441 TP_PROTO(unsigned int xid, \
442 __u32 tid, \
443 __u64 sesid, \
444 int rc), \
445 TP_ARGS(xid, tid, sesid, rc))
446
447DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(query_info_compound_err);
Steve Frenche4bd7c42020-06-11 23:02:33 -0500448DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(posix_query_info_compound_err);
Steve French81915762019-03-13 00:02:47 -0500449DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(hardlink_err);
450DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(rename_err);
451DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(rmdir_err);
452DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(set_eof_err);
453DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(set_info_compound_err);
454DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(mkdir_err);
455DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(delete_err);
Steve French68e14562022-09-21 14:05:53 -0500456DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(tdis_err);
Steve French81915762019-03-13 00:02:47 -0500457
Steve Frencheccb4422018-05-17 21:16:55 -0500458/*
459 * For logging SMB3 Status code and Command for responses which return errors
460 */
461DECLARE_EVENT_CLASS(smb3_cmd_err_class,
Steve Frenchd683bcd2018-05-19 02:28:53 -0500462 TP_PROTO(__u32 tid,
Steve Frencheccb4422018-05-17 21:16:55 -0500463 __u64 sesid,
464 __u16 cmd,
465 __u64 mid,
466 __u32 status,
467 int rc),
Steve Frenchd683bcd2018-05-19 02:28:53 -0500468 TP_ARGS(tid, sesid, cmd, mid, status, rc),
Steve Frencheccb4422018-05-17 21:16:55 -0500469 TP_STRUCT__entry(
Steve Frencheccb4422018-05-17 21:16:55 -0500470 __field(__u32, tid)
471 __field(__u64, sesid)
472 __field(__u16, cmd)
473 __field(__u64, mid)
474 __field(__u32, status)
475 __field(int, rc)
476 ),
477 TP_fast_assign(
Steve Frencheccb4422018-05-17 21:16:55 -0500478 __entry->tid = tid;
479 __entry->sesid = sesid;
480 __entry->cmd = cmd;
481 __entry->mid = mid;
482 __entry->status = status;
483 __entry->rc = rc;
484 ),
Steve Frenchd683bcd2018-05-19 02:28:53 -0500485 TP_printk("\tsid=0x%llx tid=0x%x cmd=%u mid=%llu status=0x%x rc=%d",
486 __entry->sesid, __entry->tid, __entry->cmd, __entry->mid,
487 __entry->status, __entry->rc)
Steve Frencheccb4422018-05-17 21:16:55 -0500488)
489
490#define DEFINE_SMB3_CMD_ERR_EVENT(name) \
491DEFINE_EVENT(smb3_cmd_err_class, smb3_##name, \
Steve Frenchd683bcd2018-05-19 02:28:53 -0500492 TP_PROTO(__u32 tid, \
Steve Frencheccb4422018-05-17 21:16:55 -0500493 __u64 sesid, \
494 __u16 cmd, \
495 __u64 mid, \
496 __u32 status, \
497 int rc), \
Steve Frenchd683bcd2018-05-19 02:28:53 -0500498 TP_ARGS(tid, sesid, cmd, mid, status, rc))
Steve Frencheccb4422018-05-17 21:16:55 -0500499
500DEFINE_SMB3_CMD_ERR_EVENT(cmd_err);
501
502DECLARE_EVENT_CLASS(smb3_cmd_done_class,
Steve Frenchd683bcd2018-05-19 02:28:53 -0500503 TP_PROTO(__u32 tid,
Steve Frencheccb4422018-05-17 21:16:55 -0500504 __u64 sesid,
505 __u16 cmd,
506 __u64 mid),
Steve Frenchd683bcd2018-05-19 02:28:53 -0500507 TP_ARGS(tid, sesid, cmd, mid),
Steve Frencheccb4422018-05-17 21:16:55 -0500508 TP_STRUCT__entry(
Steve Frencheccb4422018-05-17 21:16:55 -0500509 __field(__u32, tid)
510 __field(__u64, sesid)
511 __field(__u16, cmd)
512 __field(__u64, mid)
513 ),
514 TP_fast_assign(
Steve Frencheccb4422018-05-17 21:16:55 -0500515 __entry->tid = tid;
516 __entry->sesid = sesid;
517 __entry->cmd = cmd;
518 __entry->mid = mid;
519 ),
Steve Frenchd683bcd2018-05-19 02:28:53 -0500520 TP_printk("\tsid=0x%llx tid=0x%x cmd=%u mid=%llu",
521 __entry->sesid, __entry->tid,
Steve Frencheccb4422018-05-17 21:16:55 -0500522 __entry->cmd, __entry->mid)
523)
524
525#define DEFINE_SMB3_CMD_DONE_EVENT(name) \
526DEFINE_EVENT(smb3_cmd_done_class, smb3_##name, \
Steve Frenchd683bcd2018-05-19 02:28:53 -0500527 TP_PROTO(__u32 tid, \
Steve Frencheccb4422018-05-17 21:16:55 -0500528 __u64 sesid, \
529 __u16 cmd, \
530 __u64 mid), \
Steve Frenchd683bcd2018-05-19 02:28:53 -0500531 TP_ARGS(tid, sesid, cmd, mid))
Steve Frencheccb4422018-05-17 21:16:55 -0500532
Steve French53a3e0d2019-02-26 21:26:20 -0600533DEFINE_SMB3_CMD_DONE_EVENT(cmd_enter);
Steve Frencheccb4422018-05-17 21:16:55 -0500534DEFINE_SMB3_CMD_DONE_EVENT(cmd_done);
Steve Frenche68a9322018-07-30 14:23:58 -0500535DEFINE_SMB3_CMD_DONE_EVENT(ses_expired);
Steve Frencheccb4422018-05-17 21:16:55 -0500536
Steve French020eec52018-08-01 16:38:07 -0500537DECLARE_EVENT_CLASS(smb3_mid_class,
538 TP_PROTO(__u16 cmd,
539 __u64 mid,
540 __u32 pid,
541 unsigned long when_sent,
542 unsigned long when_received),
543 TP_ARGS(cmd, mid, pid, when_sent, when_received),
544 TP_STRUCT__entry(
545 __field(__u16, cmd)
546 __field(__u64, mid)
547 __field(__u32, pid)
548 __field(unsigned long, when_sent)
549 __field(unsigned long, when_received)
550 ),
551 TP_fast_assign(
552 __entry->cmd = cmd;
553 __entry->mid = mid;
554 __entry->pid = pid;
555 __entry->when_sent = when_sent;
556 __entry->when_received = when_received;
557 ),
558 TP_printk("\tcmd=%u mid=%llu pid=%u, when_sent=%lu when_rcv=%lu",
559 __entry->cmd, __entry->mid, __entry->pid, __entry->when_sent,
560 __entry->when_received)
561)
562
563#define DEFINE_SMB3_MID_EVENT(name) \
564DEFINE_EVENT(smb3_mid_class, smb3_##name, \
565 TP_PROTO(__u16 cmd, \
566 __u64 mid, \
567 __u32 pid, \
568 unsigned long when_sent, \
569 unsigned long when_received), \
570 TP_ARGS(cmd, mid, pid, when_sent, when_received))
571
572DEFINE_SMB3_MID_EVENT(slow_rsp);
573
Steve Frenchd683bcd2018-05-19 02:28:53 -0500574DECLARE_EVENT_CLASS(smb3_exit_err_class,
575 TP_PROTO(unsigned int xid,
576 const char *func_name,
577 int rc),
578 TP_ARGS(xid, func_name, rc),
579 TP_STRUCT__entry(
580 __field(unsigned int, xid)
Shyam Prasad Neb068812021-05-21 06:35:52 +0000581 __string(func_name, func_name)
Steve Frenchd683bcd2018-05-19 02:28:53 -0500582 __field(int, rc)
583 ),
584 TP_fast_assign(
585 __entry->xid = xid;
Shyam Prasad Neb068812021-05-21 06:35:52 +0000586 __assign_str(func_name, func_name);
Steve Frenchd683bcd2018-05-19 02:28:53 -0500587 __entry->rc = rc;
588 ),
589 TP_printk("\t%s: xid=%u rc=%d",
Shyam Prasad Neb068812021-05-21 06:35:52 +0000590 __get_str(func_name), __entry->xid, __entry->rc)
Steve Frenchd683bcd2018-05-19 02:28:53 -0500591)
592
593#define DEFINE_SMB3_EXIT_ERR_EVENT(name) \
594DEFINE_EVENT(smb3_exit_err_class, smb3_##name, \
595 TP_PROTO(unsigned int xid, \
596 const char *func_name, \
597 int rc), \
598 TP_ARGS(xid, func_name, rc))
599
600DEFINE_SMB3_EXIT_ERR_EVENT(exit_err);
601
Steve Frenchf2bf09e2020-02-05 18:22:37 -0600602
603DECLARE_EVENT_CLASS(smb3_sync_err_class,
604 TP_PROTO(unsigned long ino,
605 int rc),
606 TP_ARGS(ino, rc),
607 TP_STRUCT__entry(
608 __field(unsigned long, ino)
609 __field(int, rc)
610 ),
611 TP_fast_assign(
612 __entry->ino = ino;
613 __entry->rc = rc;
614 ),
615 TP_printk("\tino=%lu rc=%d",
616 __entry->ino, __entry->rc)
617)
618
619#define DEFINE_SMB3_SYNC_ERR_EVENT(name) \
620DEFINE_EVENT(smb3_sync_err_class, cifs_##name, \
621 TP_PROTO(unsigned long ino, \
622 int rc), \
623 TP_ARGS(ino, rc))
624
625DEFINE_SMB3_SYNC_ERR_EVENT(fsync_err);
626DEFINE_SMB3_SYNC_ERR_EVENT(flush_err);
627
628
Steve Frenchd683bcd2018-05-19 02:28:53 -0500629DECLARE_EVENT_CLASS(smb3_enter_exit_class,
630 TP_PROTO(unsigned int xid,
631 const char *func_name),
632 TP_ARGS(xid, func_name),
633 TP_STRUCT__entry(
634 __field(unsigned int, xid)
Shyam Prasad Neb068812021-05-21 06:35:52 +0000635 __string(func_name, func_name)
Steve Frenchd683bcd2018-05-19 02:28:53 -0500636 ),
637 TP_fast_assign(
638 __entry->xid = xid;
Shyam Prasad Neb068812021-05-21 06:35:52 +0000639 __assign_str(func_name, func_name);
Steve Frenchd683bcd2018-05-19 02:28:53 -0500640 ),
641 TP_printk("\t%s: xid=%u",
Shyam Prasad Neb068812021-05-21 06:35:52 +0000642 __get_str(func_name), __entry->xid)
Steve Frenchd683bcd2018-05-19 02:28:53 -0500643)
644
645#define DEFINE_SMB3_ENTER_EXIT_EVENT(name) \
646DEFINE_EVENT(smb3_enter_exit_class, smb3_##name, \
647 TP_PROTO(unsigned int xid, \
648 const char *func_name), \
649 TP_ARGS(xid, func_name))
650
651DEFINE_SMB3_ENTER_EXIT_EVENT(enter);
652DEFINE_SMB3_ENTER_EXIT_EVENT(exit_done);
653
Steve French28d59362018-05-30 21:42:34 -0500654/*
Steve Frenchf8af49d2018-10-28 00:47:11 -0500655 * For SMB2/SMB3 tree connect
656 */
657
658DECLARE_EVENT_CLASS(smb3_tcon_class,
659 TP_PROTO(unsigned int xid,
660 __u32 tid,
661 __u64 sesid,
662 const char *unc_name,
663 int rc),
664 TP_ARGS(xid, tid, sesid, unc_name, rc),
665 TP_STRUCT__entry(
666 __field(unsigned int, xid)
667 __field(__u32, tid)
668 __field(__u64, sesid)
Paulo Alcantara (SUSE)68ddb492019-03-21 19:31:22 -0300669 __string(name, unc_name)
Steve Frenchf8af49d2018-10-28 00:47:11 -0500670 __field(int, rc)
671 ),
672 TP_fast_assign(
673 __entry->xid = xid;
674 __entry->tid = tid;
675 __entry->sesid = sesid;
Paulo Alcantara (SUSE)68ddb492019-03-21 19:31:22 -0300676 __assign_str(name, unc_name);
Steve Frenchf8af49d2018-10-28 00:47:11 -0500677 __entry->rc = rc;
678 ),
679 TP_printk("xid=%u sid=0x%llx tid=0x%x unc_name=%s rc=%d",
680 __entry->xid, __entry->sesid, __entry->tid,
Paulo Alcantara (SUSE)68ddb492019-03-21 19:31:22 -0300681 __get_str(name), __entry->rc)
Steve Frenchf8af49d2018-10-28 00:47:11 -0500682)
683
684#define DEFINE_SMB3_TCON_EVENT(name) \
685DEFINE_EVENT(smb3_tcon_class, smb3_##name, \
686 TP_PROTO(unsigned int xid, \
687 __u32 tid, \
688 __u64 sesid, \
689 const char *unc_name, \
690 int rc), \
691 TP_ARGS(xid, tid, sesid, unc_name, rc))
692
693DEFINE_SMB3_TCON_EVENT(tcon);
694
695
696/*
Steve Frenchefe2e9f2019-02-26 19:08:12 -0600697 * For smb2/smb3 open (including create and mkdir) calls
Steve French28d59362018-05-30 21:42:34 -0500698 */
Steve Frenchefe2e9f2019-02-26 19:08:12 -0600699
700DECLARE_EVENT_CLASS(smb3_open_enter_class,
701 TP_PROTO(unsigned int xid,
702 __u32 tid,
703 __u64 sesid,
Shyam Prasad Nfddc6cc2023-03-17 12:51:17 +0000704 const char *full_path,
Steve Frenchefe2e9f2019-02-26 19:08:12 -0600705 int create_options,
706 int desired_access),
Shyam Prasad Nfddc6cc2023-03-17 12:51:17 +0000707 TP_ARGS(xid, tid, sesid, full_path, create_options, desired_access),
Steve Frenchefe2e9f2019-02-26 19:08:12 -0600708 TP_STRUCT__entry(
709 __field(unsigned int, xid)
710 __field(__u32, tid)
711 __field(__u64, sesid)
Shyam Prasad Nfddc6cc2023-03-17 12:51:17 +0000712 __string(path, full_path)
Steve Frenchefe2e9f2019-02-26 19:08:12 -0600713 __field(int, create_options)
714 __field(int, desired_access)
715 ),
716 TP_fast_assign(
717 __entry->xid = xid;
718 __entry->tid = tid;
719 __entry->sesid = sesid;
Shyam Prasad Nfddc6cc2023-03-17 12:51:17 +0000720 __assign_str(path, full_path);
Steve Frenchefe2e9f2019-02-26 19:08:12 -0600721 __entry->create_options = create_options;
722 __entry->desired_access = desired_access;
723 ),
Shyam Prasad Nfddc6cc2023-03-17 12:51:17 +0000724 TP_printk("xid=%u sid=0x%llx tid=0x%x path=%s cr_opts=0x%x des_access=0x%x",
725 __entry->xid, __entry->sesid, __entry->tid, __get_str(path),
Steve Frenchefe2e9f2019-02-26 19:08:12 -0600726 __entry->create_options, __entry->desired_access)
727)
728
729#define DEFINE_SMB3_OPEN_ENTER_EVENT(name) \
730DEFINE_EVENT(smb3_open_enter_class, smb3_##name, \
731 TP_PROTO(unsigned int xid, \
732 __u32 tid, \
733 __u64 sesid, \
Shyam Prasad Nfddc6cc2023-03-17 12:51:17 +0000734 const char *full_path, \
Steve Frenchefe2e9f2019-02-26 19:08:12 -0600735 int create_options, \
736 int desired_access), \
Shyam Prasad Nfddc6cc2023-03-17 12:51:17 +0000737 TP_ARGS(xid, tid, sesid, full_path, create_options, desired_access))
Steve Frenchefe2e9f2019-02-26 19:08:12 -0600738
739DEFINE_SMB3_OPEN_ENTER_EVENT(open_enter);
740DEFINE_SMB3_OPEN_ENTER_EVENT(posix_mkdir_enter);
741
Steve French28d59362018-05-30 21:42:34 -0500742DECLARE_EVENT_CLASS(smb3_open_err_class,
743 TP_PROTO(unsigned int xid,
744 __u32 tid,
745 __u64 sesid,
746 int create_options,
747 int desired_access,
748 int rc),
749 TP_ARGS(xid, tid, sesid, create_options, desired_access, rc),
750 TP_STRUCT__entry(
751 __field(unsigned int, xid)
752 __field(__u32, tid)
753 __field(__u64, sesid)
754 __field(int, create_options)
755 __field(int, desired_access)
756 __field(int, rc)
757 ),
758 TP_fast_assign(
759 __entry->xid = xid;
760 __entry->tid = tid;
761 __entry->sesid = sesid;
762 __entry->create_options = create_options;
763 __entry->desired_access = desired_access;
764 __entry->rc = rc;
765 ),
766 TP_printk("xid=%u sid=0x%llx tid=0x%x cr_opts=0x%x des_access=0x%x rc=%d",
767 __entry->xid, __entry->sesid, __entry->tid,
768 __entry->create_options, __entry->desired_access, __entry->rc)
769)
770
771#define DEFINE_SMB3_OPEN_ERR_EVENT(name) \
772DEFINE_EVENT(smb3_open_err_class, smb3_##name, \
773 TP_PROTO(unsigned int xid, \
774 __u32 tid, \
775 __u64 sesid, \
776 int create_options, \
777 int desired_access, \
778 int rc), \
779 TP_ARGS(xid, tid, sesid, create_options, desired_access, rc))
780
781DEFINE_SMB3_OPEN_ERR_EVENT(open_err);
Steve Frenchbea851b2018-06-14 21:56:32 -0500782DEFINE_SMB3_OPEN_ERR_EVENT(posix_mkdir_err);
Steve French28d59362018-05-30 21:42:34 -0500783
784DECLARE_EVENT_CLASS(smb3_open_done_class,
785 TP_PROTO(unsigned int xid,
786 __u64 fid,
787 __u32 tid,
788 __u64 sesid,
789 int create_options,
790 int desired_access),
791 TP_ARGS(xid, fid, tid, sesid, create_options, desired_access),
792 TP_STRUCT__entry(
793 __field(unsigned int, xid)
794 __field(__u64, fid)
795 __field(__u32, tid)
796 __field(__u64, sesid)
797 __field(int, create_options)
798 __field(int, desired_access)
799 ),
800 TP_fast_assign(
801 __entry->xid = xid;
802 __entry->fid = fid;
803 __entry->tid = tid;
804 __entry->sesid = sesid;
805 __entry->create_options = create_options;
806 __entry->desired_access = desired_access;
807 ),
808 TP_printk("xid=%u sid=0x%llx tid=0x%x fid=0x%llx cr_opts=0x%x des_access=0x%x",
809 __entry->xid, __entry->sesid, __entry->tid, __entry->fid,
810 __entry->create_options, __entry->desired_access)
811)
812
813#define DEFINE_SMB3_OPEN_DONE_EVENT(name) \
814DEFINE_EVENT(smb3_open_done_class, smb3_##name, \
815 TP_PROTO(unsigned int xid, \
816 __u64 fid, \
817 __u32 tid, \
818 __u64 sesid, \
819 int create_options, \
820 int desired_access), \
821 TP_ARGS(xid, fid, tid, sesid, create_options, desired_access))
822
823DEFINE_SMB3_OPEN_DONE_EVENT(open_done);
Steve Frenchbea851b2018-06-14 21:56:32 -0500824DEFINE_SMB3_OPEN_DONE_EVENT(posix_mkdir_done);
Steve French28d59362018-05-30 21:42:34 -0500825
Steve French179e44d2018-09-28 19:44:23 -0500826
827DECLARE_EVENT_CLASS(smb3_lease_done_class,
828 TP_PROTO(__u32 lease_state,
829 __u32 tid,
830 __u64 sesid,
831 __u64 lease_key_low,
832 __u64 lease_key_high),
833 TP_ARGS(lease_state, tid, sesid, lease_key_low, lease_key_high),
834 TP_STRUCT__entry(
835 __field(__u32, lease_state)
836 __field(__u32, tid)
837 __field(__u64, sesid)
838 __field(__u64, lease_key_low)
839 __field(__u64, lease_key_high)
840 ),
841 TP_fast_assign(
842 __entry->lease_state = lease_state;
843 __entry->tid = tid;
844 __entry->sesid = sesid;
845 __entry->lease_key_low = lease_key_low;
846 __entry->lease_key_high = lease_key_high;
847 ),
848 TP_printk("sid=0x%llx tid=0x%x lease_key=0x%llx%llx lease_state=0x%x",
849 __entry->sesid, __entry->tid, __entry->lease_key_high,
850 __entry->lease_key_low, __entry->lease_state)
851)
852
853#define DEFINE_SMB3_LEASE_DONE_EVENT(name) \
854DEFINE_EVENT(smb3_lease_done_class, smb3_##name, \
855 TP_PROTO(__u32 lease_state, \
856 __u32 tid, \
857 __u64 sesid, \
858 __u64 lease_key_low, \
859 __u64 lease_key_high), \
860 TP_ARGS(lease_state, tid, sesid, lease_key_low, lease_key_high))
861
862DEFINE_SMB3_LEASE_DONE_EVENT(lease_done);
Steve Frenchfb253d52022-05-21 23:56:16 -0500863DEFINE_SMB3_LEASE_DONE_EVENT(lease_not_found);
Steve French179e44d2018-09-28 19:44:23 -0500864
865DECLARE_EVENT_CLASS(smb3_lease_err_class,
866 TP_PROTO(__u32 lease_state,
867 __u32 tid,
868 __u64 sesid,
869 __u64 lease_key_low,
870 __u64 lease_key_high,
871 int rc),
872 TP_ARGS(lease_state, tid, sesid, lease_key_low, lease_key_high, rc),
873 TP_STRUCT__entry(
874 __field(__u32, lease_state)
875 __field(__u32, tid)
876 __field(__u64, sesid)
877 __field(__u64, lease_key_low)
878 __field(__u64, lease_key_high)
879 __field(int, rc)
880 ),
881 TP_fast_assign(
882 __entry->lease_state = lease_state;
883 __entry->tid = tid;
884 __entry->sesid = sesid;
885 __entry->lease_key_low = lease_key_low;
886 __entry->lease_key_high = lease_key_high;
887 __entry->rc = rc;
888 ),
889 TP_printk("sid=0x%llx tid=0x%x lease_key=0x%llx%llx lease_state=0x%x rc=%d",
890 __entry->sesid, __entry->tid, __entry->lease_key_high,
891 __entry->lease_key_low, __entry->lease_state, __entry->rc)
892)
893
894#define DEFINE_SMB3_LEASE_ERR_EVENT(name) \
895DEFINE_EVENT(smb3_lease_err_class, smb3_##name, \
896 TP_PROTO(__u32 lease_state, \
897 __u32 tid, \
898 __u64 sesid, \
899 __u64 lease_key_low, \
900 __u64 lease_key_high, \
901 int rc), \
902 TP_ARGS(lease_state, tid, sesid, lease_key_low, lease_key_high, rc))
903
904DEFINE_SMB3_LEASE_ERR_EVENT(lease_err);
905
Steve Frenchd7171cd2021-11-04 15:56:37 -0500906DECLARE_EVENT_CLASS(smb3_connect_class,
907 TP_PROTO(char *hostname,
908 __u64 conn_id,
909 const struct __kernel_sockaddr_storage *dst_addr),
910 TP_ARGS(hostname, conn_id, dst_addr),
911 TP_STRUCT__entry(
912 __string(hostname, hostname)
913 __field(__u64, conn_id)
914 __array(__u8, dst_addr, sizeof(struct sockaddr_storage))
915 ),
916 TP_fast_assign(
917 struct sockaddr_storage *pss = NULL;
918
919 __entry->conn_id = conn_id;
920 pss = (struct sockaddr_storage *)__entry->dst_addr;
921 *pss = *dst_addr;
922 __assign_str(hostname, hostname);
923 ),
924 TP_printk("conn_id=0x%llx server=%s addr=%pISpsfc",
925 __entry->conn_id,
926 __get_str(hostname),
927 __entry->dst_addr)
928)
929
930#define DEFINE_SMB3_CONNECT_EVENT(name) \
931DEFINE_EVENT(smb3_connect_class, smb3_##name, \
932 TP_PROTO(char *hostname, \
933 __u64 conn_id, \
934 const struct __kernel_sockaddr_storage *addr), \
935 TP_ARGS(hostname, conn_id, addr))
936
937DEFINE_SMB3_CONNECT_EVENT(connect_done);
938
939DECLARE_EVENT_CLASS(smb3_connect_err_class,
940 TP_PROTO(char *hostname, __u64 conn_id,
941 const struct __kernel_sockaddr_storage *dst_addr, int rc),
942 TP_ARGS(hostname, conn_id, dst_addr, rc),
943 TP_STRUCT__entry(
944 __string(hostname, hostname)
945 __field(__u64, conn_id)
946 __array(__u8, dst_addr, sizeof(struct sockaddr_storage))
947 __field(int, rc)
948 ),
949 TP_fast_assign(
950 struct sockaddr_storage *pss = NULL;
951
952 __entry->conn_id = conn_id;
953 __entry->rc = rc;
954 pss = (struct sockaddr_storage *)__entry->dst_addr;
955 *pss = *dst_addr;
956 __assign_str(hostname, hostname);
957 ),
958 TP_printk("rc=%d conn_id=0x%llx server=%s addr=%pISpsfc",
959 __entry->rc,
960 __entry->conn_id,
961 __get_str(hostname),
962 __entry->dst_addr)
963)
964
965#define DEFINE_SMB3_CONNECT_ERR_EVENT(name) \
966DEFINE_EVENT(smb3_connect_err_class, smb3_##name, \
967 TP_PROTO(char *hostname, \
968 __u64 conn_id, \
969 const struct __kernel_sockaddr_storage *addr, \
970 int rc), \
971 TP_ARGS(hostname, conn_id, addr, rc))
972
973DEFINE_SMB3_CONNECT_ERR_EVENT(connect_err);
974
Steve Frenchbf1fdeb2018-07-30 19:23:09 -0500975DECLARE_EVENT_CLASS(smb3_reconnect_class,
976 TP_PROTO(__u64 currmid,
Shyam Prasad N6d82c272021-02-03 23:20:46 -0800977 __u64 conn_id,
Steve Frenchbf1fdeb2018-07-30 19:23:09 -0500978 char *hostname),
Shyam Prasad N6d82c272021-02-03 23:20:46 -0800979 TP_ARGS(currmid, conn_id, hostname),
Steve Frenchbf1fdeb2018-07-30 19:23:09 -0500980 TP_STRUCT__entry(
981 __field(__u64, currmid)
Shyam Prasad N6d82c272021-02-03 23:20:46 -0800982 __field(__u64, conn_id)
Shyam Prasad Neb068812021-05-21 06:35:52 +0000983 __string(hostname, hostname)
Steve Frenchbf1fdeb2018-07-30 19:23:09 -0500984 ),
985 TP_fast_assign(
986 __entry->currmid = currmid;
Shyam Prasad N6d82c272021-02-03 23:20:46 -0800987 __entry->conn_id = conn_id;
Shyam Prasad Neb068812021-05-21 06:35:52 +0000988 __assign_str(hostname, hostname);
Steve Frenchbf1fdeb2018-07-30 19:23:09 -0500989 ),
Shyam Prasad N6d82c272021-02-03 23:20:46 -0800990 TP_printk("conn_id=0x%llx server=%s current_mid=%llu",
991 __entry->conn_id,
Shyam Prasad Neb068812021-05-21 06:35:52 +0000992 __get_str(hostname),
Steve Frenchbf1fdeb2018-07-30 19:23:09 -0500993 __entry->currmid)
994)
995
996#define DEFINE_SMB3_RECONNECT_EVENT(name) \
997DEFINE_EVENT(smb3_reconnect_class, smb3_##name, \
998 TP_PROTO(__u64 currmid, \
Shyam Prasad N6d82c272021-02-03 23:20:46 -0800999 __u64 conn_id, \
1000 char *hostname), \
1001 TP_ARGS(currmid, conn_id, hostname))
Steve Frenchbf1fdeb2018-07-30 19:23:09 -05001002
1003DEFINE_SMB3_RECONNECT_EVENT(reconnect);
1004DEFINE_SMB3_RECONNECT_EVENT(partial_send_reconnect);
1005
Steve Frenchb340a4d2018-09-01 01:10:17 -05001006DECLARE_EVENT_CLASS(smb3_credit_class,
1007 TP_PROTO(__u64 currmid,
Shyam Prasad N6d82c272021-02-03 23:20:46 -08001008 __u64 conn_id,
Steve Frenchb340a4d2018-09-01 01:10:17 -05001009 char *hostname,
Steve French9eec21b2020-10-19 18:18:15 -05001010 int credits,
Shyam Prasad N6d82c272021-02-03 23:20:46 -08001011 int credits_to_add,
1012 int in_flight),
1013 TP_ARGS(currmid, conn_id, hostname, credits, credits_to_add, in_flight),
Steve Frenchb340a4d2018-09-01 01:10:17 -05001014 TP_STRUCT__entry(
1015 __field(__u64, currmid)
Shyam Prasad N6d82c272021-02-03 23:20:46 -08001016 __field(__u64, conn_id)
Shyam Prasad Neb068812021-05-21 06:35:52 +00001017 __string(hostname, hostname)
Steve Frenchb340a4d2018-09-01 01:10:17 -05001018 __field(int, credits)
Steve French9eec21b2020-10-19 18:18:15 -05001019 __field(int, credits_to_add)
Shyam Prasad N6d82c272021-02-03 23:20:46 -08001020 __field(int, in_flight)
Steve Frenchb340a4d2018-09-01 01:10:17 -05001021 ),
1022 TP_fast_assign(
1023 __entry->currmid = currmid;
Shyam Prasad N6d82c272021-02-03 23:20:46 -08001024 __entry->conn_id = conn_id;
Shyam Prasad Neb068812021-05-21 06:35:52 +00001025 __assign_str(hostname, hostname);
Steve Frenchb340a4d2018-09-01 01:10:17 -05001026 __entry->credits = credits;
Steve French9eec21b2020-10-19 18:18:15 -05001027 __entry->credits_to_add = credits_to_add;
Shyam Prasad N6d82c272021-02-03 23:20:46 -08001028 __entry->in_flight = in_flight;
Steve Frenchb340a4d2018-09-01 01:10:17 -05001029 ),
Shyam Prasad N6d82c272021-02-03 23:20:46 -08001030 TP_printk("conn_id=0x%llx server=%s current_mid=%llu "
1031 "credits=%d credit_change=%d in_flight=%d",
1032 __entry->conn_id,
Shyam Prasad Neb068812021-05-21 06:35:52 +00001033 __get_str(hostname),
Steve Frenchb340a4d2018-09-01 01:10:17 -05001034 __entry->currmid,
Steve French9eec21b2020-10-19 18:18:15 -05001035 __entry->credits,
Shyam Prasad N6d82c272021-02-03 23:20:46 -08001036 __entry->credits_to_add,
1037 __entry->in_flight)
Steve Frenchb340a4d2018-09-01 01:10:17 -05001038)
1039
1040#define DEFINE_SMB3_CREDIT_EVENT(name) \
1041DEFINE_EVENT(smb3_credit_class, smb3_##name, \
1042 TP_PROTO(__u64 currmid, \
Shyam Prasad N6d82c272021-02-03 23:20:46 -08001043 __u64 conn_id, \
Steve Frenchb340a4d2018-09-01 01:10:17 -05001044 char *hostname, \
Steve French9eec21b2020-10-19 18:18:15 -05001045 int credits, \
Shyam Prasad N6d82c272021-02-03 23:20:46 -08001046 int credits_to_add, \
1047 int in_flight), \
1048 TP_ARGS(currmid, conn_id, hostname, credits, credits_to_add, in_flight))
Steve Frenchb340a4d2018-09-01 01:10:17 -05001049
1050DEFINE_SMB3_CREDIT_EVENT(reconnect_with_invalid_credits);
Shyam Prasad Ncd7b6992020-11-12 08:56:49 -08001051DEFINE_SMB3_CREDIT_EVENT(reconnect_detected);
Steve French7937ca92019-03-09 20:29:55 -06001052DEFINE_SMB3_CREDIT_EVENT(credit_timeout);
Shyam Prasad Ncd7b6992020-11-12 08:56:49 -08001053DEFINE_SMB3_CREDIT_EVENT(insufficient_credits);
1054DEFINE_SMB3_CREDIT_EVENT(too_many_credits);
Steve French9eec21b2020-10-19 18:18:15 -05001055DEFINE_SMB3_CREDIT_EVENT(add_credits);
David Howells1ddff772022-03-17 14:28:34 +00001056DEFINE_SMB3_CREDIT_EVENT(adj_credits);
1057DEFINE_SMB3_CREDIT_EVENT(hdr_credits);
1058DEFINE_SMB3_CREDIT_EVENT(nblk_credits);
1059DEFINE_SMB3_CREDIT_EVENT(pend_credits);
1060DEFINE_SMB3_CREDIT_EVENT(wait_credits);
1061DEFINE_SMB3_CREDIT_EVENT(waitff_credits);
1062DEFINE_SMB3_CREDIT_EVENT(overflow_credits);
Shyam Prasad Ncd7b6992020-11-12 08:56:49 -08001063DEFINE_SMB3_CREDIT_EVENT(set_credits);
Steve Frenchb340a4d2018-09-01 01:10:17 -05001064
Steve Frencheccb4422018-05-17 21:16:55 -05001065#endif /* _CIFS_TRACE_H */
1066
1067#undef TRACE_INCLUDE_PATH
1068#define TRACE_INCLUDE_PATH .
1069#define TRACE_INCLUDE_FILE trace
1070#include <trace/define_trace.h>