diff options
Diffstat (limited to 'usr/src/cmd/smbsrv')
| -rw-r--r-- | usr/src/cmd/smbsrv/dtrace/smb-trace.d | 39 | ||||
| -rw-r--r-- | usr/src/cmd/smbsrv/dtrace/smb2-trace.d | 39 |
2 files changed, 76 insertions, 2 deletions
diff --git a/usr/src/cmd/smbsrv/dtrace/smb-trace.d b/usr/src/cmd/smbsrv/dtrace/smb-trace.d index 32162dca2b..40b3cba219 100644 --- a/usr/src/cmd/smbsrv/dtrace/smb-trace.d +++ b/usr/src/cmd/smbsrv/dtrace/smb-trace.d @@ -1,3 +1,4 @@ +#!/usr/sbin/dtrace -s /* * This file and its contents are supplied under the terms of the * Common Development and Distribution License ("CDDL"), version 1.0. @@ -10,7 +11,7 @@ */ /* - * Copyright 2017 Nexenta Systems, Inc. All rights reserved. + * Copyright 2018 Nexenta Systems, Inc. All rights reserved. */ /* @@ -24,9 +25,38 @@ * args[2] smb_name_args_t * args[2] smb_open_args_t * args[2] smb_rw_args_t + * + * Usage: smb-trace.d [<client ip>|all [<share path>|all] [<zone id>]]] + * + * example: smb_trace.d 192.168.012.001 mypool_fs1 0 + * + * It is valid to specify <client ip> or <share path> as "all" to + * print data for all clients and/or all shares. + * Omitting <zone id> will print data for all zones. */ +#pragma D option defaultargs + +dtrace:::BEGIN +{ + all_clients = (($$1 == NULL) || ($$1 == "all")) ? 1 : 0; + all_shares = (($$2 == NULL) || ($$2 == "all")) ? 1 : 0; + all_zones = ($$3 == NULL) ? 1 : 0; + + client = $$1; + share = $$2; + zoneid = $3; + + printf("%Y - client=%s share=%s zone=%s)\n", walltimestamp, + (all_clients) ? "all" : client, + (all_shares) ? "all" : share, + (all_zones) ? "all" : $$3); +} + smb:::op-*-start +/ ((all_clients) || (args[0]->ci_remote == client)) && + ((all_shares) || (args[1]->soi_share == share)) && + ((all_zones) || (args[1]->soi_zoneid == zoneid)) / { printf("clnt=%s mid=0x%x uid=0x%x tid=0x%x\n", args[0]->ci_remote, @@ -36,9 +66,16 @@ smb:::op-*-start } smb:::op-*-done +/ ((all_clients) || (args[0]->ci_remote == client)) && + ((all_shares) || (args[1]->soi_share == share)) && + ((all_zones) || (args[1]->soi_zoneid == zoneid)) / { printf("clnt=%s mid=0x%x status=0x%x\n", args[0]->ci_remote, args[1]->soi_mid, args[1]->soi_status); } + +dtrace:::END +{ +} diff --git a/usr/src/cmd/smbsrv/dtrace/smb2-trace.d b/usr/src/cmd/smbsrv/dtrace/smb2-trace.d index 4e83216785..409d878dea 100644 --- a/usr/src/cmd/smbsrv/dtrace/smb2-trace.d +++ b/usr/src/cmd/smbsrv/dtrace/smb2-trace.d @@ -1,3 +1,4 @@ +#!/usr/sbin/dtrace -s /* * This file and its contents are supplied under the terms of the * Common Development and Distribution License ("CDDL"), version 1.0. @@ -10,7 +11,7 @@ */ /* - * Copyright 2017 Nexenta Systems, Inc. All rights reserved. + * Copyright 2018 Nexenta Systems, Inc. All rights reserved. */ /* @@ -23,9 +24,38 @@ * Some also provide one of: (not used here) * args[2] smb_open_args_t * args[2] smb_rw_args_t + * + * Usage: smb2-trace.d [<client ip>|all [<share path>|all] [<zone id>]]] + * + * example: smb2_trace.d 192.168.012.001 mypool_fs1 0 + * + * It is valid to specify <client ip> or <share path> as "all" to + * print data for all clients and/or all shares. + * Omitting <zone id> will print data for all zones. */ +#pragma D option defaultargs + +dtrace:::BEGIN +{ + all_clients = (($$1 == NULL) || ($$1 == "all")) ? 1 : 0; + all_shares = (($$2 == NULL) || ($$2 == "all")) ? 1 : 0; + all_zones = ($$3 == NULL) ? 1 : 0; + + client = $$1; + share = $$2; + zoneid = $3; + + printf("%Y - client=%s share=%s zone=%s)\n", walltimestamp, + (all_clients) ? "all" : client, + (all_shares) ? "all" : share, + (all_zones) ? "all" : $$3); +} + smb2:::op-*-start +/ ((all_clients == 1) || (args[0]->ci_remote == client)) && + ((all_shares == 1) || (args[1]->soi_share == share)) && + ((all_zones == 1) || (args[1]->soi_zoneid == zoneid)) / { printf("clnt=%s mid=0x%x uid=0x%x tid=0x%x\n", args[0]->ci_remote, @@ -35,9 +65,16 @@ smb2:::op-*-start } smb2:::op-*-done +/ ((all_clients == 1) || (args[0]->ci_remote == client)) && + ((all_shares == 1) || (args[1]->soi_share == share)) && + ((all_zones == 1) || (args[1]->soi_zoneid == zoneid)) / { printf("clnt=%s mid=0x%x status=0x%x\n", args[0]->ci_remote, args[1]->soi_mid, args[1]->soi_status); } + +dtrace:::END +{ +} |
