da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw/*
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * CDDL HEADER START
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw *
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * The contents of this file are subject to the terms of the
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * Common Development and Distribution License (the "License").
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * You may not use this file except in compliance with the License.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw *
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * or http://www.opensolaris.org/os/licensing.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * See the License for the specific language governing permissions
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * and limitations under the License.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw *
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * When distributing Covered Code, include this CDDL HEADER in each
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * If applicable, add the following below this CDDL HEADER, with the
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * fields enclosed by brackets "[]" replaced with your own identifying
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * information: Portions Copyright [yyyy] [name of copyright owner]
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw *
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * CDDL HEADER END
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
41610d101ac089e52e33b0a671581e0c80d256c0Yuri Pankov
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw/*
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright * Copyright (c) 2007, 2010, Oracle and/or its affiliates. All rights reserved.
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross * Copyright 2015 Nexenta Systems, Inc. All rights reserved.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright#include <mdb/mdb_modapi.h>
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright#include <mdb/mdb_ks.h>
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright#include <sys/thread.h>
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross#include <sys/taskq.h>
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw#include <smbsrv/smb_vops.h>
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw#include <smbsrv/smb.h>
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb#include <smbsrv/smb_ktypes.h>
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross#ifdef _KERNEL
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross#define SMBSRV_OBJNAME "smbsrv"
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross#else
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross#define SMBSRV_OBJNAME "libfksmbsrv.so.1"
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross#endif
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas#define SMB_DCMD_INDENT 2
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas#define ACE_TYPE_TABLEN (ACE_ALL_TYPES + 1)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas#define ACE_TYPE_ENTRY(_v_) {_v_, #_v_}
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas#define SMB_COM_ENTRY(_v_, _x_) {#_v_, _x_}
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright#define SMB_MDB_MAX_OPTS 9
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas#define SMB_OPT_SERVER 0x00000001
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright#define SMB_OPT_SESSION 0x00000002
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright#define SMB_OPT_REQUEST 0x00000004
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright#define SMB_OPT_USER 0x00000008
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright#define SMB_OPT_TREE 0x00000010
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright#define SMB_OPT_OFILE 0x00000020
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright#define SMB_OPT_ODIR 0x00000040
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas#define SMB_OPT_WALK 0x00000100
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas#define SMB_OPT_VERBOSE 0x00000200
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas#define SMB_OPT_ALL_OBJ 0x000000FF
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * Structure associating an ACE type to a string.
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eastypedef struct {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas uint8_t ace_type_value;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas const char *ace_type_sting;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas} ace_type_entry_t;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * Structure containing strings describing an SMB command.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eastypedef struct {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas const char *smb_com;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas const char *smb_andx;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas} smb_com_entry_t;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * Structure describing an object to be expanded (displayed).
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eastypedef struct {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas uint_t ex_mask;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas size_t ex_offset;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas const char *ex_dcmd;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas const char *ex_name;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas} smb_exp_t;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * List of supported options. Ther order has the match the bits SMB_OPT_xxx.
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wrighttypedef struct smb_mdb_opts {
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright char *o_name;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright uint32_t o_value;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright} smb_mdb_opts_t;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wrightstatic smb_mdb_opts_t smb_opts[SMB_MDB_MAX_OPTS] =
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright { "-s", SMB_OPT_SERVER },
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright { "-e", SMB_OPT_SESSION },
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright { "-r", SMB_OPT_REQUEST },
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright { "-u", SMB_OPT_USER },
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright { "-t", SMB_OPT_TREE },
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright { "-f", SMB_OPT_OFILE },
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright { "-d", SMB_OPT_ODIR },
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright { "-w", SMB_OPT_WALK },
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright { "-v", SMB_OPT_VERBOSE }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic smb_com_entry_t smb_com[256] =
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_CREATE_DIRECTORY, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_DELETE_DIRECTORY, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_OPEN, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_CREATE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_CLOSE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_FLUSH, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_DELETE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_RENAME, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_QUERY_INFORMATION, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_SET_INFORMATION, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_READ, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_WRITE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_LOCK_BYTE_RANGE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_UNLOCK_BYTE_RANGE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_CREATE_TEMPORARY, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_CREATE_NEW, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_CHECK_DIRECTORY, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_PROCESS_EXIT, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_SEEK, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_LOCK_AND_READ, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_WRITE_AND_UNLOCK, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x15, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x16, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x17, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x18, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x19, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_READ_RAW, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_READ_MPX, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_READ_MPX_SECONDARY, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_WRITE_RAW, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_WRITE_MPX, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_WRITE_MPX_SECONDARY, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_WRITE_COMPLETE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_QUERY_SERVER, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_SET_INFORMATION2, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_QUERY_INFORMATION2, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_LOCKING_ANDX, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_TRANSACTION, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_TRANSACTION_SECONDARY, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_IOCTL, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_IOCTL_SECONDARY, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_COPY, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_MOVE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_ECHO, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_WRITE_AND_CLOSE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_OPEN_ANDX, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_READ_ANDX, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_WRITE_ANDX, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_NEW_FILE_SIZE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_CLOSE_AND_TREE_DISC, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_TRANSACTION2, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_TRANSACTION2_SECONDARY, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_FIND_CLOSE2, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_FIND_NOTIFY_CLOSE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x36, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x37, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x38, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x39, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x3A, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x3B, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x3C, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x3D, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x3E, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x3F, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x40, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x41, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x42, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x43, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x44, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x45, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x46, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x47, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x48, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x49, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x4A, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x4B, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x4C, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x4D, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x4E, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x4F, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x50, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x51, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x52, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x53, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x54, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x55, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x56, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x57, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x58, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x59, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x5A, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x5B, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x5C, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x5D, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x5E, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x5F, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x60, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x61, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x62, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x63, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x64, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x65, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x66, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x67, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x68, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x69, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x6A, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x6B, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x6C, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x6D, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x6E, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x6F, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_TREE_CONNECT, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_TREE_DISCONNECT, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_NEGOTIATE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_SESSION_SETUP_ANDX, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_LOGOFF_ANDX, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_TREE_CONNECT_ANDX, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x76, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x77, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x78, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x79, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x7A, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x7B, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x7C, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x7D, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x7E, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x7F, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_QUERY_INFORMATION_DISK, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_SEARCH, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_FIND, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_FIND_UNIQUE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_FIND_CLOSE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x85, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x86, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x87, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x88, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x89, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x8A, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x8B, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x8C, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x8D, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x8E, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x8F, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x90, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x91, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x92, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x93, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x94, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x95, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x96, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x97, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x98, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x99, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x9A, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x9B, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x9C, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x9D, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x9E, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0x9F, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_NT_TRANSACT, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_NT_TRANSACT_SECONDARY, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_NT_CREATE_ANDX, "No"),
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright SMB_COM_ENTRY(0xA3, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_NT_CANCEL, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_NT_RENAME, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xA6, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xA7, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xA8, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xA9, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xAA, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xAB, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xAC, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xAD, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xAE, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xAF, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xB0, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xB1, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xB2, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xB3, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xB4, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xB5, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xB6, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xB7, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xB8, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xB9, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xBA, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xBB, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xBC, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xBD, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xBE, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xBF, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_OPEN_PRINT_FILE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_WRITE_PRINT_FILE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_CLOSE_PRINT_FILE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_GET_PRINT_QUEUE, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xC4, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xC5, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xC6, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xC7, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xC8, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xC9, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xCA, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xCB, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xCC, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xCD, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xCE, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xCF, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xD0, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xD1, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xD2, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xD3, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xD4, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xD5, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xD6, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xD7, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_READ_BULK, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_WRITE_BULK, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(SMB_COM_WRITE_BULK_DATA, "No"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xDB, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xDC, "?"),
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright SMB_COM_ENTRY(0xDD, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xDE, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xDF, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xE0, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xE1, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xE2, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xE3, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xE4, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xE5, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xE6, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xE7, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xE8, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xE9, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xEA, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xEB, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xEC, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xED, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xEE, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xEF, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xF0, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xF1, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xF2, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xF3, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xF4, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xF5, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xF6, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xF7, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xF8, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xF9, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xFA, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xFB, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xFC, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xFD, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xFE, "?"),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_COM_ENTRY(0xFF, "?")
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Rossstatic const char *smb2_cmd_names[SMB2__NCMDS] = {
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_negotiate",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_session_setup",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_logoff",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_tree_connect",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_tree_disconn",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_create",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_close",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_flush",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_read",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_write",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_lock",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_ioctl",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_cancel",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_echo",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_query_dir",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_change_notify",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_query_info",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_set_info",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_oplock_break",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "smb2_invalid_cmd"
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross};
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_dcmd_list(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic void smb_dcmd_list_help(void);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_dcmd_server(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic void smb_dcmd_session_help(void);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_dcmd_session(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_dcmd_request(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic void smb_dcmd_user_help(void);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_dcmd_user(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic void smb_dcmd_tree_help(void);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_dcmd_tree(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_dcmd_odir(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_dcmd_ofile(uintptr_t, uint_t, int, const mdb_arg_t *);
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Rossstatic int smb_dcmd_kshare(uintptr_t, uint_t, int, const mdb_arg_t *);
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Rossstatic int smb_dcmd_vfs(uintptr_t, uint_t, int, const mdb_arg_t *);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wrightstatic int smb_vfs_walk_init(mdb_walk_state_t *);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wrightstatic int smb_vfs_walk_step(mdb_walk_state_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic void smb_node_help(void);
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Rossstatic int smb_dcmd_node(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_node_walk_init(mdb_walk_state_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_node_walk_step(mdb_walk_state_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_lock(uintptr_t, uint_t, int, const mdb_arg_t *);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintoshstatic int smb_oplock(uintptr_t, uint_t, int, const mdb_arg_t *);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintoshstatic int smb_oplock_grant(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_ace(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_ace_walk_init(mdb_walk_state_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_ace_walk_step(mdb_walk_state_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_acl(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_sd(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_sid(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_sid_print(uintptr_t);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_fssd(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_dcmd_getopt(uint_t *, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_dcmd_setopt(uint_t, int, mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_obj_expand(uintptr_t, uint_t, const smb_exp_t *, ulong_t);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int smb_obj_list(const char *, uint_t, uint_t);
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wrightstatic int smb_worker_findstack(uintptr_t);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wrightstatic int smb_stats(uintptr_t, uint_t, int, const mdb_arg_t *);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * MDB module linkage information:
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * We declare a list of structures describing our dcmds, a list of structures
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * describing our walkers and a function named _mdb_init to return a pointer
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * to our module information.
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const mdb_dcmd_t dcmds[] = {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smblist",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "[-seutfdwv]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print tree of SMB objects",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_dcmd_list,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_dcmd_list_help },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbsrv",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "[-seutfdwv]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print smb_server information",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_dcmd_server },
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross { "smbshares",
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross "[-v]",
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross "print smb_kshare_t information",
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross smb_dcmd_kshare },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbvfs",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "[-v]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print smb_vfs information",
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross smb_dcmd_vfs },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbnode",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "?[-vps]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print smb_node_t information",
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross smb_dcmd_node,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_node_help },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbsess",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "[-utfdwv]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print smb_session_t information",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_dcmd_session,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_dcmd_session_help},
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbreq",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ":[-v]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print smb_request_t information",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_dcmd_request },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smblock", ":[-v]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print smb_lock_t information", smb_lock },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbuser",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ":[-vdftq]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print smb_user_t information",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_dcmd_user,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_dcmd_user_help },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbtree",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ":[-vdf]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print smb_tree_t information",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_dcmd_tree,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_dcmd_tree_help },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbodir",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ":[-v]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print smb_odir_t information",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_dcmd_odir },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbofile",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "[-v]",
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh "print smb_file_t information",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_dcmd_ofile },
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh { "smboplock", NULL,
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh "print smb_oplock_t information", smb_oplock },
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh { "smboplockgrant", NULL,
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh "print smb_oplock_grant_t information", smb_oplock_grant },
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright { "smbstat", NULL,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "print all smb dispatched requests statistics",
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright smb_stats },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbace", "[-v]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print smb_ace_t information", smb_ace },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbacl", "[-v]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print smb_acl_t information", smb_acl },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbsid", "[-v]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print smb_sid_t information", smb_sid },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbsd", "[-v]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print smb_sd_t information", smb_sd },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbfssd", "[-v]",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "print smb_fssd_t information", smb_fssd },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { NULL }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const mdb_walker_t walkers[] = {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbnode_walker",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "walk list of smb_node_t structures",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_node_walk_init,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_node_walk_step,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas NULL,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas NULL },
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright { "smbvfs_walker",
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "walk list of smb_vfs_t structures",
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright smb_vfs_walk_init,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright smb_vfs_walk_step,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright NULL,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright NULL },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "smbace_walker",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "walk list of smb_ace_t structures",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_ace_walk_init,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_ace_walk_step,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas NULL,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas NULL },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { NULL }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const mdb_modinfo_t modinfo = {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas MDB_API_VERSION, dcmds, walkers
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easconst mdb_modinfo_t *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas_mdb_init(void)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (&modinfo);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ****************************** Top level DCMD *******************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic void
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_dcmd_list_help(void)
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "Displays the list of objects using an indented tree format.\n"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "If no option is specified the entire tree is displayed\n\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_dec_indent(2);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%<b>OPTIONS%</b>\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_inc_indent(2);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "-v\tDisplay verbose information\n"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "-s\tDisplay the list of servers\n"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "-e\tDisplay the list of sessions\n"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "-r\tDisplay the list of smb requests\n"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "-u\tDisplay the list of users\n"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "-t\tDisplay the list of trees\n"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "-f\tDisplay the list of open files\n"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "-d\tDisplay the list of open searches\n");
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb}
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ::smblist
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * This function lists the objects specified on the command line. If no object
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * is specified the entire tree (server through ofile and odir) is displayed.
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*ARGSUSED*/
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_dcmd_list(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas GElf_Sym sym;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas uint_t opts = 0;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas int new_argc;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_arg_t new_argv[SMB_MDB_MAX_OPTS];
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (smb_dcmd_getopt(&opts, argc, argv))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_USAGE);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (!(opts & ~(SMB_OPT_WALK | SMB_OPT_VERBOSE)))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas opts |= SMB_OPT_ALL_OBJ;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas opts |= SMB_OPT_WALK;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas new_argc = smb_dcmd_setopt(opts, SMB_MDB_MAX_OPTS, new_argv);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross if (mdb_lookup_by_obj(SMBSRV_OBJNAME, "smb_servers", &sym) == -1) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to find symbol smb_servers");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross addr = (uintptr_t)sym.st_value + OFFSETOF(smb_llist_t, ll_list);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross if (mdb_pwalk_dcmd("list", "smbsrv", new_argc, new_argv, addr)) {
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross mdb_warn("cannot walk smb_server list");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_OK);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb}
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ***************************** smb_server_t **********************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const char *smb_server_state[SMB_SERVER_STATE_SENTINEL] =
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "CREATED",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "CONFIGURED",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "RUNNING",
9fb67ea305c66b6a297583b9b0db6796b0dfe497afshin salek ardakani - Sun Microsystems - Irvine United States "STOPPING",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "DELETING"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * List of objects that can be expanded under a server structure.
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const smb_exp_t smb_server_exp[] =
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { SMB_OPT_ALL_OBJ,
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross OFFSETOF(smb_server_t, sv_nbt_daemon.ld_session_list.ll_list),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "smbsess", "smb_session"},
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { SMB_OPT_ALL_OBJ,
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross OFFSETOF(smb_server_t, sv_tcp_daemon.ld_session_list.ll_list),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "smbsess", "smb_session"},
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { 0, 0, NULL, NULL }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ::smbsrv
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * smbsrv dcmd - Print out smb_server structures.
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*ARGSUSED*/
faa1795a28a5c712eed6d0a3f84d98c368a316c6jbstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_dcmd_server(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas uint_t opts;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ulong_t indent = 0;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (smb_dcmd_getopt(&opts, argc, argv))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_USAGE);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (!(flags & DCMD_ADDRSPEC))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (smb_obj_list("smb_server", opts | SMB_OPT_SERVER,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas flags));
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (((opts & SMB_OPT_WALK) && (opts & SMB_OPT_SERVER)) ||
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas !(opts & SMB_OPT_WALK)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_server_t *sv;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas const char *state;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas sv = mdb_alloc(sizeof (smb_server_t), UM_SLEEP | UM_GC);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_vread(sv, sizeof (smb_server_t), addr) == -1) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to read smb_server at %p", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas indent = SMB_DCMD_INDENT;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (opts & SMB_OPT_VERBOSE) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_arg_t argv;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas argv.a_type = MDB_TYPE_STRING;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas argv.a_un.a_str = "smb_server_t";
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_call_dcmd("print", addr, flags, 1, &argv))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas } else {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (DCMD_HDRSPEC(flags))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%<b>%<u>%-?s% "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%-4s% "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%-32s% "
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "%</u>%</b>\n",
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "SERVER", "ZONE", "STATE");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sv->sv_state >= SMB_SERVER_STATE_SENTINEL)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state = "UNKNOWN";
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas else
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state = smb_server_state[sv->sv_state];
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright mdb_printf("%-?p %-4d %-32s \n",
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright addr, sv->sv_zid, state);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (smb_obj_expand(addr, opts, smb_server_exp, indent))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_OK);
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb}
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ***************************** smb_session_t *********************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const char *smb_session_state[SMB_SESSION_STATE_SENTINEL] =
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "INITIALIZED",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "DISCONNECTED",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "CONNECTED",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "ESTABLISHED",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "NEGOTIATED",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "TERMINATED"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * List of objects that can be expanded under a session structure.
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const smb_exp_t smb_session_exp[] =
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { SMB_OPT_REQUEST,
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross OFFSETOF(smb_session_t, s_req_list.sl_list),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "smbreq", "smb_request"},
3b13a1ef7511135ec0c75b5f94de8075454efd79Thomas Keiser { SMB_OPT_USER,
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross OFFSETOF(smb_session_t, s_user_list.ll_list),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "smbuser", "smb_user"},
3b13a1ef7511135ec0c75b5f94de8075454efd79Thomas Keiser { SMB_OPT_TREE | SMB_OPT_OFILE | SMB_OPT_ODIR,
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross OFFSETOF(smb_session_t, s_tree_list.ll_list),
3b13a1ef7511135ec0c75b5f94de8075454efd79Thomas Keiser "smbtree", "smb_tree"},
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { 0, 0, NULL, NULL}
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic void
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_dcmd_session_help(void)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "Display the contents of smb_session_t, with optional"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas " filtering.\n\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_dec_indent(2);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%<b>OPTIONS%</b>\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_inc_indent(2);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "-v\tDisplay verbose smb_session information\n"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "-r\tDisplay the list of smb requests attached\n"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "-u\tDisplay the list of users attached\n");
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ::smbsess
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * smbsess dcmd - Print out the smb_session structure.
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_dcmd_session(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas uint_t opts;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ulong_t indent = 0;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (smb_dcmd_getopt(&opts, argc, argv))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_USAGE);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (!(flags & DCMD_ADDRSPEC)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas opts |= SMB_OPT_SESSION;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas opts &= ~SMB_OPT_SERVER;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (smb_obj_list("smb_session", opts, flags));
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (((opts & SMB_OPT_WALK) && (opts & SMB_OPT_SESSION)) ||
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas !(opts & SMB_OPT_WALK)) {
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross char cipaddr[INET6_ADDRSTRLEN];
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross char lipaddr[INET6_ADDRSTRLEN];
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross int ipaddrstrlen;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_session_t *se;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas const char *state;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas indent = SMB_DCMD_INDENT;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas se = mdb_alloc(sizeof (*se), UM_SLEEP | UM_GC);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_vread(se, sizeof (*se), addr) == -1) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to read smb_session at %p", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (se->s_state >= SMB_SESSION_STATE_SENTINEL)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state = "INVALID";
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas else
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state = smb_session_state[se->s_state];
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross switch (se->ipaddr.a_family) {
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross case AF_INET:
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross ipaddrstrlen = INET_ADDRSTRLEN;
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross (void) mdb_snprintf(cipaddr, sizeof (cipaddr),
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "%I", se->ipaddr.a_ipv4);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross (void) mdb_snprintf(lipaddr, sizeof (lipaddr),
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "%I", se->local_ipaddr.a_ipv4);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross break;
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross case AF_INET6:
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross ipaddrstrlen = INET6_ADDRSTRLEN;
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross (void) mdb_snprintf(cipaddr, sizeof (cipaddr),
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "%N", &(se->ipaddr.a_ipv6));
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross (void) mdb_snprintf(lipaddr, sizeof (lipaddr),
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "%N", &(se->local_ipaddr.a_ipv6));
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross break;
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross default:
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross ipaddrstrlen = INET_ADDRSTRLEN;
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross (void) mdb_snprintf(cipaddr, sizeof (cipaddr),
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "unknown");
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross (void) mdb_snprintf(lipaddr, sizeof (lipaddr),
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "unknown");
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross }
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (opts & SMB_OPT_VERBOSE) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%<b>%<u>SMB session information "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "(%p): %</u>%</b>\n", addr);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf("Client IP address: %s %d\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross cipaddr, se->s_remote_port);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf("Local IP Address: %s %d\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross lipaddr, se->s_local_port);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Session KID: %u\n", se->s_kid);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Workstation Name: %s\n",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas se->workstation);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Session state: %u (%s)\n", se->s_state,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf("Session dialect: %#x\n", se->dialect);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Number of Users: %u\n",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas se->s_user_list.ll_count);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Number of Trees: %u\n", se->s_tree_cnt);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Number of Files: %u\n", se->s_file_cnt);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Number of Shares: %u\n", se->s_dir_cnt);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Number of active Transact.: %u\n\n",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas se->s_xa_list.ll_count);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas } else {
41610d101ac089e52e33b0a671581e0c80d256c0Yuri Pankov if (DCMD_HDRSPEC(flags)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "%<b>%<u>%-?s %-*s %-8s %-8s %-12s%</u>%</b>\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "SESSION", ipaddrstrlen, "IP_ADDR",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "PORT", "DIALECT", "STATE");
41610d101ac089e52e33b0a671581e0c80d256c0Yuri Pankov }
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf("%-?p %-*s %-8d %-8#x %s\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross addr, ipaddrstrlen, cipaddr,
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross se->s_remote_port, se->dialect, state);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (smb_obj_expand(addr, opts, smb_session_exp, indent))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_OK);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * **************************** smb_request_t **********************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const char *smb_request_state[SMB_REQ_STATE_SENTINEL] =
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "FREE",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "INITIALIZING",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "SUBMITTED",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "ACTIVE",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "WAITING_EVENT",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "EVENT_OCCURRED",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "WAITING_LOCK",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "COMPLETED",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "CANCELED",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "CLEANED_UP"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright#define SMB_REQUEST_BANNER \
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "%<b>%<u>%-?s %-?s %-14s %-14s %-16s %-32s%</u>%</b>\n"
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright#define SMB_REQUEST_FORMAT \
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh "%-?p %-?p %-14lld %-14lld %-16s %s\n"
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_dcmd_request(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas uint_t opts;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (smb_dcmd_getopt(&opts, argc, argv))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_USAGE);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (!(flags & DCMD_ADDRSPEC)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas opts |= SMB_OPT_REQUEST;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas opts &= ~(SMB_OPT_SERVER | SMB_OPT_SESSION | SMB_OPT_USER);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (smb_obj_list("smb_request", opts, flags));
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (((opts & SMB_OPT_WALK) && (opts & SMB_OPT_REQUEST)) ||
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas !(opts & SMB_OPT_WALK)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_request_t *sr;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas const char *state;
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross const char *cur_cmd_name;
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross uint_t cur_cmd_code;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright uint64_t waiting;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright uint64_t running;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas sr = mdb_alloc(sizeof (*sr), UM_SLEEP | UM_GC);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_vread(sr, sizeof (*sr), addr) == -1) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to read smb_request at %p", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright if (sr->sr_magic != SMB_REQ_MAGIC) {
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright mdb_warn("not an smb_request_t (%p)>", addr);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright return (DCMD_ERR);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright }
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright waiting = 0;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright running = 0;
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross /*
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross * Note: mdb_gethrtime() is only available in kmdb
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross */
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross#ifdef _KERNEL
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright if (sr->sr_time_submitted != 0) {
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright if (sr->sr_time_active != 0) {
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright waiting = sr->sr_time_active -
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright sr->sr_time_submitted;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright running = mdb_gethrtime() -
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright sr->sr_time_active;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright } else {
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright waiting = mdb_gethrtime() -
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright sr->sr_time_submitted;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright }
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright }
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright waiting /= NANOSEC;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright running /= NANOSEC;
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross#endif /* _KERNEL */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sr->sr_state >= SMB_REQ_STATE_SENTINEL)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state = "INVALID";
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas else
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state = smb_request_state[sr->sr_state];
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross if (sr->smb2_cmd_code != 0) {
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross /* SMB2 request */
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross cur_cmd_code = sr->smb2_cmd_code;
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross if (cur_cmd_code > SMB2_INVALID_CMD)
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross cur_cmd_code = SMB2_INVALID_CMD;
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross cur_cmd_name = smb2_cmd_names[cur_cmd_code];
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross } else {
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross /* SMB1 request */
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross cur_cmd_code = sr->smb_com & 0xFF;
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross cur_cmd_name = smb_com[cur_cmd_code].smb_com;
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross }
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (opts & SMB_OPT_VERBOSE) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright "%</b>%</u>SMB request information (%p):"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%</u>%</b>\n\n", addr);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross if (sr->smb2_cmd_code == 0) {
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross /* SMB1 request */
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf(
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "first SMB COM: %u (%s)\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross sr->first_smb_com,
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross smb_com[sr->first_smb_com].smb_com);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross }
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf(
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "current SMB COM: %u (%s)\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross cur_cmd_code, cur_cmd_name);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf(
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "state: %u (%s)\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross sr->sr_state, state);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf(
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "TID(tree): %u (%p)\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross sr->smb_tid, sr->tid_tree);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf(
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "UID(user): %u (%p)\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross sr->smb_uid, sr->uid_user);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf(
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "FID(file): %u (%p)\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross sr->smb_fid, sr->fid_ofile);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf(
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "PID: %u\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross sr->smb_pid);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross if (sr->smb2_messageid != 0) {
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf(
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "MID: 0x%llx\n\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross sr->smb2_messageid);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross } else {
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf(
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "MID: %u\n\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross sr->smb_mid);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross }
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf(
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "waiting time: %lld\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross waiting);
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright mdb_printf(
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh "running time: %lld\n",
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright running);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf(
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross "worker thread: %p\n",
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross sr->sr_worker);
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright smb_worker_findstack((uintptr_t)sr->sr_worker);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas } else {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (DCMD_HDRSPEC(flags))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright SMB_REQUEST_BANNER,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "ADDR",
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "WORKER",
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "WAITING(s)",
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "RUNNING(s)",
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "STATE",
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "COMMAND");
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross mdb_printf(
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross SMB_REQUEST_FORMAT,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright addr,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright sr->sr_worker,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright waiting,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright running,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright state,
a90cf9f29973990687fa61de9f1f6ea22e924e40Gordon Ross cur_cmd_name);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_OK);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ****************************** smb_user_t ***********************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const char *smb_user_state[SMB_USER_STATE_SENTINEL] =
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
12b65585e720714b31036daaa2b30eb76014048eGordon Ross "LOGGING_ON",
12b65585e720714b31036daaa2b30eb76014048eGordon Ross "LOGGED_ON",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "LOGGING_OFF",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "LOGGED_OFF"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic void
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_dcmd_user_help(void)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "Display the contents of smb_user_t, with optional filtering.\n\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_dec_indent(2);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%<b>OPTIONS%</b>\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_inc_indent(2);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
3b13a1ef7511135ec0c75b5f94de8075454efd79Thomas Keiser "-v\tDisplay verbose smb_user information\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas}
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_dcmd_user(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas uint_t opts;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (smb_dcmd_getopt(&opts, argc, argv))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_USAGE);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (!(flags & DCMD_ADDRSPEC)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas opts |= SMB_OPT_USER;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas opts &= ~(SMB_OPT_SERVER | SMB_OPT_SESSION | SMB_OPT_REQUEST);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (smb_obj_list("smb_user", opts, flags));
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (((opts & SMB_OPT_WALK) && (opts & SMB_OPT_USER)) ||
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas !(opts & SMB_OPT_WALK)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_user_t *user;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas char *account;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas user = mdb_alloc(sizeof (*user), UM_SLEEP | UM_GC);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_vread(user, sizeof (*user), addr) == -1) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to read smb_user at %p", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas account = mdb_zalloc(user->u_domain_len + user->u_name_len + 2,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas UM_SLEEP | UM_GC);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (user->u_domain_len)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_vread(account, user->u_domain_len,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (uintptr_t)user->u_domain);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas strcat(account, "\\");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (user->u_name_len)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_vread(account + strlen(account),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas user->u_name_len, (uintptr_t)user->u_name);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (opts & SMB_OPT_VERBOSE) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas const char *state;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (user->u_state >= SMB_USER_STATE_SENTINEL)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state = "INVALID";
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas else
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state = smb_user_state[user->u_state];
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%<b>%<u>SMB user information (%p):"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%</u>%</b>\n", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("UID: %u\n", user->u_uid);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("State: %d (%s)\n", user->u_state, state);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Flags: 0x%08x\n", user->u_flags);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Privileges: 0x%08x\n", user->u_privileges);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Credential: %p\n", user->u_cred);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Reference Count: %d\n", user->u_refcnt);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("User Account: %s\n\n", account);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas } else {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (DCMD_HDRSPEC(flags))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%<b>%<u>%?-s "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%-5s "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%-32s%</u>%</b>\n",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "USER", "UID", "ACCOUNT");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%-?p %-5u %-32s\n", addr, user->u_uid,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas account);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_OK);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ****************************** smb_tree_t ***********************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const char *smb_tree_state[SMB_TREE_STATE_SENTINEL] =
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "CONNECTED",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "DISCONNECTING",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "DISCONNECTED"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * List of objects that can be expanded under a tree structure.
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const smb_exp_t smb_tree_exp[] =
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { SMB_OPT_OFILE,
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross OFFSETOF(smb_tree_t, t_ofile_list.ll_list),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "smbofile", "smb_ofile"},
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { SMB_OPT_ODIR,
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross OFFSETOF(smb_tree_t, t_odir_list.ll_list),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "smbodir", "smb_odir"},
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { 0, 0, NULL, NULL}
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic void
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_dcmd_tree_help(void)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "Display the contents of smb_tree_t, with optional filtering.\n\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_dec_indent(2);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%<b>OPTIONS%</b>\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_inc_indent(2);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "-v\tDisplay verbose smb_tree information\n"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "-d\tDisplay the list of smb_odirs attached\n"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "-f\tDisplay the list of smb_ofiles attached\n");
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_dcmd_tree(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas uint_t opts;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ulong_t indent = 0;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (smb_dcmd_getopt(&opts, argc, argv))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_USAGE);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (!(flags & DCMD_ADDRSPEC)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas opts |= SMB_OPT_TREE;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas opts &= ~(SMB_OPT_SERVER | SMB_OPT_SESSION | SMB_OPT_REQUEST |
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_OPT_USER);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (smb_obj_list("smb_tree", opts, flags));
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (((opts & SMB_OPT_WALK) && (opts & SMB_OPT_TREE)) ||
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas !(opts & SMB_OPT_WALK)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_tree_t *tree;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas indent = SMB_DCMD_INDENT;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas tree = mdb_alloc(sizeof (*tree), UM_SLEEP | UM_GC);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_vread(tree, sizeof (*tree), addr) == -1) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to read smb_tree at %p", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (opts & SMB_OPT_VERBOSE) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas const char *state;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (tree->t_state >= SMB_TREE_STATE_SENTINEL)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state = "INVALID";
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas else
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state = smb_tree_state[tree->t_state];
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%<b>%<u>SMB tree information (%p):"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%</u>%</b>\n\n", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("TID: %04x\n", tree->t_tid);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("State: %d (%s)\n", tree->t_state, state);
c8ec8eea9849cac239663c46be8a7f5d2ba7ca00jose borrego mdb_printf("Share: %s\n", tree->t_sharename);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Resource: %s\n", tree->t_resource);
c8ec8eea9849cac239663c46be8a7f5d2ba7ca00jose borrego mdb_printf("Type: %s\n", tree->t_typename);
c8ec8eea9849cac239663c46be8a7f5d2ba7ca00jose borrego mdb_printf("Volume: %s\n", tree->t_volume);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Umask: %04x\n", tree->t_umask);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Flags: %08x\n", tree->t_flags);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("SMB Node: %llx\n", tree->t_snode);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Reference Count: %d\n\n", tree->t_refcnt);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas } else {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (DCMD_HDRSPEC(flags))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%<b>%<u>%-?s %-5s %-16s %-32s%</u>%</b>\n",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "TREE", "TID", "SHARE NAME", "RESOURCE");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%-?p %-5u %-16s %-32s\n", addr,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas tree->t_tid, tree->t_sharename, tree->t_resource);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (smb_obj_expand(addr, opts, smb_tree_exp, indent))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_OK);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ****************************** smb_odir_t ***********************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const char *smb_odir_state[SMB_ODIR_STATE_SENTINEL] =
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "OPEN",
9fb67ea305c66b6a297583b9b0db6796b0dfe497afshin salek ardakani - Sun Microsystems - Irvine United States "IN_USE",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "CLOSING",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "CLOSED"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_dcmd_odir(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas uint_t opts;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (smb_dcmd_getopt(&opts, argc, argv))
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_USAGE);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (!(flags & DCMD_ADDRSPEC)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas opts |= SMB_OPT_ODIR;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas opts &= ~(SMB_OPT_SERVER | SMB_OPT_SESSION | SMB_OPT_REQUEST |
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_OPT_USER | SMB_OPT_TREE | SMB_OPT_OFILE);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (smb_obj_list("smb_odir", opts, flags));
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (((opts & SMB_OPT_WALK) && (opts & SMB_OPT_ODIR)) ||
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas !(opts & SMB_OPT_WALK)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_odir_t *od;
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas od = mdb_alloc(sizeof (*od), UM_SLEEP | UM_GC);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_vread(od, sizeof (*od), addr) == -1) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to read smb_odir at %p", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (opts & SMB_OPT_VERBOSE) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas const char *state;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (od->d_state >= SMB_ODIR_STATE_SENTINEL)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state = "INVALID";
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas else
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state = smb_odir_state[od->d_state];
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%<b>%<u>SMB odir information (%p):%</u>%</b>\n\n",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("State: %d (%s)\n", od->d_state, state);
7f667e74610492ddbce8ce60f52ece95d2401949jose borrego mdb_printf("SID: %u\n", od->d_odid);
3b13a1ef7511135ec0c75b5f94de8075454efd79Thomas Keiser mdb_printf("User: %p\n", od->d_user);
3b13a1ef7511135ec0c75b5f94de8075454efd79Thomas Keiser mdb_printf("Tree: %p\n", od->d_tree);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Reference Count: %d\n", od->d_refcnt);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Pattern: %s\n", od->d_pattern);
7f667e74610492ddbce8ce60f52ece95d2401949jose borrego mdb_printf("SMB Node: %p\n\n", od->d_dnode);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas } else {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (DCMD_HDRSPEC(flags))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
e3f2c991a8548408db0a2787bd8b43d5124821d3Keyur Desai "%<b>%<u>%-?s "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%-5s "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%-?s "
e3f2c991a8548408db0a2787bd8b43d5124821d3Keyur Desai "%-16s%</u>%</b>\n",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "ODIR", "SID", "VNODE", "PATTERN");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
e3f2c991a8548408db0a2787bd8b43d5124821d3Keyur Desai mdb_printf("%?p %-5u %-16p %s\n",
7f667e74610492ddbce8ce60f52ece95d2401949jose borrego addr, od->d_odid, od->d_dnode, od->d_pattern);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_OK);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ****************************** smb_ofile_t **********************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const char *smb_ofile_state[SMB_OFILE_STATE_SENTINEL] =
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "OPEN",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "CLOSING",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "CLOSED"
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_dcmd_ofile(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas uint_t opts;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (smb_dcmd_getopt(&opts, argc, argv))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_USAGE);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (!(flags & DCMD_ADDRSPEC)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas opts |= SMB_OPT_OFILE;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas opts &= ~(SMB_OPT_SERVER | SMB_OPT_SESSION | SMB_OPT_REQUEST |
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SMB_OPT_USER | SMB_OPT_TREE | SMB_OPT_ODIR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (smb_obj_list("smb_ofile", opts, flags));
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (((opts & SMB_OPT_WALK) && (opts & SMB_OPT_OFILE)) ||
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas !(opts & SMB_OPT_WALK)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_ofile_t *of;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas of = mdb_alloc(sizeof (*of), UM_SLEEP | UM_GC);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_vread(of, sizeof (*of), addr) == -1) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to read smb_ofile at %p", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (opts & SMB_OPT_VERBOSE) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas const char *state;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
2c2d21e98a95cba5687ec6574c974a5c6c4a6adbRichard Lowe if (of->f_state >= SMB_OFILE_STATE_SENTINEL)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state = "INVALID";
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas else
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas state = smb_ofile_state[of->f_state];
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%<b>%<u>SMB ofile information (%p):%</u>%</b>\n\n",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("FID: %u\n", of->f_fid);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("State: %d (%s)\n", of->f_state, state);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("SMB Node: %p\n", of->f_node);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("LLF Offset: 0x%llx (%s)\n",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas of->f_llf_pos,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ((of->f_flags & SMB_OFLAGS_LLF_POS_VALID) ?
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "Valid" : "Invalid"));
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Flags: 0x%08x\n", of->f_flags);
3b13a1ef7511135ec0c75b5f94de8075454efd79Thomas Keiser mdb_printf("User: %p\n", of->f_user);
3b13a1ef7511135ec0c75b5f94de8075454efd79Thomas Keiser mdb_printf("Tree: %p\n", of->f_tree);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Credential: %p\n\n", of->f_cr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas } else {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (DCMD_HDRSPEC(flags))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%<b>%<u>%-?s "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%-5s "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%-?s "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%-?s%</u>%</b>\n",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "OFILE", "FID", "SMB NODE", "CRED");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%?p %-5u %-p %p\n", addr,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas of->f_fid, of->f_node, of->f_cr);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_OK);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross/*
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross * *****************************************************************************
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross * ******************************** smb_kshare_t *******************************
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross * *****************************************************************************
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross */
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Rossstatic int
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Rosssmb_kshare_cb(uintptr_t addr, const void *data, void *arg)
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross{
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross uint_t *opts = arg;
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross uintptr_t ta, sa;
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross char name[32];
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross char path[64];
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross _NOTE(ARGUNUSED(data));
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross if (*opts & SMB_OPT_VERBOSE) {
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross mdb_arg_t argv;
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross argv.a_type = MDB_TYPE_STRING;
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross argv.a_un.a_str = "smb_kshare_t";
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross /* Don't fail the walk if this fails. */
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross mdb_call_dcmd("print", addr, 0, 1, &argv);
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross } else {
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross /*
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross * Summary line for a kshare
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross * Don't fail the walk if any of these fail.
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross */
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross ta = addr + OFFSETOF(smb_kshare_t, shr_name);
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross if (mdb_vread(&sa, sizeof (sa), ta) < 0 ||
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross mdb_readstr(name, sizeof (name), sa) <= 0)
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross strcpy(name, "?");
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross ta = addr + OFFSETOF(smb_kshare_t, shr_path);
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross if (mdb_vread(&sa, sizeof (sa), ta) < 0 ||
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross mdb_readstr(path, sizeof (path), sa) <= 0)
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross strcpy(path, "?");
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross mdb_printf("%-?p ", addr); /* smb_kshare_t */
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross mdb_printf("%-16s ", name);
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross mdb_printf("%-s", path);
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross mdb_printf("\n");
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross }
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross return (WALK_NEXT);
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross}
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross/*
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross * ::smbshares
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross *
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross * dcmd - Print out smb_kshare structures.
8622ec4569457733001d4982ef7f5b44427069beGordon Ross * requires addr of an smb_server_t
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross */
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross/*ARGSUSED*/
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Rossstatic int
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Rosssmb_dcmd_kshare(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross{
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross uint_t opts = 0;
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross if (mdb_getopts(argc, argv,
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross 'v', MDB_OPT_SETBITS, SMB_OPT_VERBOSE, &opts,
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross NULL) != argc)
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross return (DCMD_USAGE);
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross
8622ec4569457733001d4982ef7f5b44427069beGordon Ross if (!(flags & DCMD_ADDRSPEC))
8622ec4569457733001d4982ef7f5b44427069beGordon Ross return (DCMD_USAGE);
8622ec4569457733001d4982ef7f5b44427069beGordon Ross addr += OFFSETOF(smb_server_t, sv_export.e_share_avl.avl_tree);
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross if (DCMD_HDRSPEC(flags)) {
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross mdb_printf(
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross "%<b>%<u>"
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross "%-?s "
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross "%-16s "
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross "%-s"
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross "%</u>%</b>\n",
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross "smb_kshare_t", "name", "path");
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross }
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross if (mdb_pwalk("avl", smb_kshare_cb, &opts, addr) == -1) {
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross mdb_warn("cannot walk smb_kshare avl");
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross return (DCMD_ERR);
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross }
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross return (DCMD_OK);
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross}
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Ross
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright/*
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright * *****************************************************************************
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright * ******************************** smb_vfs_t **********************************
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright * *****************************************************************************
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright */
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright/*
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright * ::smbvfs
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright *
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright * smbvfs dcmd - Prints out smb_vfs structures.
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright */
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright/*ARGSUSED*/
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wrightstatic int
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Rosssmb_dcmd_vfs(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright{
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright int verbose = FALSE;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright smb_vfs_t *sf;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright vnode_t *vn;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright char *path;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright if (mdb_getopts(argc, argv,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright 'v', MDB_OPT_SETBITS, TRUE, &verbose,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright NULL) != argc)
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright return (DCMD_USAGE);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright /*
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright * If no smb_vfs address was specified on the command line, we can
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright * print out all smb_vfs by invoking the smb_vfs walker, using
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright * this dcmd itself as the callback.
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright */
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright if (!(flags & DCMD_ADDRSPEC)) {
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright if (mdb_walk_dcmd("smbvfs_walker", "smbvfs",
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright argc, argv) == -1) {
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright mdb_warn("failed to walk 'smb_vfs'");
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright return (DCMD_ERR);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright }
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright return (DCMD_OK);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright }
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright if (DCMD_HDRSPEC(flags)) {
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright mdb_printf(
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "%<b>%<u>"
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "%-?s "
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "%-10s "
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "%-16s "
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "%-16s"
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "%-s"
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "%</u>%</b>\n",
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "SMB_VFS", "REFCNT", "VFS", "VNODE", "ROOT");
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright }
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright sf = mdb_alloc(sizeof (*sf), UM_SLEEP | UM_GC);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright if (mdb_vread(sf, sizeof (*sf), addr) == -1) {
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright mdb_warn("failed to read smb_vfs at %p", addr);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright return (DCMD_ERR);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright }
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright vn = mdb_alloc(sizeof (*vn), UM_SLEEP | UM_GC);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright if (mdb_vread(vn, sizeof (*vn),
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright (uintptr_t)sf->sv_rootvp) == -1) {
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright mdb_warn("failed to read vnode at %p", sf->sv_rootvp);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright return (DCMD_ERR);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright }
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright path = mdb_zalloc(MAXPATHLEN, UM_SLEEP | UM_GC);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright (void) mdb_vread(path, MAXPATHLEN, (uintptr_t)vn->v_path);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright mdb_printf(
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "%-?p %-10d %-?p %-?p %-s\n", addr, sf->sv_refcnt,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright sf->sv_vfsp, sf->sv_rootvp, path);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright return (DCMD_OK);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright}
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright/*
8622ec4569457733001d4982ef7f5b44427069beGordon Ross * Initialize the smb_vfs_t walker to point to the smb_export
8622ec4569457733001d4982ef7f5b44427069beGordon Ross * in the specified smb_server_t instance. (no global walks)
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright */
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wrightstatic int
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wrightsmb_vfs_walk_init(mdb_walk_state_t *wsp)
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright{
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
8622ec4569457733001d4982ef7f5b44427069beGordon Ross if (wsp->walk_addr == NULL) {
8622ec4569457733001d4982ef7f5b44427069beGordon Ross mdb_printf("require address of an smb_server_t\n");
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright return (WALK_ERR);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright }
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
8622ec4569457733001d4982ef7f5b44427069beGordon Ross wsp->walk_addr +=
8622ec4569457733001d4982ef7f5b44427069beGordon Ross OFFSETOF(smb_server_t, sv_export.e_vfs_list.ll_list);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright if (mdb_layered_walk("list", wsp) == -1) {
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright mdb_warn("failed to walk list of VFS");
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright return (WALK_ERR);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright }
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright return (WALK_NEXT);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright}
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wrightstatic int
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wrightsmb_vfs_walk_step(mdb_walk_state_t *wsp)
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright{
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright return (wsp->walk_callback(wsp->walk_addr, wsp->walk_layer,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright wsp->walk_cbdata));
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright}
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ******************************* smb_node_t **********************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstatic void
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_node_help(void)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf(
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw "Display the contents of smb_node_t, with optional filtering.\n\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_dec_indent(2);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("%<b>OPTIONS%</b>\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_inc_indent(2);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf(
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw "-v\tDisplay verbose smb_node information\n"
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw "-p\tDisplay the full path of the vnode associated\n"
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw "-s\tDisplay the stack of the last 16 calls that modified the "
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw "reference\n\tcount\n");
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ::smbnode
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw *
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * smb_node dcmd - Print out smb_node structure.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstatic int
5a6c34e66bd3c0e1e99813ddb7112100eaad276eGordon Rosssmb_dcmd_node(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw smb_node_t node;
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh int rc;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw int verbose = FALSE;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw int print_full_path = FALSE;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw int stack_trace = FALSE;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw vnode_t vnode;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw char od_name[MAXNAMELEN];
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw char path_name[1024];
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh uintptr_t list_addr, oplock_addr;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (mdb_getopts(argc, argv,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw 'v', MDB_OPT_SETBITS, TRUE, &verbose,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw 'p', MDB_OPT_SETBITS, TRUE, &print_full_path,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw 's', MDB_OPT_SETBITS, TRUE, &stack_trace,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw NULL) != argc)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_USAGE);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw /*
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * If no smb_node address was specified on the command line, we can
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * print out all smb nodes by invoking the smb_node walker, using
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * this dcmd itself as the callback.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (!(flags & DCMD_ADDRSPEC)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_walk_dcmd("smbnode_walker", "smbnode",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw argc, argv) == -1) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_warn("failed to walk 'smb_node'");
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_OK);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw /*
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * If this is the first invocation of the command, print a nice
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * header line for the output that will follow.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (DCMD_HDRSPEC(flags)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (verbose) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%<b>%<u>SMB node information:%</u>%</b>\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas } else {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%<b>%<u>%-?s "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%-?s "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%-18s "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%-6s "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%-6s "
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh "%-8s "
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%-6s%</u>%</b>\n",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "ADDR", "VP", "NODE-NAME", "OFILES", "LOCKS",
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh "OPLOCK", "REF");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw /*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * For each smb_node, we just need to read the smb_node_t struct, read
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * and then print out the following fields.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (mdb_vread(&node, sizeof (node), addr) == sizeof (node)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_snprintf(od_name, sizeof (od_name), "%s",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas node.od_name);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (print_full_path) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (mdb_vread(&vnode, sizeof (vnode_t),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (uintptr_t)node.vp) == sizeof (vnode_t)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_readstr(path_name, sizeof (path_name),
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw (uintptr_t)vnode.v_path) != 0) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw (void) mdb_snprintf(od_name,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas sizeof (od_name), "N/A");
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (verbose) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("VP: %p\n", node.vp);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Name: %s\n", od_name);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (print_full_path)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("V-node Path: %s\n", path_name);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Ofiles: %u\n", node.n_ofile_list.ll_count);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Range Locks: %u\n",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw node.n_lock_list.ll_count);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (node.n_lock_list.ll_count != 0) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw (void) mdb_inc_indent(SMB_DCMD_INDENT);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw list_addr = addr +
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross OFFSETOF(smb_node_t, n_lock_list) +
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross OFFSETOF(smb_llist_t, ll_list);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_pwalk_dcmd("list", "smblock", 0,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas NULL, list_addr)) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_warn("failed to walk node's active"
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw " locks");
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw (void) mdb_dec_indent(SMB_DCMD_INDENT);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh if (node.n_oplock.ol_count == 0) {
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh mdb_printf("Opportunistic Locks: 0\n");
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh } else {
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh oplock_addr =
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross addr + OFFSETOF(smb_node_t, n_oplock);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh mdb_printf("Opportunistic Lock: %p\n",
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh oplock_addr);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh rc = mdb_call_dcmd("smboplock", oplock_addr,
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh flags, argc, argv);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh if (rc != DCMD_OK)
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh return (rc);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("Reference Count: %u\n\n", node.n_refcnt);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw } else {
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh mdb_printf("%-?p %-?p %-18s %-6d %-6d %-8d %-6d ",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw addr, node.vp, od_name, node.n_ofile_list.ll_count,
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh node.n_lock_list.ll_count,
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh node.n_oplock.ol_count, node.n_refcnt);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (print_full_path)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\t%s\n", path_name);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (stack_trace && node.n_audit_buf) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw int ctr;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw smb_audit_buf_node_t *anb;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw anb = mdb_alloc(sizeof (smb_audit_buf_node_t),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas UM_SLEEP | UM_GC);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (mdb_vread(anb, sizeof (*anb),
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw (uintptr_t)node.n_audit_buf) != sizeof (*anb)) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_warn("failed to read audit buffer");
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw ctr = anb->anb_max_index + 1;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw anb->anb_index--;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw anb->anb_index &= anb->anb_max_index;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw while (ctr) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw smb_audit_record_node_t *anr;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw anr = anb->anb_records + anb->anb_index;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (anr->anr_depth) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw char c[MDB_SYM_NAMLEN];
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw GElf_Sym sym;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw int i;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("\nRefCnt: %u\t",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw anr->anr_refcnt);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw for (i = 0;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw i < anr->anr_depth;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw i++) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (mdb_lookup_by_addr(
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw anr->anr_stack[i],
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw MDB_SYM_FUZZY,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw c, sizeof (c),
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw &sym) == -1) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw continue;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("%s+0x%1x",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw c,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw anr->anr_stack[i] -
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw (uintptr_t)sym.st_value);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw ++i;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw break;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw while (i < anr->anr_depth) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (mdb_lookup_by_addr(
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw anr->anr_stack[i],
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw MDB_SYM_FUZZY,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw c, sizeof (c),
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw &sym) == -1) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw ++i;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw continue;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("\n\t\t%s+0x%1x",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw c,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw anr->anr_stack[i] -
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw (uintptr_t)sym.st_value);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw ++i;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("\n");
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw anb->anb_index--;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw anb->anb_index &= anb->anb_max_index;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw ctr--;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw } else {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_warn("failed to read struct smb_node at %p", addr);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_OK);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * Initialize the smb_node_t walker by reading the value of smb_node_hash_table
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * in the kernel's symbol table. Only global walk supported.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_node_walk_init(mdb_walk_state_t *wsp)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas GElf_Sym sym;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas int i;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas uintptr_t node_hash_table_addr;
faa1795a28a5c712eed6d0a3f84d98c368a316c6jb
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (wsp->walk_addr == NULL) {
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross if (mdb_lookup_by_obj(SMBSRV_OBJNAME, "smb_node_hash_table",
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross &sym) == -1) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to find 'smb_node_hash_table'");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (WALK_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas node_hash_table_addr = (uintptr_t)sym.st_value;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw } else {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("smb_node walk only supports global walks\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (WALK_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas for (i = 0; i < SMBND_HASH_MASK + 1; i++) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas wsp->walk_addr = node_hash_table_addr +
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross (i * sizeof (smb_llist_t)) + OFFSETOF(smb_llist_t, ll_list);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_layered_walk("list", wsp) == -1) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to walk 'list'");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (WALK_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (WALK_NEXT);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_node_walk_step(mdb_walk_state_t *wsp)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (wsp->walk_callback(wsp->walk_addr, wsp->walk_layer,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas wsp->walk_cbdata));
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ****************************** smb_lock_t ***********************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstatic int
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwsmb_lock(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw smb_lock_t lock;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw int verbose = FALSE;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw uintptr_t list_addr;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw char *lock_type;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (mdb_getopts(argc, argv,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw 'v', MDB_OPT_SETBITS, TRUE, &verbose,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw NULL) != argc)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_USAGE);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw /*
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * An smb_lock_t address must be specified.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (!(flags & DCMD_ADDRSPEC))
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_USAGE);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw /*
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * If this is the first invocation of the command, print a nice
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw * header line for the output that will follow.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (DCMD_HDRSPEC(flags)) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (verbose)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("SMB lock information:\n\n");
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw else
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("%<u>%-?s %4s %16s %8s %9s%</u>\n",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw "Locks: ", "TYPE", "START", "LENGTH",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw "CONFLICTS");
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (mdb_vread(&lock, sizeof (lock), addr) == sizeof (lock)) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw switch (lock.l_type) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw case SMB_LOCK_TYPE_READWRITE:
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock_type = "RW";
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw break;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw case SMB_LOCK_TYPE_READONLY:
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock_type = "RO";
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw break;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw default:
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock_type = "N/A";
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw break;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (verbose) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("Type :\t%s (%u)\n",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock_type, lock.l_type);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("Start :\t%llx\n",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock.l_start);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("Length :\t%lx\n",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock.l_length);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("Session :\t%p\n",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock.l_session);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("File :\t%p\n",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock.l_file);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("User ID :\t%u\n",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock.l_uid);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("Process ID :\t%u\n",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock.l_pid);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("Conflicts :\t%u\n",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock.l_conflict_list.sl_count);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (lock.l_conflict_list.sl_count != 0) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw (void) mdb_inc_indent(SMB_DCMD_INDENT);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw list_addr = addr +
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross OFFSETOF(smb_lock_t, l_conflict_list) +
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross OFFSETOF(smb_slist_t, sl_list);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (mdb_pwalk_dcmd("list", "smb_lock",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw 0, NULL, list_addr)) {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_warn("failed to walk conflict "
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw "locks ");
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw (void) mdb_dec_indent(SMB_DCMD_INDENT);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("Blocked by :\t%p\n",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock.l_blocked_by);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("Flags :\t0x%x\n",
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock.l_flags);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("\n");
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw } else {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_printf("%?p %4s %16llx %08lx %9x", addr,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock_type, lock.l_start, lock.l_length,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw lock.l_conflict_list.sl_count);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw } else {
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw mdb_warn("failed to read struct smb_request at %p", addr);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_OK);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh/*
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh * *****************************************************************************
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh * ************************** smb_oplock_grant_t *******************************
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh * *****************************************************************************
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh */
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh/*ARGSUSED*/
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintoshstatic int
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintoshsmb_oplock_grant(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh{
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh smb_oplock_grant_t grant;
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh char *level;
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh if (!(flags & DCMD_ADDRSPEC))
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh return (DCMD_USAGE);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh /*
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh * If this is the first invocation of the command, print a nice
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh * header line for the output that will follow.
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh */
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh if (DCMD_HDRSPEC(flags)) {
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh mdb_printf("%<u>%-16s %-10s %-16s%</u>\n",
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh "Grants:", "LEVEL", "OFILE");
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh }
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh if (mdb_vread(&grant, sizeof (grant), addr) == sizeof (grant)) {
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh switch (grant.og_level) {
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh case SMB_OPLOCK_EXCLUSIVE:
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh level = "EXCLUSIVE";
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh break;
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh case SMB_OPLOCK_BATCH:
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh level = "BATCH";
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh break;
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh case SMB_OPLOCK_LEVEL_II:
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh level = "LEVEL_II";
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh break;
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh default:
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh level = "UNKNOWN";
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh break;
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh }
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh mdb_printf("%-16p %-10s %-16p", addr, level, grant.og_ofile);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh }
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh return (DCMD_OK);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh}
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh/*
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh * *****************************************************************************
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh * ***************************** smb_oplock_t **********************************
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh * *****************************************************************************
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh */
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh/*ARGSUSED*/
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintoshstatic int
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintoshsmb_oplock(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh{
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh smb_oplock_t oplock;
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh uintptr_t list_addr;
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh if (!(flags & DCMD_ADDRSPEC))
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh return (DCMD_USAGE);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh if (mdb_vread(&oplock, sizeof (oplock), addr) != sizeof (oplock)) {
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh mdb_warn("failed to read struct smb_oplock at %p", addr);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh return (DCMD_ERR);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh }
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh if (oplock.ol_count == 0)
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh return (DCMD_OK);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh (void) mdb_inc_indent(SMB_DCMD_INDENT);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh switch (oplock.ol_break) {
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh case SMB_OPLOCK_BREAK_TO_NONE:
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh mdb_printf("Break Pending: BREAK_TO_NONE\n");
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh break;
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh case SMB_OPLOCK_BREAK_TO_LEVEL_II:
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh mdb_printf(
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh "Break Pending: BREAK_TO_LEVEL_II\n");
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh break;
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh default:
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh break;
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh }
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross list_addr = addr + OFFSETOF(smb_oplock_t, ol_grants);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh if (mdb_pwalk_dcmd("list", "smboplockgrant",
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh argc, argv, list_addr)) {
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh mdb_warn("failed to walk oplock grants");
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh }
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh (void) mdb_dec_indent(SMB_DCMD_INDENT);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh return (DCMD_OK);
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh}
cb174861876aea6950a7ab4ce944aff84b1914cdjoyce mcintosh
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright * ::smbstat
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas *
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright * Prints SMB requests statistics.
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*ARGSUSED*/
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_stats(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright smb_server_t *sv;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright if (!(flags & DCMD_ADDRSPEC))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_USAGE);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright sv = mdb_alloc(sizeof (*sv), UM_SLEEP | UM_GC);
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright if (mdb_vread(sv, sizeof (*sv), addr) == -1) {
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright mdb_warn("failed to read server object at %p", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright if (sv->sv_magic != SMB_SERVER_MAGIC) {
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright mdb_warn("not an smb_server_t (%p)>", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright mdb_printf(
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "\n%<b> nbt tcp users trees files pipes%</b>\n"
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright "%5d %5d %5d %5d %5d %5d\n",
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright sv->sv_nbt_sess,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright sv->sv_tcp_sess,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright sv->sv_users,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright sv->sv_trees,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright sv->sv_files,
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright sv->sv_pipes);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_OK);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ******************************** smb_ace_t **********************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const ace_type_entry_t ace_types[ACE_TYPE_TABLEN] =
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_ACCESS_ALLOWED_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_ACCESS_DENIED_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_SYSTEM_AUDIT_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_SYSTEM_ALARM_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_ACCESS_ALLOWED_COMPOUND_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_ACCESS_ALLOWED_OBJECT_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_ACCESS_DENIED_OBJECT_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_SYSTEM_AUDIT_OBJECT_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_SYSTEM_ALARM_OBJECT_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_ACCESS_ALLOWED_CALLBACK_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_ACCESS_DENIED_CALLBACK_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_ACCESS_ALLOWED_CALLBACK_OBJECT_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_ACCESS_DENIED_CALLBACK_OBJECT_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_SYSTEM_AUDIT_CALLBACK_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_SYSTEM_ALARM_CALLBACK_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_SYSTEM_AUDIT_CALLBACK_OBJECT_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(ACE_SYSTEM_ALARM_CALLBACK_OBJECT_ACE_TYPE),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x11),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x12),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x13),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x14),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x15),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x16),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x17),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x18),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x19),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x1A),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x1B),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x1C),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x1D),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x1E),
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ACE_TYPE_ENTRY(0x1F)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic const mdb_bitmask_t ace_flag_bits[] = {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "OBJECT_INHERIT_ACE", OBJECT_INHERIT_ACE, OBJECT_INHERIT_ACE },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "CONTAINER_INHERIT_ACE", CONTAINER_INHERIT_ACE,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas CONTAINER_INHERIT_ACE },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "NO_PROPOGATE_INHERIT_ACE", NO_PROPOGATE_INHERIT_ACE,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas NO_PROPOGATE_INHERIT_ACE },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "INHERIT_ONLY_ACE", INHERIT_ONLY_ACE, INHERIT_ONLY_ACE },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "INHERITED_ACE", INHERITED_ACE, INHERITED_ACE },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "SUCCESSFUL_ACCESS_ACE_FLAG", SUCCESSFUL_ACCESS_ACE_FLAG,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas SUCCESSFUL_ACCESS_ACE_FLAG },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { "FAILED_ACCESS_ACE_FLAG", FAILED_ACCESS_ACE_FLAG,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas FAILED_ACCESS_ACE_FLAG },
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas { NULL, 0, 0 }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas};
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ::smbace
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_ace(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_ace_t ace;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw int verbose = FALSE;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas const char *ptr;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas int rc;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_getopts(argc, argv, 'v', MDB_OPT_SETBITS, TRUE, &verbose,
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw NULL) != argc)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_USAGE);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw /*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * An smb_ace address is required.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (!(flags & DCMD_ADDRSPEC))
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_USAGE);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_vread(&ace, sizeof (ace), addr) != sizeof (ace)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to read struct smb_ace at %p", addr);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (verbose) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (ace.se_hdr.se_type < ACE_TYPE_TABLEN)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ptr = ace_types[ace.se_hdr.se_type].ace_type_sting;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas else
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ptr = "Unknown";
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("ACE Type: 0x%02x (%s)\n", ace.se_hdr.se_type, ptr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("ACE Flags: %b\n", (int)ace.se_hdr.se_flags,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ace_flag_bits);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("ACE Wire Size: 0x%04x\n", ace.se_hdr.se_bsize);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("ACE Mask: 0x%08x\n", ace.se_mask);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("ACE SID: ");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas } else {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (DCMD_HDRSPEC(flags))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf(
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "%<b>%<u>%?-s %-4s %-4s %-8s %s%</u>%</b>\n",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas "ACE", "TYPE", "FLAGS", "MASK", "SID");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%?p 0x%02x 0x%02x 0x%08x ", addr,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas ace.se_hdr.se_type, ace.se_hdr.se_flags, ace.se_mask);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas rc = smb_sid_print((uintptr_t)ace.se_sid);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (rc);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_ace_walk_init(mdb_walk_state_t *wsp)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (wsp->walk_addr == 0) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("smb_ace walk only supports local walks\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (WALK_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross wsp->walk_addr += OFFSETOF(smb_acl_t, sl_sorted);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_layered_walk("list", wsp) == -1) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to walk list of ACEs");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (WALK_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (WALK_NEXT);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_ace_walk_step(mdb_walk_state_t *wsp)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (wsp->walk_callback(wsp->walk_addr, wsp->walk_layer,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas wsp->walk_cbdata));
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ******************************** smb_acl_t **********************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ::smbacl
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_acl(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_acl_t acl;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas /* An smb_acl address is required. */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (!(flags & DCMD_ADDRSPEC))
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_USAGE);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_vread(&acl, sizeof (acl), addr) != sizeof (acl)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to read struct smb_acl at %p", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("ACL Revision: %d\n", acl.sl_revision);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("ACL Size on Wire: %d\n", acl.sl_bsize);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("ACL Number of ACEs: %d\n", acl.sl_acecnt);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_inc_indent(SMB_DCMD_INDENT);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_pwalk_dcmd("smbace_walker", "smbace", argc, argv, addr)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_dec_indent(SMB_DCMD_INDENT);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to walk list of ACEs for ACL %p", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_dec_indent(SMB_DCMD_INDENT);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_OK);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas}
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ********************************* smb_sd_t **********************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ::smbsd
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_sd(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_sd_t sd;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas int rc;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw /*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * An smb_sid address is required.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (!(flags & DCMD_ADDRSPEC))
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_USAGE);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_vread(&sd, sizeof (sd), addr) != sizeof (sd)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to read struct smb_sd at %p", addr);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("SD Revision: %d\n", sd.sd_revision);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("SD Control: %04x\n", sd.sd_control);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_OWNER_DEFAULTED)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\t SE_OWNER_DEFAULTED\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_GROUP_DEFAULTED)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\t SE_GROUP_DEFAULTED\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_DACL_PRESENT)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\t SE_DACL_PRESENT\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_DACL_DEFAULTED)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\t SE_DACL_DEFAULTED\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_SACL_PRESENT)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\t SE_SACL_PRESENT\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_SACL_DEFAULTED)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\t SE_SACL_DEFAULTED\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_DACL_AUTO_INHERIT_REQ)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\t SE_DACL_AUTO_INHERIT_REQ\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_SACL_AUTO_INHERIT_REQ)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\t SE_SACL_AUTO_INHERIT_REQ\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_DACL_AUTO_INHERITED)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\t SE_DACL_AUTO_INHERITED\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_SACL_AUTO_INHERITED)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\t SE_SACL_AUTO_INHERITED\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_DACL_PROTECTED)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\t SE_DACL_PROTECTED\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_SACL_PROTECTED)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\t SE_SACL_PROTECTED\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_SELF_RELATIVE)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\t SE_SELF_RELATIVE\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("SID of Owner: ");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas rc = smb_sid_print((uintptr_t)sd.sd_owner);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (rc != DCMD_OK)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (rc);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\nSID of Group: ");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas rc = smb_sid_print((uintptr_t)sd.sd_group);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (rc != DCMD_OK)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (rc);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_SACL_PRESENT && sd.sd_sacl) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%<b>%<u>System ACL%</u>%</b>\n");
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw (void) mdb_inc_indent(SMB_DCMD_INDENT);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas rc = mdb_call_dcmd("smbacl", (uintptr_t)sd.sd_sacl, flags,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas argc, argv);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw (void) mdb_dec_indent(SMB_DCMD_INDENT);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (rc != DCMD_OK)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (rc);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (sd.sd_control & SE_DACL_PRESENT && sd.sd_dacl) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%<b>%<u>Discretionary ACL%</u>%</b>\n");
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw (void) mdb_inc_indent(SMB_DCMD_INDENT);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas rc = mdb_call_dcmd("smbacl", (uintptr_t)sd.sd_dacl, flags,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas argc, argv);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw (void) mdb_dec_indent(SMB_DCMD_INDENT);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (rc != DCMD_OK)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (rc);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_OK);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ********************************* smb_sid_t *********************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ::smbsid
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*ARGSUSED*/
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_sid(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw /*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * An smb_sid address is required.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (!(flags & DCMD_ADDRSPEC))
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_USAGE);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (smb_sid_print(addr));
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas}
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * smb_sid_print
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_sid_print(uintptr_t addr)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_sid_t sid;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_sid_t *psid;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas size_t sid_size;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas int i;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas uint64_t authority;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
b819cea2f73f98c5662230cc9affc8cc84f77fcfGordon Ross sid_size = OFFSETOF(smb_sid_t, sid_subauth);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_vread(&sid, sid_size, addr) != sid_size) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to read struct smb_sid at %p", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas sid_size += sid.sid_subauthcnt * sizeof (sid.sid_subauth[0]);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas psid = mdb_zalloc(sid_size, UM_SLEEP | UM_GC);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_vread(psid, sid_size, addr) != sid_size) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to read struct smb_sid at %p", addr);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("S-%d", psid->sid_revision);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas authority = 0;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas for (i = 0; i < NT_SID_AUTH_MAX; i++) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas authority += ((uint64_t)psid->sid_authority[i]) <<
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (8 * (NT_SID_AUTH_MAX - 1) - i);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("-%ll", authority);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas for (i = 0; i < psid->sid_subauthcnt; i++)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("-%d", psid->sid_subauth[i]);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_OK);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ********************************* smb_fssd_t ********************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * ::smbfssd
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_fssd(uintptr_t addr, uint_t flags, int argc, const mdb_arg_t *argv)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas smb_fssd_t fssd;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas int rc;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw /*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * An smb_fssd address is required.
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw if (!(flags & DCMD_ADDRSPEC))
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_USAGE);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_vread(&fssd, sizeof (fssd), addr) != sizeof (fssd)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to read struct smb_fssd at %p", addr);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("FSSD secinfo: 0x%x\n", fssd.sd_secinfo);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (fssd.sd_secinfo & SMB_OWNER_SECINFO)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("FSSD uid: %d\n", fssd.sd_uid);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (fssd.sd_secinfo & SMB_GROUP_SECINFO)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("FSSD gid: %d\n", fssd.sd_gid);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (fssd.sd_secinfo & SMB_SACL_SECINFO && fssd.sd_zsacl) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%<b>%<u>System ACL%</u>%</b>\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_inc_indent(SMB_DCMD_INDENT);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas rc = mdb_call_dcmd("smbacl", (uintptr_t)fssd.sd_zsacl, flags,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas argc, argv);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_dec_indent(SMB_DCMD_INDENT);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (rc != DCMD_OK)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (rc);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (fssd.sd_secinfo & SMB_DACL_SECINFO && fssd.sd_zdacl) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_printf("%<b>%<u>Discretionary ACL%</u>%</b>\n");
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_inc_indent(SMB_DCMD_INDENT);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas rc = mdb_call_dcmd("smbacl", (uintptr_t)fssd.sd_zdacl, flags,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas argc, argv);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_dec_indent(SMB_DCMD_INDENT);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (rc != DCMD_OK)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (rc);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw return (DCMD_OK);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * **************************** Utility Funcions *******************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * *****************************************************************************
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * smb_dcmd_getopt
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * This function analyzes the arguments passed in and sets the bit corresponding
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * to the options found in the opts variable.
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * Return Value
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * -1 An error occured during the decoding
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * 0 The decoding was successful
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amwstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_dcmd_getopt(uint_t *opts, int argc, const mdb_arg_t *argv)
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas *opts = 0;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_getopts(argc, argv,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas 's', MDB_OPT_SETBITS, SMB_OPT_SERVER, opts,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas 'e', MDB_OPT_SETBITS, SMB_OPT_SESSION, opts,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas 'r', MDB_OPT_SETBITS, SMB_OPT_REQUEST, opts,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas 'u', MDB_OPT_SETBITS, SMB_OPT_USER, opts,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas 't', MDB_OPT_SETBITS, SMB_OPT_TREE, opts,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas 'f', MDB_OPT_SETBITS, SMB_OPT_OFILE, opts,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas 'd', MDB_OPT_SETBITS, SMB_OPT_ODIR, opts,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas 'w', MDB_OPT_SETBITS, SMB_OPT_WALK, opts,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas 'v', MDB_OPT_SETBITS, SMB_OPT_VERBOSE, opts,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas NULL) != argc)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (-1);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (0);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * smb_dcmd_setopt
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * This function set the arguments corresponding to the bits set in opts.
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * Return Value
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * Number of arguments set.
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_dcmd_setopt(uint_t opts, int max_argc, mdb_arg_t *argv)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas int i;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas int argc = 0;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas for (i = 0; i < SMB_MDB_MAX_OPTS; i++) {
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright if ((opts & smb_opts[i].o_value) && (argc < max_argc)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas argv->a_type = MDB_TYPE_STRING;
148c5f43199ca0b43fc8e3b643aab11cd66ea327Alan Wright argv->a_un.a_str = smb_opts[i].o_name;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas argc++;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas argv++;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (argc);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * smb_obj_expand
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_obj_expand(uintptr_t addr, uint_t opts, const smb_exp_t *x, ulong_t indent)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas int rc = 0;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas int argc;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_arg_t argv[SMB_MDB_MAX_OPTS];
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas argc = smb_dcmd_setopt(opts | SMB_OPT_WALK, SMB_MDB_MAX_OPTS, argv);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_inc_indent(indent);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas while (x->ex_dcmd) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (x->ex_mask & opts) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas rc = mdb_pwalk_dcmd("list", x->ex_dcmd, argc, argv,
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas addr + x->ex_offset);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (rc) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to walk the list of %s in %p",
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas x->ex_name, addr + x->ex_offset);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas break;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas x++;
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas (void) mdb_dec_indent(indent);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (rc);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw/*
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * smb_obj_list
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * Function called by the DCMDs when no address is provided. It expands the
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * tree under the object type associated with the calling DCMD (based on the
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * flags passed in).
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * Return Value
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas *
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * DCMD_OK
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas * DCMD_ERR
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw */
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2easstatic int
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eassmb_obj_list(const char *name, uint_t opts, uint_t flags)
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas{
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas int argc;
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_arg_t argv[SMB_MDB_MAX_OPTS];
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas argc = smb_dcmd_setopt(opts, SMB_MDB_MAX_OPTS, argv);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas if (mdb_call_dcmd("smblist", 0, flags, argc, argv)) {
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas mdb_warn("failed to list %s", name);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_ERR);
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas }
6537f381d2d9e7b4e2f7b29c3e7a3f13be036f2eas return (DCMD_OK);
da6c28aaf62fa55f0fdb8004aa40f88f23bf53f0amw}
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wrightstatic int
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wrightsmb_worker_findstack(uintptr_t addr)
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright{
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright char cmd[80];
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright mdb_arg_t cmdarg;
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright mdb_inc_indent(2);
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright mdb_snprintf(cmd, sizeof (cmd), "<.$c%d", 16);
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright cmdarg.a_type = MDB_TYPE_STRING;
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright cmdarg.a_un.a_str = cmd;
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright (void) mdb_call_dcmd("findstack", addr, DCMD_ADDRSPEC, 1, &cmdarg);
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright mdb_dec_indent(2);
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright mdb_printf("\n");
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright return (DCMD_OK);
fc724630b14603e4c1147df68b7bf45f7de7431fAlan Wright}