| .. | .. |
|---|
| 3 | 3 | * Copyright (C) 2018, Microsoft Corporation. |
|---|
| 4 | 4 | * |
|---|
| 5 | 5 | * Author(s): Steve French <stfrench@microsoft.com> |
|---|
| 6 | | - * |
|---|
| 7 | | - * This program is free software; you can redistribute it and/or modify |
|---|
| 8 | | - * it under the terms of the GNU General Public License as published by |
|---|
| 9 | | - * the Free Software Foundation; either version 2 of the License, or |
|---|
| 10 | | - * (at your option) any later version. |
|---|
| 11 | | - * |
|---|
| 12 | | - * This program is distributed in the hope that it will be useful, |
|---|
| 13 | | - * but WITHOUT ANY WARRANTY; without even the implied warranty of |
|---|
| 14 | | - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See |
|---|
| 15 | | - * the GNU General Public License for more details. |
|---|
| 16 | 6 | */ |
|---|
| 17 | 7 | #undef TRACE_SYSTEM |
|---|
| 18 | 8 | #define TRACE_SYSTEM cifs |
|---|
| .. | .. |
|---|
| 68 | 58 | |
|---|
| 69 | 59 | DEFINE_SMB3_RW_ERR_EVENT(write_err); |
|---|
| 70 | 60 | DEFINE_SMB3_RW_ERR_EVENT(read_err); |
|---|
| 61 | +DEFINE_SMB3_RW_ERR_EVENT(query_dir_err); |
|---|
| 62 | +DEFINE_SMB3_RW_ERR_EVENT(zero_err); |
|---|
| 63 | +DEFINE_SMB3_RW_ERR_EVENT(falloc_err); |
|---|
| 71 | 64 | |
|---|
| 72 | 65 | |
|---|
| 73 | 66 | /* For logging successful read or write */ |
|---|
| .. | .. |
|---|
| 110 | 103 | __u32 len), \ |
|---|
| 111 | 104 | TP_ARGS(xid, fid, tid, sesid, offset, len)) |
|---|
| 112 | 105 | |
|---|
| 106 | +DEFINE_SMB3_RW_DONE_EVENT(write_enter); |
|---|
| 107 | +DEFINE_SMB3_RW_DONE_EVENT(read_enter); |
|---|
| 108 | +DEFINE_SMB3_RW_DONE_EVENT(query_dir_enter); |
|---|
| 109 | +DEFINE_SMB3_RW_DONE_EVENT(zero_enter); |
|---|
| 110 | +DEFINE_SMB3_RW_DONE_EVENT(falloc_enter); |
|---|
| 113 | 111 | DEFINE_SMB3_RW_DONE_EVENT(write_done); |
|---|
| 114 | 112 | DEFINE_SMB3_RW_DONE_EVENT(read_done); |
|---|
| 113 | +DEFINE_SMB3_RW_DONE_EVENT(query_dir_done); |
|---|
| 114 | +DEFINE_SMB3_RW_DONE_EVENT(zero_done); |
|---|
| 115 | +DEFINE_SMB3_RW_DONE_EVENT(falloc_done); |
|---|
| 115 | 116 | |
|---|
| 116 | 117 | /* |
|---|
| 117 | 118 | * For handle based calls other than read and write, and get/set info |
|---|
| 118 | 119 | */ |
|---|
| 120 | +DECLARE_EVENT_CLASS(smb3_fd_class, |
|---|
| 121 | + TP_PROTO(unsigned int xid, |
|---|
| 122 | + __u64 fid, |
|---|
| 123 | + __u32 tid, |
|---|
| 124 | + __u64 sesid), |
|---|
| 125 | + TP_ARGS(xid, fid, tid, sesid), |
|---|
| 126 | + TP_STRUCT__entry( |
|---|
| 127 | + __field(unsigned int, xid) |
|---|
| 128 | + __field(__u64, fid) |
|---|
| 129 | + __field(__u32, tid) |
|---|
| 130 | + __field(__u64, sesid) |
|---|
| 131 | + ), |
|---|
| 132 | + TP_fast_assign( |
|---|
| 133 | + __entry->xid = xid; |
|---|
| 134 | + __entry->fid = fid; |
|---|
| 135 | + __entry->tid = tid; |
|---|
| 136 | + __entry->sesid = sesid; |
|---|
| 137 | + ), |
|---|
| 138 | + TP_printk("\txid=%u sid=0x%llx tid=0x%x fid=0x%llx", |
|---|
| 139 | + __entry->xid, __entry->sesid, __entry->tid, __entry->fid) |
|---|
| 140 | +) |
|---|
| 141 | + |
|---|
| 142 | +#define DEFINE_SMB3_FD_EVENT(name) \ |
|---|
| 143 | +DEFINE_EVENT(smb3_fd_class, smb3_##name, \ |
|---|
| 144 | + TP_PROTO(unsigned int xid, \ |
|---|
| 145 | + __u64 fid, \ |
|---|
| 146 | + __u32 tid, \ |
|---|
| 147 | + __u64 sesid), \ |
|---|
| 148 | + TP_ARGS(xid, fid, tid, sesid)) |
|---|
| 149 | + |
|---|
| 150 | +DEFINE_SMB3_FD_EVENT(flush_enter); |
|---|
| 151 | +DEFINE_SMB3_FD_EVENT(flush_done); |
|---|
| 152 | +DEFINE_SMB3_FD_EVENT(close_enter); |
|---|
| 153 | +DEFINE_SMB3_FD_EVENT(close_done); |
|---|
| 154 | + |
|---|
| 119 | 155 | DECLARE_EVENT_CLASS(smb3_fd_err_class, |
|---|
| 120 | 156 | TP_PROTO(unsigned int xid, |
|---|
| 121 | 157 | __u64 fid, |
|---|
| .. | .. |
|---|
| 158 | 194 | /* |
|---|
| 159 | 195 | * For handle based query/set info calls |
|---|
| 160 | 196 | */ |
|---|
| 197 | +DECLARE_EVENT_CLASS(smb3_inf_enter_class, |
|---|
| 198 | + TP_PROTO(unsigned int xid, |
|---|
| 199 | + __u64 fid, |
|---|
| 200 | + __u32 tid, |
|---|
| 201 | + __u64 sesid, |
|---|
| 202 | + __u8 infclass, |
|---|
| 203 | + __u32 type), |
|---|
| 204 | + TP_ARGS(xid, fid, tid, sesid, infclass, type), |
|---|
| 205 | + TP_STRUCT__entry( |
|---|
| 206 | + __field(unsigned int, xid) |
|---|
| 207 | + __field(__u64, fid) |
|---|
| 208 | + __field(__u32, tid) |
|---|
| 209 | + __field(__u64, sesid) |
|---|
| 210 | + __field(__u8, infclass) |
|---|
| 211 | + __field(__u32, type) |
|---|
| 212 | + ), |
|---|
| 213 | + TP_fast_assign( |
|---|
| 214 | + __entry->xid = xid; |
|---|
| 215 | + __entry->fid = fid; |
|---|
| 216 | + __entry->tid = tid; |
|---|
| 217 | + __entry->sesid = sesid; |
|---|
| 218 | + __entry->infclass = infclass; |
|---|
| 219 | + __entry->type = type; |
|---|
| 220 | + ), |
|---|
| 221 | + TP_printk("xid=%u sid=0x%llx tid=0x%x fid=0x%llx class=%u type=0x%x", |
|---|
| 222 | + __entry->xid, __entry->sesid, __entry->tid, __entry->fid, |
|---|
| 223 | + __entry->infclass, __entry->type) |
|---|
| 224 | +) |
|---|
| 225 | + |
|---|
| 226 | +#define DEFINE_SMB3_INF_ENTER_EVENT(name) \ |
|---|
| 227 | +DEFINE_EVENT(smb3_inf_enter_class, smb3_##name, \ |
|---|
| 228 | + TP_PROTO(unsigned int xid, \ |
|---|
| 229 | + __u64 fid, \ |
|---|
| 230 | + __u32 tid, \ |
|---|
| 231 | + __u64 sesid, \ |
|---|
| 232 | + __u8 infclass, \ |
|---|
| 233 | + __u32 type), \ |
|---|
| 234 | + TP_ARGS(xid, fid, tid, sesid, infclass, type)) |
|---|
| 235 | + |
|---|
| 236 | +DEFINE_SMB3_INF_ENTER_EVENT(query_info_enter); |
|---|
| 237 | +DEFINE_SMB3_INF_ENTER_EVENT(query_info_done); |
|---|
| 238 | +DEFINE_SMB3_INF_ENTER_EVENT(notify_enter); |
|---|
| 239 | +DEFINE_SMB3_INF_ENTER_EVENT(notify_done); |
|---|
| 240 | + |
|---|
| 161 | 241 | DECLARE_EVENT_CLASS(smb3_inf_err_class, |
|---|
| 162 | 242 | TP_PROTO(unsigned int xid, |
|---|
| 163 | 243 | __u64 fid, |
|---|
| .. | .. |
|---|
| 203 | 283 | |
|---|
| 204 | 284 | DEFINE_SMB3_INF_ERR_EVENT(query_info_err); |
|---|
| 205 | 285 | DEFINE_SMB3_INF_ERR_EVENT(set_info_err); |
|---|
| 286 | +DEFINE_SMB3_INF_ERR_EVENT(notify_err); |
|---|
| 206 | 287 | DEFINE_SMB3_INF_ERR_EVENT(fsctl_err); |
|---|
| 288 | + |
|---|
| 289 | +DECLARE_EVENT_CLASS(smb3_inf_compound_enter_class, |
|---|
| 290 | + TP_PROTO(unsigned int xid, |
|---|
| 291 | + __u32 tid, |
|---|
| 292 | + __u64 sesid, |
|---|
| 293 | + const char *full_path), |
|---|
| 294 | + TP_ARGS(xid, tid, sesid, full_path), |
|---|
| 295 | + TP_STRUCT__entry( |
|---|
| 296 | + __field(unsigned int, xid) |
|---|
| 297 | + __field(__u32, tid) |
|---|
| 298 | + __field(__u64, sesid) |
|---|
| 299 | + __string(path, full_path) |
|---|
| 300 | + ), |
|---|
| 301 | + TP_fast_assign( |
|---|
| 302 | + __entry->xid = xid; |
|---|
| 303 | + __entry->tid = tid; |
|---|
| 304 | + __entry->sesid = sesid; |
|---|
| 305 | + __assign_str(path, full_path); |
|---|
| 306 | + ), |
|---|
| 307 | + TP_printk("xid=%u sid=0x%llx tid=0x%x path=%s", |
|---|
| 308 | + __entry->xid, __entry->sesid, __entry->tid, |
|---|
| 309 | + __get_str(path)) |
|---|
| 310 | +) |
|---|
| 311 | + |
|---|
| 312 | +#define DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(name) \ |
|---|
| 313 | +DEFINE_EVENT(smb3_inf_compound_enter_class, smb3_##name, \ |
|---|
| 314 | + TP_PROTO(unsigned int xid, \ |
|---|
| 315 | + __u32 tid, \ |
|---|
| 316 | + __u64 sesid, \ |
|---|
| 317 | + const char *full_path), \ |
|---|
| 318 | + TP_ARGS(xid, tid, sesid, full_path)) |
|---|
| 319 | + |
|---|
| 320 | +DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(query_info_compound_enter); |
|---|
| 321 | +DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(posix_query_info_compound_enter); |
|---|
| 322 | +DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(hardlink_enter); |
|---|
| 323 | +DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(rename_enter); |
|---|
| 324 | +DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(rmdir_enter); |
|---|
| 325 | +DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(set_eof_enter); |
|---|
| 326 | +DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(set_info_compound_enter); |
|---|
| 327 | +DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(delete_enter); |
|---|
| 328 | +DEFINE_SMB3_INF_COMPOUND_ENTER_EVENT(mkdir_enter); |
|---|
| 329 | + |
|---|
| 330 | + |
|---|
| 331 | +DECLARE_EVENT_CLASS(smb3_inf_compound_done_class, |
|---|
| 332 | + TP_PROTO(unsigned int xid, |
|---|
| 333 | + __u32 tid, |
|---|
| 334 | + __u64 sesid), |
|---|
| 335 | + TP_ARGS(xid, tid, sesid), |
|---|
| 336 | + TP_STRUCT__entry( |
|---|
| 337 | + __field(unsigned int, xid) |
|---|
| 338 | + __field(__u32, tid) |
|---|
| 339 | + __field(__u64, sesid) |
|---|
| 340 | + ), |
|---|
| 341 | + TP_fast_assign( |
|---|
| 342 | + __entry->xid = xid; |
|---|
| 343 | + __entry->tid = tid; |
|---|
| 344 | + __entry->sesid = sesid; |
|---|
| 345 | + ), |
|---|
| 346 | + TP_printk("xid=%u sid=0x%llx tid=0x%x", |
|---|
| 347 | + __entry->xid, __entry->sesid, __entry->tid) |
|---|
| 348 | +) |
|---|
| 349 | + |
|---|
| 350 | +#define DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(name) \ |
|---|
| 351 | +DEFINE_EVENT(smb3_inf_compound_done_class, smb3_##name, \ |
|---|
| 352 | + TP_PROTO(unsigned int xid, \ |
|---|
| 353 | + __u32 tid, \ |
|---|
| 354 | + __u64 sesid), \ |
|---|
| 355 | + TP_ARGS(xid, tid, sesid)) |
|---|
| 356 | + |
|---|
| 357 | +DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(query_info_compound_done); |
|---|
| 358 | +DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(posix_query_info_compound_done); |
|---|
| 359 | +DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(hardlink_done); |
|---|
| 360 | +DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(rename_done); |
|---|
| 361 | +DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(rmdir_done); |
|---|
| 362 | +DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(set_eof_done); |
|---|
| 363 | +DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(set_info_compound_done); |
|---|
| 364 | +DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(delete_done); |
|---|
| 365 | +DEFINE_SMB3_INF_COMPOUND_DONE_EVENT(mkdir_done); |
|---|
| 366 | + |
|---|
| 367 | + |
|---|
| 368 | +DECLARE_EVENT_CLASS(smb3_inf_compound_err_class, |
|---|
| 369 | + TP_PROTO(unsigned int xid, |
|---|
| 370 | + __u32 tid, |
|---|
| 371 | + __u64 sesid, |
|---|
| 372 | + int rc), |
|---|
| 373 | + TP_ARGS(xid, tid, sesid, rc), |
|---|
| 374 | + TP_STRUCT__entry( |
|---|
| 375 | + __field(unsigned int, xid) |
|---|
| 376 | + __field(__u32, tid) |
|---|
| 377 | + __field(__u64, sesid) |
|---|
| 378 | + __field(int, rc) |
|---|
| 379 | + ), |
|---|
| 380 | + TP_fast_assign( |
|---|
| 381 | + __entry->xid = xid; |
|---|
| 382 | + __entry->tid = tid; |
|---|
| 383 | + __entry->sesid = sesid; |
|---|
| 384 | + __entry->rc = rc; |
|---|
| 385 | + ), |
|---|
| 386 | + TP_printk("xid=%u sid=0x%llx tid=0x%x rc=%d", |
|---|
| 387 | + __entry->xid, __entry->sesid, __entry->tid, |
|---|
| 388 | + __entry->rc) |
|---|
| 389 | +) |
|---|
| 390 | + |
|---|
| 391 | +#define DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(name) \ |
|---|
| 392 | +DEFINE_EVENT(smb3_inf_compound_err_class, smb3_##name, \ |
|---|
| 393 | + TP_PROTO(unsigned int xid, \ |
|---|
| 394 | + __u32 tid, \ |
|---|
| 395 | + __u64 sesid, \ |
|---|
| 396 | + int rc), \ |
|---|
| 397 | + TP_ARGS(xid, tid, sesid, rc)) |
|---|
| 398 | + |
|---|
| 399 | +DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(query_info_compound_err); |
|---|
| 400 | +DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(posix_query_info_compound_err); |
|---|
| 401 | +DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(hardlink_err); |
|---|
| 402 | +DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(rename_err); |
|---|
| 403 | +DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(rmdir_err); |
|---|
| 404 | +DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(set_eof_err); |
|---|
| 405 | +DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(set_info_compound_err); |
|---|
| 406 | +DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(mkdir_err); |
|---|
| 407 | +DEFINE_SMB3_INF_COMPOUND_ERR_EVENT(delete_err); |
|---|
| 207 | 408 | |
|---|
| 208 | 409 | /* |
|---|
| 209 | 410 | * For logging SMB3 Status code and Command for responses which return errors |
|---|
| .. | .. |
|---|
| 280 | 481 | __u64 mid), \ |
|---|
| 281 | 482 | TP_ARGS(tid, sesid, cmd, mid)) |
|---|
| 282 | 483 | |
|---|
| 484 | +DEFINE_SMB3_CMD_DONE_EVENT(cmd_enter); |
|---|
| 283 | 485 | DEFINE_SMB3_CMD_DONE_EVENT(cmd_done); |
|---|
| 284 | 486 | DEFINE_SMB3_CMD_DONE_EVENT(ses_expired); |
|---|
| 285 | 487 | |
|---|
| .. | .. |
|---|
| 348 | 550 | |
|---|
| 349 | 551 | DEFINE_SMB3_EXIT_ERR_EVENT(exit_err); |
|---|
| 350 | 552 | |
|---|
| 553 | + |
|---|
| 554 | +DECLARE_EVENT_CLASS(smb3_sync_err_class, |
|---|
| 555 | + TP_PROTO(unsigned long ino, |
|---|
| 556 | + int rc), |
|---|
| 557 | + TP_ARGS(ino, rc), |
|---|
| 558 | + TP_STRUCT__entry( |
|---|
| 559 | + __field(unsigned long, ino) |
|---|
| 560 | + __field(int, rc) |
|---|
| 561 | + ), |
|---|
| 562 | + TP_fast_assign( |
|---|
| 563 | + __entry->ino = ino; |
|---|
| 564 | + __entry->rc = rc; |
|---|
| 565 | + ), |
|---|
| 566 | + TP_printk("\tino=%lu rc=%d", |
|---|
| 567 | + __entry->ino, __entry->rc) |
|---|
| 568 | +) |
|---|
| 569 | + |
|---|
| 570 | +#define DEFINE_SMB3_SYNC_ERR_EVENT(name) \ |
|---|
| 571 | +DEFINE_EVENT(smb3_sync_err_class, cifs_##name, \ |
|---|
| 572 | + TP_PROTO(unsigned long ino, \ |
|---|
| 573 | + int rc), \ |
|---|
| 574 | + TP_ARGS(ino, rc)) |
|---|
| 575 | + |
|---|
| 576 | +DEFINE_SMB3_SYNC_ERR_EVENT(fsync_err); |
|---|
| 577 | +DEFINE_SMB3_SYNC_ERR_EVENT(flush_err); |
|---|
| 578 | + |
|---|
| 579 | + |
|---|
| 351 | 580 | DECLARE_EVENT_CLASS(smb3_enter_exit_class, |
|---|
| 352 | 581 | TP_PROTO(unsigned int xid, |
|---|
| 353 | 582 | const char *func_name), |
|---|
| .. | .. |
|---|
| 374 | 603 | DEFINE_SMB3_ENTER_EXIT_EVENT(exit_done); |
|---|
| 375 | 604 | |
|---|
| 376 | 605 | /* |
|---|
| 377 | | - * For smb2/smb3 open call |
|---|
| 606 | + * For SMB2/SMB3 tree connect |
|---|
| 378 | 607 | */ |
|---|
| 608 | + |
|---|
| 609 | +DECLARE_EVENT_CLASS(smb3_tcon_class, |
|---|
| 610 | + TP_PROTO(unsigned int xid, |
|---|
| 611 | + __u32 tid, |
|---|
| 612 | + __u64 sesid, |
|---|
| 613 | + const char *unc_name, |
|---|
| 614 | + int rc), |
|---|
| 615 | + TP_ARGS(xid, tid, sesid, unc_name, rc), |
|---|
| 616 | + TP_STRUCT__entry( |
|---|
| 617 | + __field(unsigned int, xid) |
|---|
| 618 | + __field(__u32, tid) |
|---|
| 619 | + __field(__u64, sesid) |
|---|
| 620 | + __string(name, unc_name) |
|---|
| 621 | + __field(int, rc) |
|---|
| 622 | + ), |
|---|
| 623 | + TP_fast_assign( |
|---|
| 624 | + __entry->xid = xid; |
|---|
| 625 | + __entry->tid = tid; |
|---|
| 626 | + __entry->sesid = sesid; |
|---|
| 627 | + __assign_str(name, unc_name); |
|---|
| 628 | + __entry->rc = rc; |
|---|
| 629 | + ), |
|---|
| 630 | + TP_printk("xid=%u sid=0x%llx tid=0x%x unc_name=%s rc=%d", |
|---|
| 631 | + __entry->xid, __entry->sesid, __entry->tid, |
|---|
| 632 | + __get_str(name), __entry->rc) |
|---|
| 633 | +) |
|---|
| 634 | + |
|---|
| 635 | +#define DEFINE_SMB3_TCON_EVENT(name) \ |
|---|
| 636 | +DEFINE_EVENT(smb3_tcon_class, smb3_##name, \ |
|---|
| 637 | + TP_PROTO(unsigned int xid, \ |
|---|
| 638 | + __u32 tid, \ |
|---|
| 639 | + __u64 sesid, \ |
|---|
| 640 | + const char *unc_name, \ |
|---|
| 641 | + int rc), \ |
|---|
| 642 | + TP_ARGS(xid, tid, sesid, unc_name, rc)) |
|---|
| 643 | + |
|---|
| 644 | +DEFINE_SMB3_TCON_EVENT(tcon); |
|---|
| 645 | + |
|---|
| 646 | + |
|---|
| 647 | +/* |
|---|
| 648 | + * For smb2/smb3 open (including create and mkdir) calls |
|---|
| 649 | + */ |
|---|
| 650 | + |
|---|
| 651 | +DECLARE_EVENT_CLASS(smb3_open_enter_class, |
|---|
| 652 | + TP_PROTO(unsigned int xid, |
|---|
| 653 | + __u32 tid, |
|---|
| 654 | + __u64 sesid, |
|---|
| 655 | + int create_options, |
|---|
| 656 | + int desired_access), |
|---|
| 657 | + TP_ARGS(xid, tid, sesid, create_options, desired_access), |
|---|
| 658 | + TP_STRUCT__entry( |
|---|
| 659 | + __field(unsigned int, xid) |
|---|
| 660 | + __field(__u32, tid) |
|---|
| 661 | + __field(__u64, sesid) |
|---|
| 662 | + __field(int, create_options) |
|---|
| 663 | + __field(int, desired_access) |
|---|
| 664 | + ), |
|---|
| 665 | + TP_fast_assign( |
|---|
| 666 | + __entry->xid = xid; |
|---|
| 667 | + __entry->tid = tid; |
|---|
| 668 | + __entry->sesid = sesid; |
|---|
| 669 | + __entry->create_options = create_options; |
|---|
| 670 | + __entry->desired_access = desired_access; |
|---|
| 671 | + ), |
|---|
| 672 | + TP_printk("xid=%u sid=0x%llx tid=0x%x cr_opts=0x%x des_access=0x%x", |
|---|
| 673 | + __entry->xid, __entry->sesid, __entry->tid, |
|---|
| 674 | + __entry->create_options, __entry->desired_access) |
|---|
| 675 | +) |
|---|
| 676 | + |
|---|
| 677 | +#define DEFINE_SMB3_OPEN_ENTER_EVENT(name) \ |
|---|
| 678 | +DEFINE_EVENT(smb3_open_enter_class, smb3_##name, \ |
|---|
| 679 | + TP_PROTO(unsigned int xid, \ |
|---|
| 680 | + __u32 tid, \ |
|---|
| 681 | + __u64 sesid, \ |
|---|
| 682 | + int create_options, \ |
|---|
| 683 | + int desired_access), \ |
|---|
| 684 | + TP_ARGS(xid, tid, sesid, create_options, desired_access)) |
|---|
| 685 | + |
|---|
| 686 | +DEFINE_SMB3_OPEN_ENTER_EVENT(open_enter); |
|---|
| 687 | +DEFINE_SMB3_OPEN_ENTER_EVENT(posix_mkdir_enter); |
|---|
| 688 | + |
|---|
| 379 | 689 | DECLARE_EVENT_CLASS(smb3_open_err_class, |
|---|
| 380 | 690 | TP_PROTO(unsigned int xid, |
|---|
| 381 | 691 | __u32 tid, |
|---|
| .. | .. |
|---|
| 460 | 770 | DEFINE_SMB3_OPEN_DONE_EVENT(open_done); |
|---|
| 461 | 771 | DEFINE_SMB3_OPEN_DONE_EVENT(posix_mkdir_done); |
|---|
| 462 | 772 | |
|---|
| 773 | + |
|---|
| 774 | +DECLARE_EVENT_CLASS(smb3_lease_done_class, |
|---|
| 775 | + TP_PROTO(__u32 lease_state, |
|---|
| 776 | + __u32 tid, |
|---|
| 777 | + __u64 sesid, |
|---|
| 778 | + __u64 lease_key_low, |
|---|
| 779 | + __u64 lease_key_high), |
|---|
| 780 | + TP_ARGS(lease_state, tid, sesid, lease_key_low, lease_key_high), |
|---|
| 781 | + TP_STRUCT__entry( |
|---|
| 782 | + __field(__u32, lease_state) |
|---|
| 783 | + __field(__u32, tid) |
|---|
| 784 | + __field(__u64, sesid) |
|---|
| 785 | + __field(__u64, lease_key_low) |
|---|
| 786 | + __field(__u64, lease_key_high) |
|---|
| 787 | + ), |
|---|
| 788 | + TP_fast_assign( |
|---|
| 789 | + __entry->lease_state = lease_state; |
|---|
| 790 | + __entry->tid = tid; |
|---|
| 791 | + __entry->sesid = sesid; |
|---|
| 792 | + __entry->lease_key_low = lease_key_low; |
|---|
| 793 | + __entry->lease_key_high = lease_key_high; |
|---|
| 794 | + ), |
|---|
| 795 | + TP_printk("sid=0x%llx tid=0x%x lease_key=0x%llx%llx lease_state=0x%x", |
|---|
| 796 | + __entry->sesid, __entry->tid, __entry->lease_key_high, |
|---|
| 797 | + __entry->lease_key_low, __entry->lease_state) |
|---|
| 798 | +) |
|---|
| 799 | + |
|---|
| 800 | +#define DEFINE_SMB3_LEASE_DONE_EVENT(name) \ |
|---|
| 801 | +DEFINE_EVENT(smb3_lease_done_class, smb3_##name, \ |
|---|
| 802 | + TP_PROTO(__u32 lease_state, \ |
|---|
| 803 | + __u32 tid, \ |
|---|
| 804 | + __u64 sesid, \ |
|---|
| 805 | + __u64 lease_key_low, \ |
|---|
| 806 | + __u64 lease_key_high), \ |
|---|
| 807 | + TP_ARGS(lease_state, tid, sesid, lease_key_low, lease_key_high)) |
|---|
| 808 | + |
|---|
| 809 | +DEFINE_SMB3_LEASE_DONE_EVENT(lease_done); |
|---|
| 810 | + |
|---|
| 811 | +DECLARE_EVENT_CLASS(smb3_lease_err_class, |
|---|
| 812 | + TP_PROTO(__u32 lease_state, |
|---|
| 813 | + __u32 tid, |
|---|
| 814 | + __u64 sesid, |
|---|
| 815 | + __u64 lease_key_low, |
|---|
| 816 | + __u64 lease_key_high, |
|---|
| 817 | + int rc), |
|---|
| 818 | + TP_ARGS(lease_state, tid, sesid, lease_key_low, lease_key_high, rc), |
|---|
| 819 | + TP_STRUCT__entry( |
|---|
| 820 | + __field(__u32, lease_state) |
|---|
| 821 | + __field(__u32, tid) |
|---|
| 822 | + __field(__u64, sesid) |
|---|
| 823 | + __field(__u64, lease_key_low) |
|---|
| 824 | + __field(__u64, lease_key_high) |
|---|
| 825 | + __field(int, rc) |
|---|
| 826 | + ), |
|---|
| 827 | + TP_fast_assign( |
|---|
| 828 | + __entry->lease_state = lease_state; |
|---|
| 829 | + __entry->tid = tid; |
|---|
| 830 | + __entry->sesid = sesid; |
|---|
| 831 | + __entry->lease_key_low = lease_key_low; |
|---|
| 832 | + __entry->lease_key_high = lease_key_high; |
|---|
| 833 | + __entry->rc = rc; |
|---|
| 834 | + ), |
|---|
| 835 | + TP_printk("sid=0x%llx tid=0x%x lease_key=0x%llx%llx lease_state=0x%x rc=%d", |
|---|
| 836 | + __entry->sesid, __entry->tid, __entry->lease_key_high, |
|---|
| 837 | + __entry->lease_key_low, __entry->lease_state, __entry->rc) |
|---|
| 838 | +) |
|---|
| 839 | + |
|---|
| 840 | +#define DEFINE_SMB3_LEASE_ERR_EVENT(name) \ |
|---|
| 841 | +DEFINE_EVENT(smb3_lease_err_class, smb3_##name, \ |
|---|
| 842 | + TP_PROTO(__u32 lease_state, \ |
|---|
| 843 | + __u32 tid, \ |
|---|
| 844 | + __u64 sesid, \ |
|---|
| 845 | + __u64 lease_key_low, \ |
|---|
| 846 | + __u64 lease_key_high, \ |
|---|
| 847 | + int rc), \ |
|---|
| 848 | + TP_ARGS(lease_state, tid, sesid, lease_key_low, lease_key_high, rc)) |
|---|
| 849 | + |
|---|
| 850 | +DEFINE_SMB3_LEASE_ERR_EVENT(lease_err); |
|---|
| 851 | + |
|---|
| 463 | 852 | DECLARE_EVENT_CLASS(smb3_reconnect_class, |
|---|
| 464 | 853 | TP_PROTO(__u64 currmid, |
|---|
| 465 | 854 | char *hostname), |
|---|
| .. | .. |
|---|
| 486 | 875 | DEFINE_SMB3_RECONNECT_EVENT(reconnect); |
|---|
| 487 | 876 | DEFINE_SMB3_RECONNECT_EVENT(partial_send_reconnect); |
|---|
| 488 | 877 | |
|---|
| 878 | +DECLARE_EVENT_CLASS(smb3_credit_class, |
|---|
| 879 | + TP_PROTO(__u64 currmid, |
|---|
| 880 | + char *hostname, |
|---|
| 881 | + int credits, |
|---|
| 882 | + int credits_to_add), |
|---|
| 883 | + TP_ARGS(currmid, hostname, credits, credits_to_add), |
|---|
| 884 | + TP_STRUCT__entry( |
|---|
| 885 | + __field(__u64, currmid) |
|---|
| 886 | + __field(char *, hostname) |
|---|
| 887 | + __field(int, credits) |
|---|
| 888 | + __field(int, credits_to_add) |
|---|
| 889 | + ), |
|---|
| 890 | + TP_fast_assign( |
|---|
| 891 | + __entry->currmid = currmid; |
|---|
| 892 | + __entry->hostname = hostname; |
|---|
| 893 | + __entry->credits = credits; |
|---|
| 894 | + __entry->credits_to_add = credits_to_add; |
|---|
| 895 | + ), |
|---|
| 896 | + TP_printk("server=%s current_mid=0x%llx credits=%d credits_to_add=%d", |
|---|
| 897 | + __entry->hostname, |
|---|
| 898 | + __entry->currmid, |
|---|
| 899 | + __entry->credits, |
|---|
| 900 | + __entry->credits_to_add) |
|---|
| 901 | +) |
|---|
| 902 | + |
|---|
| 903 | +#define DEFINE_SMB3_CREDIT_EVENT(name) \ |
|---|
| 904 | +DEFINE_EVENT(smb3_credit_class, smb3_##name, \ |
|---|
| 905 | + TP_PROTO(__u64 currmid, \ |
|---|
| 906 | + char *hostname, \ |
|---|
| 907 | + int credits, \ |
|---|
| 908 | + int credits_to_add), \ |
|---|
| 909 | + TP_ARGS(currmid, hostname, credits, credits_to_add)) |
|---|
| 910 | + |
|---|
| 911 | +DEFINE_SMB3_CREDIT_EVENT(reconnect_with_invalid_credits); |
|---|
| 912 | +DEFINE_SMB3_CREDIT_EVENT(credit_timeout); |
|---|
| 913 | +DEFINE_SMB3_CREDIT_EVENT(add_credits); |
|---|
| 914 | + |
|---|
| 489 | 915 | #endif /* _CIFS_TRACE_H */ |
|---|
| 490 | 916 | |
|---|
| 491 | 917 | #undef TRACE_INCLUDE_PATH |
|---|