1da6c28aaSamw /*
2da6c28aaSamw  * CDDL HEADER START
3da6c28aaSamw  *
4da6c28aaSamw  * The contents of this file are subject to the terms of the
5da6c28aaSamw  * Common Development and Distribution License (the "License").
6da6c28aaSamw  * You may not use this file except in compliance with the License.
7da6c28aaSamw  *
8da6c28aaSamw  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9da6c28aaSamw  * or http://www.opensolaris.org/os/licensing.
10da6c28aaSamw  * See the License for the specific language governing permissions
11da6c28aaSamw  * and limitations under the License.
12da6c28aaSamw  *
13da6c28aaSamw  * When distributing Covered Code, include this CDDL HEADER in each
14da6c28aaSamw  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15da6c28aaSamw  * If applicable, add the following below this CDDL HEADER, with the
16da6c28aaSamw  * fields enclosed by brackets "[]" replaced with your own identifying
17da6c28aaSamw  * information: Portions Copyright [yyyy] [name of copyright owner]
18da6c28aaSamw  *
19da6c28aaSamw  * CDDL HEADER END
20da6c28aaSamw  */
21da6c28aaSamw /*
22*c5866007SKeyur Desai  * Copyright (c) 2007, 2010, Oracle and/or its affiliates. All rights reserved.
23da6c28aaSamw  */
24da6c28aaSamw 
259fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include <sys/list.h>
269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include <assert.h>
27da6c28aaSamw #include <alloca.h>
28da6c28aaSamw #include <door.h>
29da6c28aaSamw #include <errno.h>
30da6c28aaSamw #include <syslog.h>
31da6c28aaSamw #include <unistd.h>
32da6c28aaSamw #include <stdio.h>
33da6c28aaSamw #include <synch.h>
34da6c28aaSamw #include <string.h>
35da6c28aaSamw #include <stdlib.h>
36da6c28aaSamw #include <sys/stat.h>
37da6c28aaSamw #include <fcntl.h>
38da6c28aaSamw #include <pthread.h>
39da6c28aaSamw #include <strings.h>
409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include <smbsrv/smb_door.h>
419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include <smbsrv/smb_xdr.h>
429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include <smbsrv/smb_token.h>
439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include <smbsrv/libmlsvc.h>
449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include <smbsrv/libsmbns.h>
459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include "smbd.h"
46da6c28aaSamw 
47*c5866007SKeyur Desai #define	SMBD_ARG_MAGIC		0x53415247	/* 'SARG' */
48*c5866007SKeyur Desai 
49da6c28aaSamw /*
509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Parameter for door operations.
519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  */
529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States typedef struct smbd_arg {
53*c5866007SKeyur Desai 	uint32_t	magic;
549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	list_node_t	lnd;
559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_doorhdr_t	hdr;
569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	const char	*opname;
579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	char		*data;
589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	size_t		datalen;
599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	char		*rbuf;
609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	size_t		rsize;
61*c5866007SKeyur Desai 	boolean_t	response_ready;
62*c5866007SKeyur Desai 	boolean_t	response_abort;
639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	uint32_t	status;
649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States } smbd_arg_t;
659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * The list contains asynchronous requests that have been initiated
689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * but have not yet been collected (via smbd_dop_async_response).
699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  */
709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States typedef struct smbd_doorsvc {
719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	mutex_t		sd_mutex;
729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	cond_t		sd_cv;
739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	list_t		sd_async_list;
749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	uint32_t	sd_async_count;
759fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States } smbd_doorsvc_t;
769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_null(smbd_arg_t *);
789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_async_response(smbd_arg_t *);
799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_user_auth_logon(smbd_arg_t *);
809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_user_nonauth_logon(smbd_arg_t *);
819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_user_auth_logoff(smbd_arg_t *);
829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_lookup_sid(smbd_arg_t *);
839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_lookup_name(smbd_arg_t *);
849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_join(smbd_arg_t *);
859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_get_dcinfo(smbd_arg_t *);
869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_vss_get_count(smbd_arg_t *);
879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_vss_get_snapshots(smbd_arg_t *);
889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_vss_map_gmttoken(smbd_arg_t *);
899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_ads_find_host(smbd_arg_t *);
909fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_quota_query(smbd_arg_t *);
919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_quota_set(smbd_arg_t *);
929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_dfs_get_referrals(smbd_arg_t *);
939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States typedef int (*smbd_dop_t)(smbd_arg_t *);
959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
969fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States typedef struct smbd_doorop {
979fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_dopcode_t	opcode;
989fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smbd_dop_t	op;
999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States } smbd_doorop_t;
1009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
1019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_doorop_t smbd_doorops[] = {
1029fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_NULL,			smbd_dop_null },
1039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_ASYNC_RESPONSE,	smbd_dop_async_response },
1049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_USER_AUTH_LOGON,	smbd_dop_user_auth_logon },
1059fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_USER_NONAUTH_LOGON,	smbd_dop_user_nonauth_logon },
1069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_USER_AUTH_LOGOFF,	smbd_dop_user_auth_logoff },
1079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_LOOKUP_SID,		smbd_dop_lookup_sid },
1089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_LOOKUP_NAME,		smbd_dop_lookup_name },
1099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_JOIN,			smbd_dop_join },
1109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_GET_DCINFO,		smbd_dop_get_dcinfo },
1119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_VSS_GET_COUNT,		smbd_dop_vss_get_count },
1129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_VSS_GET_SNAPSHOTS,	smbd_dop_vss_get_snapshots },
1139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_VSS_MAP_GMTTOKEN,	smbd_dop_vss_map_gmttoken },
1149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_ADS_FIND_HOST,		smbd_dop_ads_find_host },
1159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_QUOTA_QUERY,		smbd_dop_quota_query },
1169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_QUOTA_SET,		smbd_dop_quota_set },
1179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	{ SMB_DR_DFS_GET_REFERRALS,	smbd_dop_dfs_get_referrals }
1189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States };
1199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
1209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_ndoorop = (sizeof (smbd_doorops) / sizeof (smbd_doorops[0]));
1219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
1229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static smbd_doorsvc_t smbd_doorsvc;
1239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_door_fd = -1;
1249fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_door_cookie = 0x534D4244;	/* SMBD */
1259fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static smbd_door_t smbd_door_sdh;
1269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
1279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static void smbd_door_dispatch(void *, char *, size_t, door_desc_t *, uint_t);
1289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_door_dispatch_async(smbd_arg_t *);
1299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static void smbd_door_release_async(smbd_arg_t *);
1309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static void *smbd_door_dispatch_op(void *);
1319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
1329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
133da6c28aaSamw  * Start the smbd door service.  Create and bind to a door.
134da6c28aaSamw  * Returns 0 on success. Otherwise, -1.
135da6c28aaSamw  */
136da6c28aaSamw int
1379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_start(void)
138da6c28aaSamw {
139da6c28aaSamw 	int	newfd;
140da6c28aaSamw 
1419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) mutex_lock(&smbd_doorsvc.sd_mutex);
142da6c28aaSamw 
1439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smbd_door_fd != -1) {
144da6c28aaSamw 		(void) fprintf(stderr, "smb_doorsrv_start: already started");
1459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) mutex_unlock(&smbd_doorsvc.sd_mutex);
146da6c28aaSamw 		return (-1);
147da6c28aaSamw 	}
148da6c28aaSamw 
1499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smbd_door_init(&smbd_door_sdh, "doorsrv");
1509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
1519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	list_create(&smbd_doorsvc.sd_async_list, sizeof (smbd_arg_t),
1529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    offsetof(smbd_arg_t, lnd));
1539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smbd_doorsvc.sd_async_count = 0;
1549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
1559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if ((smbd_door_fd = door_create(smbd_door_dispatch,
1569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    &smbd_door_cookie, DOOR_UNREF)) < 0) {
157da6c28aaSamw 		(void) fprintf(stderr, "smb_doorsrv_start: door_create: %s",
158da6c28aaSamw 		    strerror(errno));
1599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		smbd_door_fd = -1;
1609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) mutex_unlock(&smbd_doorsvc.sd_mutex);
161da6c28aaSamw 		return (-1);
162da6c28aaSamw 	}
163da6c28aaSamw 
1649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) unlink(SMBD_DOOR_NAME);
165da6c28aaSamw 
1669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if ((newfd = creat(SMBD_DOOR_NAME, 0644)) < 0) {
167da6c28aaSamw 		(void) fprintf(stderr, "smb_doorsrv_start: open: %s",
168da6c28aaSamw 		    strerror(errno));
1699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) door_revoke(smbd_door_fd);
1709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		smbd_door_fd = -1;
1719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) mutex_unlock(&smbd_doorsvc.sd_mutex);
172da6c28aaSamw 		return (-1);
173da6c28aaSamw 	}
174da6c28aaSamw 
175da6c28aaSamw 	(void) close(newfd);
1769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) fdetach(SMBD_DOOR_NAME);
177da6c28aaSamw 
1789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (fattach(smbd_door_fd, SMBD_DOOR_NAME) < 0) {
179da6c28aaSamw 		(void) fprintf(stderr, "smb_doorsrv_start: fattach: %s",
180da6c28aaSamw 		    strerror(errno));
1819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) door_revoke(smbd_door_fd);
1829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		smbd_door_fd = -1;
1839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) mutex_unlock(&smbd_doorsvc.sd_mutex);
184da6c28aaSamw 		return (-1);
185da6c28aaSamw 	}
186da6c28aaSamw 
1879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) mutex_unlock(&smbd_doorsvc.sd_mutex);
1889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (smbd_door_fd);
189da6c28aaSamw }
190da6c28aaSamw 
191da6c28aaSamw /*
192da6c28aaSamw  * Stop the smbd door service.
193da6c28aaSamw  */
194da6c28aaSamw void
1959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_stop(void)
196da6c28aaSamw {
1979fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) mutex_lock(&smbd_doorsvc.sd_mutex);
198da6c28aaSamw 
1999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smbd_door_fini(&smbd_door_sdh);
2009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smbd_door_fd != -1) {
2029fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) fdetach(SMBD_DOOR_NAME);
2039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) door_revoke(smbd_door_fd);
2049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		smbd_door_fd = -1;
205da6c28aaSamw 	}
206da6c28aaSamw 
2079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) mutex_unlock(&smbd_doorsvc.sd_mutex);
2089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
2099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*ARGSUSED*/
2119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static void
2129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_dispatch(void *cookie, char *argp, size_t arg_size, door_desc_t *dp,
2139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States     uint_t n_desc)
2149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
2159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smbd_arg_t	dop_arg;
2169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_doorhdr_t	*hdr;
2179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	size_t		hdr_size;
2189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	char		*rbuf = NULL;
2199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smbd_door_enter(&smbd_door_sdh);
2219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (!smbd_online())
2239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		smbd_door_return(&smbd_door_sdh, NULL, 0, NULL, 0);
2249fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2259fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	bzero(&dop_arg, sizeof (smbd_arg_t));
2269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	hdr = &dop_arg.hdr;
2279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	hdr_size = xdr_sizeof(smb_doorhdr_xdr, hdr);
2289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if ((cookie != &smbd_door_cookie) || (argp == NULL) ||
2309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    (arg_size < hdr_size)) {
2319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		smbd_door_return(&smbd_door_sdh, NULL, 0, NULL, 0);
2329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
2339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2349fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smb_doorhdr_decode(hdr, (uint8_t *)argp, hdr_size) == -1) {
2359fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		syslog(LOG_DEBUG, "smbd_door_dispatch: header decode failed");
2369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		smbd_door_return(&smbd_door_sdh, NULL, 0, NULL, 0);
2379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
2389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if ((hdr->dh_magic != SMB_DOOR_HDR_MAGIC) || (hdr->dh_txid == 0)) {
2409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		syslog(LOG_DEBUG, "smbd_door_dispatch: invalid header");
2419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		smbd_door_return(&smbd_door_sdh, NULL, 0, NULL, 0);
2429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
2439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	dop_arg.opname = smb_doorhdr_opname(hdr->dh_op);
2459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	dop_arg.data = argp + hdr_size;
2469fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	dop_arg.datalen = hdr->dh_datalen;
2479fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (hdr->dh_op == SMB_DR_ASYNC_RESPONSE) {
2499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		/*
2509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		 * ASYNC_RESPONSE is used to collect the response
2519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		 * to an async call; it cannot be an async call.
2529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		 */
2539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		hdr->dh_flags &= ~SMB_DF_ASYNC;
2549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
2559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (hdr->dh_flags & SMB_DF_ASYNC) {
2579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		if (smbd_door_dispatch_async(&dop_arg) == 0)
2589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			hdr->dh_door_rc = SMB_DOP_SUCCESS;
2599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		else
2609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			hdr->dh_door_rc = SMB_DOP_NOT_CALLED;
2619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	} else {
2629fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) smbd_door_dispatch_op(&dop_arg);
2639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
2649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if ((rbuf = (char *)alloca(dop_arg.rsize + hdr_size)) == NULL) {
2669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		errno = ENOMEM;
2679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		syslog(LOG_DEBUG, "smbd_door_dispatch[%s]: alloca %m",
2689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		    dop_arg.opname);
2699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		smbd_door_return(&smbd_door_sdh, NULL, 0, NULL, 0);
2709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
2719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (dop_arg.rbuf != NULL) {
2739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) memcpy(rbuf + hdr_size, dop_arg.rbuf, dop_arg.rsize);
2749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		free(dop_arg.rbuf);
2759fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
2769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	hdr->dh_datalen = dop_arg.rsize;
2789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) smb_doorhdr_encode(hdr, (uint8_t *)rbuf, hdr_size);
2799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	dop_arg.rsize += hdr_size;
2809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
2819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smbd_door_return(&smbd_door_sdh, rbuf, dop_arg.rsize, NULL, 0);
2829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	/*NOTREACHED*/
283da6c28aaSamw }
284da6c28aaSamw 
285da6c28aaSamw /*
2869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Launch a thread to process an asynchronous door call.
287da6c28aaSamw  */
2889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
2899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_dispatch_async(smbd_arg_t *req_arg)
290da6c28aaSamw {
2919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smbd_arg_t	*arg = NULL;
2929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	char		*data = NULL;
2939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	pthread_attr_t	attr;
2949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	pthread_t	tid;
2959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	int		rc;
296da6c28aaSamw 
2979fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if ((req_arg->hdr.dh_flags & SMB_DF_ASYNC) == 0) {
2989fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		errno = EINVAL;
2999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (-1);
3009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
3019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3029fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if ((arg = malloc(sizeof (smbd_arg_t))) == NULL) {
3039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		syslog(LOG_DEBUG, "smbd_door_dispatch_async[%s]: %m",
3049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		    req_arg->opname);
3059fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (-1);
3069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
3079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) memcpy(arg, req_arg, sizeof (smbd_arg_t));
3099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg->data = NULL;
3109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (req_arg->datalen != 0) {
3129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		if ((data = malloc(req_arg->datalen)) == NULL) {
3139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			free(arg);
3149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			syslog(LOG_DEBUG, "smbd_door_dispatch_async[%s]: %m",
3159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			    req_arg->opname);
3169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			return (-1);
3179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		}
3189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) memcpy(data, req_arg->data, req_arg->datalen);
3209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		arg->data = data;
3219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
3229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) mutex_lock(&smbd_doorsvc.sd_mutex);
324*c5866007SKeyur Desai 	arg->magic = SMBD_ARG_MAGIC;
3259fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	list_insert_tail(&smbd_doorsvc.sd_async_list, arg);
3269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	++smbd_doorsvc.sd_async_count;
3279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) mutex_unlock(&smbd_doorsvc.sd_mutex);
3289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) pthread_attr_init(&attr);
3309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
3319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	rc = pthread_create(&tid, &attr, smbd_door_dispatch_op, arg);
3329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) pthread_attr_destroy(&attr);
3339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3349fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (rc != 0) {
3359fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) mutex_lock(&smbd_doorsvc.sd_mutex);
3369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		smbd_door_release_async(arg);
3379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) mutex_unlock(&smbd_doorsvc.sd_mutex);
3389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
3399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (rc);
3419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
3429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
3449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Remove an entry from the async response pending list and free
3459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * the arg and associated data.
3469fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  *
3479fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Must only be called while holding the smbd_doorsvc mutex.
3489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  */
3499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static void
3509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_release_async(smbd_arg_t *arg)
3519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
3529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (arg != NULL) {
353*c5866007SKeyur Desai 		assert(arg->magic == SMBD_ARG_MAGIC);
354*c5866007SKeyur Desai 		arg->magic = (uint32_t)~SMBD_ARG_MAGIC;
355*c5866007SKeyur Desai 
3569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		list_remove(&smbd_doorsvc.sd_async_list, arg);
3579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		--smbd_doorsvc.sd_async_count;
3589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		free(arg->data);
359*c5866007SKeyur Desai 		arg->data = NULL;
3609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		free(arg);
3619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
3629fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
3639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
3659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * All door calls are processed here: synchronous or asynchronous:
3669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * - synchronous calls are invoked by direct function call
3679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * - asynchronous calls are invoked from a launched thread
3689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  *
369*c5866007SKeyur Desai  * If the kernel has attempted to collect a response before the op
370*c5866007SKeyur Desai  * has completed, the arg will have been marked as response_abort
371*c5866007SKeyur Desai  * and we can discard the response data and release the arg.
372*c5866007SKeyur Desai  *
3739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * We send a notification when asynchronous (ASYNC) door calls
3749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * from the kernel (SYSSPACE) have completed.
3759fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  */
3769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static void *
3779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_dispatch_op(void *thread_arg)
3789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
3799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smbd_arg_t	*arg = (smbd_arg_t *)thread_arg;
3809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smbd_doorop_t	*doorop;
3819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_doorhdr_t	*hdr;
3829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	int		i;
3839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if ((!smbd_online()) || arg == NULL)
3859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (NULL);
3869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	hdr = &arg->hdr;
3889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg->opname = smb_doorhdr_opname(hdr->dh_op);
3899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3909fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	for (i = 0; i < smbd_ndoorop; ++i) {
3919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		doorop = &smbd_doorops[i];
3929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		if (hdr->dh_op == doorop->opcode) {
3949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			hdr->dh_door_rc = doorop->op(arg);
3959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			hdr->dh_status = arg->status;
3969fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
3979fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			if ((hdr->dh_flags & SMB_DF_SYSSPACE) &&
3989fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			    (hdr->dh_flags & SMB_DF_ASYNC)) {
3999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 				assert(hdr->dh_op != SMB_DR_ASYNC_RESPONSE);
400*c5866007SKeyur Desai 
401*c5866007SKeyur Desai 				(void) mutex_lock(&smbd_doorsvc.sd_mutex);
402*c5866007SKeyur Desai 				if (arg->response_abort) {
403*c5866007SKeyur Desai 					free(arg->rbuf);
404*c5866007SKeyur Desai 					arg->rbuf = NULL;
405*c5866007SKeyur Desai 					smbd_door_release_async(arg);
406*c5866007SKeyur Desai 				} else {
407*c5866007SKeyur Desai 					arg->response_ready = B_TRUE;
408*c5866007SKeyur Desai 				}
409*c5866007SKeyur Desai 				(void) mutex_unlock(&smbd_doorsvc.sd_mutex);
410*c5866007SKeyur Desai 
4119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 				(void) smb_kmod_event_notify(hdr->dh_txid);
4129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			}
4139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
4149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			return (NULL);
4159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		}
4169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
4179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
4189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	syslog(LOG_ERR, "smbd_door_dispatch_op[%s]: invalid op %u",
4199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    arg->opname, hdr->dh_op);
420da6c28aaSamw 	return (NULL);
421da6c28aaSamw }
422da6c28aaSamw 
4239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
4249fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Wrapper for door_return.  smbd_door_enter() increments a reference count
4259fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * when a door call is dispatched and smbd_door_return() decrements the
4269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * reference count when it completes.
4279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  *
4289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * The reference counting is used in smbd_door_fini() to wait for active
4299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * calls to complete before closing the door.
4309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  */
4319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States void
4329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_init(smbd_door_t *sdh, const char *name)
4339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
4349fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) strlcpy(sdh->sd_name, name, SMBD_DOOR_NAMESZ);
4359fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
4369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
4379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States void
4389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_enter(smbd_door_t *sdh)
4399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
4409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) mutex_lock(&sdh->sd_mutex);
4419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	++sdh->sd_ncalls;
4429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) mutex_unlock(&sdh->sd_mutex);
443da6c28aaSamw }
444da6c28aaSamw 
445da6c28aaSamw /*
4469fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * We have two calls to door_return because the first call (with data)
4479fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * can fail, which can leave the door call blocked here.  The second
4489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * call (with NULL) is guaranteed to unblock and return to the caller.
4499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  */
4509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States void
4519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_return(smbd_door_t *sdh, char *data_ptr, size_t data_size,
4529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States     door_desc_t *desc_ptr, uint_t num_desc)
4539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
4549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) mutex_lock(&sdh->sd_mutex);
4559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
4569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (sdh->sd_ncalls == 0)
4579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		syslog(LOG_ERR, "smbd_door_return[%s]: unexpected count=0",
4589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		    sdh->sd_name);
4599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	else
4609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		--sdh->sd_ncalls;
4619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
4629fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) cond_broadcast(&sdh->sd_cv);
4639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) mutex_unlock(&sdh->sd_mutex);
4649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
4659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) door_return(data_ptr, data_size, desc_ptr, num_desc);
4669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) door_return(NULL, 0, NULL, 0);
4679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	/* NOTREACHED */
4689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
4699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
4709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
4719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * A door service is about to terminate.
4729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Give active requests a small grace period to complete.
4739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  */
4749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States void
4759fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_fini(smbd_door_t *sdh)
4769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
4779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	timestruc_t	delay;
4789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	int		rc = 0;
4799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
4809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) mutex_lock(&sdh->sd_mutex);
4819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
4829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	while (rc != ETIME && sdh->sd_ncalls != 0) {
4839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		delay.tv_sec = 1;
4849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		delay.tv_nsec = 0;
4859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		rc = cond_reltimedwait(&sdh->sd_cv, &sdh->sd_mutex, &delay);
4869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
4879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
4889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (sdh->sd_ncalls != 0)
4899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		syslog(LOG_NOTICE, "smbd_door_fini[%s]: %d remaining",
4909fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		    sdh->sd_name, sdh->sd_ncalls);
4919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
4929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) mutex_unlock(&sdh->sd_mutex);
4939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
4949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
4959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
4969fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Null door operation: always returns success.
4979fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Assumes no request or response data.
498da6c28aaSamw  */
499da6c28aaSamw /*ARGSUSED*/
5009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
5019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_null(smbd_arg_t *arg)
502da6c28aaSamw {
5039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
5043ad684d6Sjb150015 }
5053ad684d6Sjb150015 
5069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
5079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Async response handler: setup the rbuf and rsize for the specified
5089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * transaction.  This function is used by the kernel to collect the
5099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * response half of an asynchronous door call.
510*c5866007SKeyur Desai  *
511*c5866007SKeyur Desai  * If a door client attempts to collect a response before the op has
512*c5866007SKeyur Desai  * completed (!response_ready), mark the arg as response_abort and
513*c5866007SKeyur Desai  * set an error.  The response will be discarded when the op completes.
5149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  */
5159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
5169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_async_response(smbd_arg_t *rsp_arg)
5179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
5189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	list_t		*arg_list = &smbd_doorsvc.sd_async_list;
5199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smbd_arg_t	*arg;
5209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
5219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) mutex_lock(&smbd_doorsvc.sd_mutex);
5229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg = list_head(arg_list);
5239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
5249fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	while (arg != NULL) {
525*c5866007SKeyur Desai 		assert(arg->magic == SMBD_ARG_MAGIC);
526*c5866007SKeyur Desai 
5279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		if (arg->hdr.dh_txid == rsp_arg->hdr.dh_txid) {
528*c5866007SKeyur Desai 			if (!arg->response_ready) {
529*c5866007SKeyur Desai 				arg->response_abort = B_TRUE;
530*c5866007SKeyur Desai 				rsp_arg->hdr.dh_door_rc = SMB_DOP_NOT_CALLED;
531*c5866007SKeyur Desai 				syslog(LOG_NOTICE, "doorsvc[%s]: %u not ready",
532*c5866007SKeyur Desai 				    arg->opname, arg->hdr.dh_txid);
533*c5866007SKeyur Desai 				break;
534*c5866007SKeyur Desai 			}
535*c5866007SKeyur Desai 
5369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			rsp_arg->rbuf = arg->rbuf;
5379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			rsp_arg->rsize = arg->rsize;
5389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			arg->rbuf = NULL;
5399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			arg->rsize = 0;
5409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			smbd_door_release_async(arg);
5419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			break;
542da6c28aaSamw 		}
543da6c28aaSamw 
5449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		arg = list_next(arg_list, arg);
545da6c28aaSamw 	}
546da6c28aaSamw 
5479fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	(void) mutex_unlock(&smbd_doorsvc.sd_mutex);
5489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
5499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
5509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
5519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
5529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_user_nonauth_logon(smbd_arg_t *arg)
5539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
554*c5866007SKeyur Desai 	uint32_t	sid = 0;
5559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
5569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smb_common_decode(arg->data, arg->datalen,
5579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    xdr_uint32_t, &sid) != 0)
5589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_DECODE_ERROR);
5599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
5609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smbd_user_nonauth_logon(sid);
5619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
5629fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
5639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
5649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
5659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_user_auth_logoff(smbd_arg_t *arg)
5669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
567*c5866007SKeyur Desai 	uint32_t	sid = 0;
5689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
5699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smb_common_decode(arg->data, arg->datalen,
5709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    xdr_uint32_t, &sid) != 0)
5719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_DECODE_ERROR);
5729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
5739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smbd_user_auth_logoff(sid);
5749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
5759fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
5769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
5779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
5789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Obtains an access token on successful user authentication.
5799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  */
5809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
5819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_user_auth_logon(smbd_arg_t *arg)
5829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
5839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_logon_t	*user_info;
5849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_token_t	*token;
5859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
5869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	user_info = smb_logon_decode((uint8_t *)arg->data,
5879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    arg->datalen);
5889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (user_info == NULL)
5899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_DECODE_ERROR);
5909fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
5919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	token = smbd_user_auth_logon(user_info);
5929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
5939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_logon_free(user_info);
5949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
5959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (token == NULL)
5969fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_EMPTYBUF);
5979fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
5989fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg->rbuf = (char *)smb_token_encode(token, &arg->rsize);
5999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_token_destroy(token);
6009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
6019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (arg->rbuf == NULL)
6029fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_ENCODE_ERROR);
6039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
6049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
6059fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
6069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
6079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_lookup_name(smbd_arg_t *arg)
6089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
6099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_domain_t	dinfo;
6109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_account_t	ainfo;
6119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	lsa_account_t	acct;
6129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	char		buf[MAXNAMELEN];
6139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
614*c5866007SKeyur Desai 	bzero(&acct, sizeof (lsa_account_t));
615*c5866007SKeyur Desai 
6169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smb_common_decode(arg->data, arg->datalen,
6179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    lsa_account_xdr, &acct) != 0)
6189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_DECODE_ERROR);
6199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
6209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (*acct.a_domain == '\0')
6219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) snprintf(buf, MAXNAMELEN, "%s", acct.a_name);
6229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	else if (strchr(acct.a_domain, '.') != NULL)
6239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) snprintf(buf, MAXNAMELEN, "%s@%s", acct.a_name,
6249fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		    acct.a_domain);
625da6c28aaSamw 	else
6269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) snprintf(buf, MAXNAMELEN, "%s\\%s", acct.a_domain,
6279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		    acct.a_name);
6289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
6299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	acct.a_status = lsa_lookup_name(buf, acct.a_sidtype, &ainfo);
6309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (acct.a_status == NT_STATUS_SUCCESS) {
6319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		acct.a_sidtype = ainfo.a_type;
6329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		smb_sid_tostr(ainfo.a_sid, acct.a_sid);
6339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) strlcpy(acct.a_name, ainfo.a_name, MAXNAMELEN);
6349fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
6359fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		if (smb_domain_lookup_name(ainfo.a_domain, &dinfo))
6369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			(void) strlcpy(acct.a_domain, dinfo.di_fqname,
6379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			    MAXNAMELEN);
6389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		else
6399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			(void) strlcpy(acct.a_domain, ainfo.a_domain,
6409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			    MAXNAMELEN);
6419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		smb_account_free(&ainfo);
642da6c28aaSamw 	}
643da6c28aaSamw 
6449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg->rbuf = smb_common_encode(&acct, lsa_account_xdr, &arg->rsize);
6459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
6469fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (arg->rbuf == NULL)
6479fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_ENCODE_ERROR);
6489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
6499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
6509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
6519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
6529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_lookup_sid(smbd_arg_t *arg)
6539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
6549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_domain_t	dinfo;
6559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_account_t	ainfo;
6569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	lsa_account_t	acct;
6579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_sid_t	*sid;
6589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
659*c5866007SKeyur Desai 	bzero(&acct, sizeof (lsa_account_t));
660*c5866007SKeyur Desai 
6619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smb_common_decode(arg->data, arg->datalen,
6629fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    lsa_account_xdr, &acct) != 0)
6639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_DECODE_ERROR);
6649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
6659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	sid = smb_sid_fromstr(acct.a_sid);
6669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	acct.a_status = lsa_lookup_sid(sid, &ainfo);
6679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_sid_free(sid);
6689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
6699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (acct.a_status == NT_STATUS_SUCCESS) {
6709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		acct.a_sidtype = ainfo.a_type;
6719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		smb_sid_tostr(ainfo.a_sid, acct.a_sid);
6729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		(void) strlcpy(acct.a_name, ainfo.a_name, MAXNAMELEN);
6739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
6749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		if (smb_domain_lookup_name(ainfo.a_domain, &dinfo))
6759fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			(void) strlcpy(acct.a_domain, dinfo.di_fqname,
6769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			    MAXNAMELEN);
6779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		else
6789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			(void) strlcpy(acct.a_domain, ainfo.a_domain,
6799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			    MAXNAMELEN);
6809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
6819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		smb_account_free(&ainfo);
6829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
6839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
6849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg->rbuf = smb_common_encode(&acct, lsa_account_xdr, &arg->rsize);
6859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
6869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (arg->rbuf == NULL)
6879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_ENCODE_ERROR);
6889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
6899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
6909fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
6919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
6929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_join(smbd_arg_t *arg)
6939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
6949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_joininfo_t	jdi;
6959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	uint32_t	status;
6969fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
697*c5866007SKeyur Desai 	bzero(&jdi, sizeof (smb_joininfo_t));
698*c5866007SKeyur Desai 
6999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smb_common_decode(arg->data, arg->datalen,
7009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    smb_joininfo_xdr, &jdi) != 0)
7019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_DECODE_ERROR);
7029fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	status = smbd_join(&jdi);
7049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7059fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg->rbuf = smb_common_encode(&status, xdr_uint32_t, &arg->rsize);
7069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (arg->rbuf == NULL)
7089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_ENCODE_ERROR);
7099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
7109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
7119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
7139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_get_dcinfo(smbd_arg_t *arg)
7149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
7159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_domainex_t	dxi;
7169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (!smb_domain_getinfo(&dxi))
7189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_EMPTYBUF);
7199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg->rbuf = smb_string_encode(dxi.d_dc, &arg->rsize);
7219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (arg->rbuf == NULL)
7239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_ENCODE_ERROR);
7249fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
7259fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
7269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
7289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Return the number of snapshots for a dataset
7299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  */
7309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
7319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_vss_get_count(smbd_arg_t *arg)
7329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
7339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_string_t	path;
7349fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	uint32_t	count;
7359fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	bzero(&path, sizeof (smb_string_t));
7379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg->rbuf = NULL;
7389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smb_string_decode(&path, arg->data, arg->datalen) != 0)
7409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_DECODE_ERROR);
7419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smbd_vss_get_count(path.buf, &count) == 0)
7439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		arg->rbuf = smb_common_encode(&count, xdr_uint32_t,
7449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		    &arg->rsize);
7459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7469fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	xdr_free(smb_string_xdr, (char *)&path);
7479fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (arg->rbuf == NULL)
7499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_ENCODE_ERROR);
7509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
7519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
7529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
7549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Return the count and list of snapshots.
7559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * The list is in @GMT token format.
7569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  */
7579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
7589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_vss_get_snapshots(smbd_arg_t *arg)
7599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
7609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	char				**gmtp;
7619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_gmttoken_query_t		request;
7629fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_gmttoken_response_t		reply;
7639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	uint_t				i;
7649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	bzero(&request, sizeof (smb_gmttoken_query_t));
7669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	bzero(&reply, sizeof (smb_gmttoken_response_t));
7679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smb_common_decode(arg->data, arg->datalen,
7699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    smb_gmttoken_query_xdr, &request) != 0)
7709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_DECODE_ERROR);
7719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	reply.gtr_gmttokens.gtr_gmttokens_val = malloc(request.gtq_count *
7739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    sizeof (char *));
7749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	bzero(reply.gtr_gmttokens.gtr_gmttokens_val, request.gtq_count *
7759fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    sizeof (char *));
7769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (reply.gtr_gmttokens.gtr_gmttokens_val == NULL) {
7789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		xdr_free(smb_gmttoken_query_xdr, (char *)&request);
7799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_EMPTYBUF);
7809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
7819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smbd_vss_get_snapshots(request.gtq_path, request.gtq_count,
7839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    &reply.gtr_count,
7849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    &reply.gtr_gmttokens.gtr_gmttokens_len,
7859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    reply.gtr_gmttokens.gtr_gmttokens_val);
7869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg->rbuf = smb_common_encode(&reply, smb_gmttoken_response_xdr,
7889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    &arg->rsize);
7899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (arg->rbuf == NULL) {
7909fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		xdr_free(smb_gmttoken_query_xdr, (char *)&request);
7919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_ENCODE_ERROR);
7929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
7939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
7949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	for (i = 0, gmtp = reply.gtr_gmttokens.gtr_gmttokens_val;
7959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    (i < request.gtq_count); i++) {
7969fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		if (*gmtp)
7979fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 			free(*gmtp);
7989fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		gmtp++;
7999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
8009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	free(reply.gtr_gmttokens.gtr_gmttokens_val);
8029fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	xdr_free(smb_gmttoken_query_xdr, (char *)&request);
8039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
8049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
8059fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
8079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Return the name of the snapshot that matches the dataset path
8089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * and @GMT token.
8099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  */
8109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
8119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_vss_map_gmttoken(smbd_arg_t *arg)
8129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
8139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	char			*snapname;
8149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_gmttoken_snapname_t	request;
8159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	bzero(&request, sizeof (smb_gmttoken_snapname_t));
8179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smb_common_decode(arg->data, arg->datalen,
8199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    smb_gmttoken_snapname_xdr, &request) != 0) {
8209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		xdr_free(smb_gmttoken_snapname_xdr, (char *)&request);
8219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_DECODE_ERROR);
8229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
8239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8249fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if ((snapname = malloc(MAXPATHLEN)) == NULL) {
8259fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		xdr_free(smb_gmttoken_snapname_xdr, (char *)&request);
8269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (NULL);
8279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
8289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if ((smbd_vss_map_gmttoken(request.gts_path, request.gts_gmttoken,
8309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    snapname) != 0)) {
8319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		*snapname = '\0';
8329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	}
8339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8349fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg->rbuf = smb_string_encode(snapname, &arg->rsize);
8359fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	xdr_free(smb_gmttoken_snapname_xdr, (char *)&request);
8369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	free(snapname);
8379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (arg->rbuf == NULL)
8399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_ENCODE_ERROR);
8409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
8419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
8429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
8449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_ads_find_host(smbd_arg_t *arg)
8459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
8469fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_ads_host_info_t	*hinfo = NULL;
8479fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	char			*hostname = "";
8489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_string_t		fqdn;
8499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	bzero(&fqdn, sizeof (smb_string_t));
8519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smb_string_decode(&fqdn, arg->data, arg->datalen) != 0)
8539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_DECODE_ERROR);
8549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if ((hinfo = smb_ads_find_host(fqdn.buf, NULL)) != NULL)
8569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		hostname = hinfo->name;
8579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	xdr_free(smb_string_xdr, (char *)&fqdn);
8599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg->rbuf = smb_string_encode(hostname, &arg->rsize);
8619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	free(hinfo);
8629fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (arg->rbuf == NULL)
8649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_ENCODE_ERROR);
8659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
8669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
8679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
8699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Query the list of user/group quota entries for a given filesystem.
8709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  */
8719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
8729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_quota_query(smbd_arg_t *arg)
8739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
8749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_quota_query_t	request;
8759fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_quota_response_t	reply;
8769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	uint32_t		status;
8779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	bzero(&request, sizeof (smb_quota_query_t));
8799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	bzero(&reply, sizeof (smb_quota_response_t));
8809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smb_common_decode(arg->data, arg->datalen,
8829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    smb_quota_query_xdr, &request) != 0)
8839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_DECODE_ERROR);
8849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	status = smb_quota_query(&request, &reply);
8869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	reply.qr_status = status;
8879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg->rbuf = smb_common_encode(&reply, smb_quota_response_xdr,
8899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    &arg->rsize);
8909fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	xdr_free(smb_quota_query_xdr, (char *)&request);
8929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_quota_free(&reply);
8939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (arg->rbuf == NULL)
8959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_ENCODE_ERROR);
8969fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
8979fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
8989fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
8999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
9009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  * Set a list of user/group quota entries for a given filesystem.
9019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States  */
9029fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
9039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_quota_set(smbd_arg_t *arg)
9049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
9059fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	smb_quota_set_t	request;
9069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	uint32_t	status = 0;
9079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
9089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	bzero(&request, sizeof (smb_quota_set_t));
9099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
9109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smb_common_decode(arg->data, arg->datalen,
9119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    smb_quota_set_xdr, &request) != 0)
9129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_DECODE_ERROR);
9139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
9149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	status = smb_quota_set(&request);
9159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
9169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg->rbuf = smb_common_encode(&status, xdr_uint32_t, &arg->rsize);
9179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	xdr_free(smb_quota_set_xdr, (char *)&request);
9189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
9199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (arg->rbuf == NULL)
9209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_ENCODE_ERROR);
9219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
9229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
9239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
9249fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
9259fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_dfs_get_referrals(smbd_arg_t *arg)
9269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
9279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	dfs_referral_query_t	request;
9289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	dfs_referral_response_t	reply;
9299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
9309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	bzero(&request, sizeof (request));
9319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	bzero(&reply, sizeof (reply));
9329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
9339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (smb_common_decode(arg->data, arg->datalen,
9349fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    dfs_referral_query_xdr, &request) != 0)
9359fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_DECODE_ERROR);
9369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
9379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	reply.rp_status = dfs_get_referrals((const char *)request.rq_path,
9389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    request.rq_type, &reply.rp_referrals);
9399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
9409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (reply.rp_status != ERROR_SUCCESS)
9419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		bzero(&reply.rp_referrals, sizeof (dfs_info_t));
9429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
9439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	arg->rbuf = smb_common_encode(&reply, dfs_referral_response_xdr,
9449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	    &arg->rsize);
9459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
9469fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (reply.rp_status == ERROR_SUCCESS)
9479fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		dfs_info_free(&reply.rp_referrals);
9489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
9499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	xdr_free(dfs_referral_query_xdr, (char *)&request);
9509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 
9519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	if (arg->rbuf == NULL)
9529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 		return (SMB_DOP_ENCODE_ERROR);
9539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States 	return (SMB_DOP_SUCCESS);
954da6c28aaSamw }
955