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 /*
22c5866007SKeyur Desai * Copyright (c) 2007, 2010, Oracle and/or its affiliates. All rights reserved.
23*b819cea2SGordon Ross * Copyright 2013 Nexenta Systems, Inc. All rights reserved.
24da6c28aaSamw */
25da6c28aaSamw
269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include <sys/list.h>
279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include <assert.h>
28da6c28aaSamw #include <alloca.h>
29da6c28aaSamw #include <door.h>
30da6c28aaSamw #include <errno.h>
31da6c28aaSamw #include <syslog.h>
32da6c28aaSamw #include <unistd.h>
33da6c28aaSamw #include <stdio.h>
34da6c28aaSamw #include <synch.h>
35da6c28aaSamw #include <string.h>
36da6c28aaSamw #include <stdlib.h>
37da6c28aaSamw #include <sys/stat.h>
38da6c28aaSamw #include <fcntl.h>
39da6c28aaSamw #include <pthread.h>
40da6c28aaSamw #include <strings.h>
419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include <smbsrv/smb_door.h>
429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include <smbsrv/smb_xdr.h>
439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include <smbsrv/smb_token.h>
449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include <smbsrv/libmlsvc.h>
459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include <smbsrv/libsmbns.h>
469fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States #include "smbd.h"
47da6c28aaSamw
489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * The list contains asynchronous requests that have been initiated
509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * but have not yet been collected (via smbd_dop_async_response).
519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States */
529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States typedef struct smbd_doorsvc {
539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States mutex_t sd_mutex;
549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States cond_t sd_cv;
559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States list_t sd_async_list;
569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States uint32_t sd_async_count;
579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States } smbd_doorsvc_t;
589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_null(smbd_arg_t *);
609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_async_response(smbd_arg_t *);
619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_user_auth_logon(smbd_arg_t *);
629fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_user_nonauth_logon(smbd_arg_t *);
639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_user_auth_logoff(smbd_arg_t *);
649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_lookup_sid(smbd_arg_t *);
659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_lookup_name(smbd_arg_t *);
669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_join(smbd_arg_t *);
679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_get_dcinfo(smbd_arg_t *);
689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_vss_get_count(smbd_arg_t *);
699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_vss_get_snapshots(smbd_arg_t *);
709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_vss_map_gmttoken(smbd_arg_t *);
719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_ads_find_host(smbd_arg_t *);
729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_quota_query(smbd_arg_t *);
739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_quota_set(smbd_arg_t *);
749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_dop_dfs_get_referrals(smbd_arg_t *);
75148c5f43SAlan Wright static int smbd_dop_shr_hostaccess(smbd_arg_t *);
76148c5f43SAlan Wright static int smbd_dop_shr_exec(smbd_arg_t *);
779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States typedef int (*smbd_dop_t)(smbd_arg_t *);
799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States typedef struct smbd_doorop {
819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_dopcode_t opcode;
829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_t op;
839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States } smbd_doorop_t;
849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_doorop_t smbd_doorops[] = {
869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_NULL, smbd_dop_null },
879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_ASYNC_RESPONSE, smbd_dop_async_response },
889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_USER_AUTH_LOGON, smbd_dop_user_auth_logon },
899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_USER_NONAUTH_LOGON, smbd_dop_user_nonauth_logon },
909fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_USER_AUTH_LOGOFF, smbd_dop_user_auth_logoff },
919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_LOOKUP_SID, smbd_dop_lookup_sid },
929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_LOOKUP_NAME, smbd_dop_lookup_name },
939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_JOIN, smbd_dop_join },
949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_GET_DCINFO, smbd_dop_get_dcinfo },
959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_VSS_GET_COUNT, smbd_dop_vss_get_count },
969fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_VSS_GET_SNAPSHOTS, smbd_dop_vss_get_snapshots },
979fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_VSS_MAP_GMTTOKEN, smbd_dop_vss_map_gmttoken },
989fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_ADS_FIND_HOST, smbd_dop_ads_find_host },
999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_QUOTA_QUERY, smbd_dop_quota_query },
1009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States { SMB_DR_QUOTA_SET, smbd_dop_quota_set },
101148c5f43SAlan Wright { SMB_DR_DFS_GET_REFERRALS, smbd_dop_dfs_get_referrals },
102148c5f43SAlan Wright { SMB_DR_SHR_HOSTACCESS, smbd_dop_shr_hostaccess },
103148c5f43SAlan Wright { SMB_DR_SHR_EXEC, smbd_dop_shr_exec }
1049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States };
1059fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
1069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_ndoorop = (sizeof (smbd_doorops) / sizeof (smbd_doorops[0]));
1079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
1089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static smbd_doorsvc_t smbd_doorsvc;
1099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_door_fd = -1;
1109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_door_cookie = 0x534D4244; /* SMBD */
1119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static smbd_door_t smbd_door_sdh;
112*b819cea2SGordon Ross static char *smbd_door_name = NULL;
1139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
1149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static void smbd_door_dispatch(void *, char *, size_t, door_desc_t *, uint_t);
1159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int smbd_door_dispatch_async(smbd_arg_t *);
1169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static void smbd_door_release_async(smbd_arg_t *);
1179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
1189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
119da6c28aaSamw * Start the smbd door service. Create and bind to a door.
120da6c28aaSamw * Returns 0 on success. Otherwise, -1.
121da6c28aaSamw */
122da6c28aaSamw int
smbd_door_start(void)1239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_start(void)
124da6c28aaSamw {
125da6c28aaSamw int newfd;
126da6c28aaSamw
1279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_lock(&smbd_doorsvc.sd_mutex);
128da6c28aaSamw
1299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smbd_door_fd != -1) {
130da6c28aaSamw (void) fprintf(stderr, "smb_doorsrv_start: already started");
1319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_unlock(&smbd_doorsvc.sd_mutex);
132da6c28aaSamw return (-1);
133da6c28aaSamw }
134da6c28aaSamw
135*b819cea2SGordon Ross smbd_door_name = getenv("SMBD_DOOR_NAME");
136*b819cea2SGordon Ross if (smbd_door_name == NULL)
137*b819cea2SGordon Ross smbd_door_name = SMBD_DOOR_NAME;
138*b819cea2SGordon Ross
1399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_init(&smbd_door_sdh, "doorsrv");
1409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
1419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States list_create(&smbd_doorsvc.sd_async_list, sizeof (smbd_arg_t),
1429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States offsetof(smbd_arg_t, lnd));
1439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_doorsvc.sd_async_count = 0;
1449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
1459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if ((smbd_door_fd = door_create(smbd_door_dispatch,
1469fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States &smbd_door_cookie, DOOR_UNREF)) < 0) {
147da6c28aaSamw (void) fprintf(stderr, "smb_doorsrv_start: door_create: %s",
148da6c28aaSamw strerror(errno));
1499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_fd = -1;
1509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_unlock(&smbd_doorsvc.sd_mutex);
151da6c28aaSamw return (-1);
152da6c28aaSamw }
153da6c28aaSamw
154*b819cea2SGordon Ross (void) unlink(smbd_door_name);
155da6c28aaSamw
156*b819cea2SGordon Ross if ((newfd = creat(smbd_door_name, 0644)) < 0) {
157da6c28aaSamw (void) fprintf(stderr, "smb_doorsrv_start: open: %s",
158da6c28aaSamw strerror(errno));
1599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) door_revoke(smbd_door_fd);
1609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_fd = -1;
1619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_unlock(&smbd_doorsvc.sd_mutex);
162da6c28aaSamw return (-1);
163da6c28aaSamw }
164da6c28aaSamw
165da6c28aaSamw (void) close(newfd);
166*b819cea2SGordon Ross (void) fdetach(smbd_door_name);
167da6c28aaSamw
168*b819cea2SGordon Ross if (fattach(smbd_door_fd, smbd_door_name) < 0) {
169da6c28aaSamw (void) fprintf(stderr, "smb_doorsrv_start: fattach: %s",
170da6c28aaSamw strerror(errno));
1719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) door_revoke(smbd_door_fd);
1729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_fd = -1;
1739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_unlock(&smbd_doorsvc.sd_mutex);
174da6c28aaSamw return (-1);
175da6c28aaSamw }
176da6c28aaSamw
1779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_unlock(&smbd_doorsvc.sd_mutex);
1789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (smbd_door_fd);
179da6c28aaSamw }
180da6c28aaSamw
181da6c28aaSamw /*
182da6c28aaSamw * Stop the smbd door service.
183da6c28aaSamw */
184da6c28aaSamw void
smbd_door_stop(void)1859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_stop(void)
186da6c28aaSamw {
1879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_lock(&smbd_doorsvc.sd_mutex);
188da6c28aaSamw
1899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_fini(&smbd_door_sdh);
1909fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
191*b819cea2SGordon Ross if (smbd_door_name)
192*b819cea2SGordon Ross (void) fdetach(smbd_door_name);
193*b819cea2SGordon Ross
1949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smbd_door_fd != -1) {
1959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) door_revoke(smbd_door_fd);
1969fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_fd = -1;
197da6c28aaSamw }
198da6c28aaSamw
1999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_unlock(&smbd_doorsvc.sd_mutex);
2009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
2019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
2029fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*ARGSUSED*/
2039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static void
smbd_door_dispatch(void * cookie,char * argp,size_t arg_size,door_desc_t * dp,uint_t n_desc)2049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_dispatch(void *cookie, char *argp, size_t arg_size, door_desc_t *dp,
2059fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States uint_t n_desc)
2069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
2079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_arg_t dop_arg;
2089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_doorhdr_t *hdr;
2099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States size_t hdr_size;
2109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States char *rbuf = NULL;
2119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
2129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_enter(&smbd_door_sdh);
2139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
2149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (!smbd_online())
2159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_return(&smbd_door_sdh, NULL, 0, NULL, 0);
2169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
2179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States bzero(&dop_arg, sizeof (smbd_arg_t));
2189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States hdr = &dop_arg.hdr;
2199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States hdr_size = xdr_sizeof(smb_doorhdr_xdr, hdr);
2209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
2219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if ((cookie != &smbd_door_cookie) || (argp == NULL) ||
2229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (arg_size < hdr_size)) {
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
2269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_doorhdr_decode(hdr, (uint8_t *)argp, hdr_size) == -1) {
2279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States syslog(LOG_DEBUG, "smbd_door_dispatch: header decode failed");
2289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_return(&smbd_door_sdh, NULL, 0, NULL, 0);
2299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
2309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
2319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if ((hdr->dh_magic != SMB_DOOR_HDR_MAGIC) || (hdr->dh_txid == 0)) {
2329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States syslog(LOG_DEBUG, "smbd_door_dispatch: invalid header");
2339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_return(&smbd_door_sdh, NULL, 0, NULL, 0);
2349fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
2359fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
2369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States dop_arg.opname = smb_doorhdr_opname(hdr->dh_op);
2379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States dop_arg.data = argp + hdr_size;
2389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States dop_arg.datalen = hdr->dh_datalen;
2399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
2409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (hdr->dh_op == SMB_DR_ASYNC_RESPONSE) {
2419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
2429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * ASYNC_RESPONSE is used to collect the response
2439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * to an async call; it cannot be an async call.
2449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States */
2459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States hdr->dh_flags &= ~SMB_DF_ASYNC;
2469fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
2479fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
2489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (hdr->dh_flags & SMB_DF_ASYNC) {
2499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smbd_door_dispatch_async(&dop_arg) == 0)
2509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States hdr->dh_door_rc = SMB_DOP_SUCCESS;
2519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States else
2529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States hdr->dh_door_rc = SMB_DOP_NOT_CALLED;
2539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States } else {
2549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) smbd_door_dispatch_op(&dop_arg);
2559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
2569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
2579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if ((rbuf = (char *)alloca(dop_arg.rsize + hdr_size)) == NULL) {
2589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States errno = ENOMEM;
2599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States syslog(LOG_DEBUG, "smbd_door_dispatch[%s]: alloca %m",
2609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States dop_arg.opname);
2619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_return(&smbd_door_sdh, NULL, 0, NULL, 0);
2629fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
2639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
2649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (dop_arg.rbuf != NULL) {
2659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) memcpy(rbuf + hdr_size, dop_arg.rbuf, dop_arg.rsize);
2669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States free(dop_arg.rbuf);
2679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
2689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
2699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States hdr->dh_datalen = dop_arg.rsize;
2709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) smb_doorhdr_encode(hdr, (uint8_t *)rbuf, hdr_size);
2719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States dop_arg.rsize += hdr_size;
2729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
2739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_return(&smbd_door_sdh, rbuf, dop_arg.rsize, NULL, 0);
2749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*NOTREACHED*/
275da6c28aaSamw }
276da6c28aaSamw
277da6c28aaSamw /*
2789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * Launch a thread to process an asynchronous door call.
279da6c28aaSamw */
2809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_door_dispatch_async(smbd_arg_t * req_arg)2819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_dispatch_async(smbd_arg_t *req_arg)
282da6c28aaSamw {
2839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_arg_t *arg = NULL;
2849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States char *data = NULL;
2859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States pthread_attr_t attr;
2869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States pthread_t tid;
2879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States int rc;
288da6c28aaSamw
2899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if ((req_arg->hdr.dh_flags & SMB_DF_ASYNC) == 0) {
2909fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States errno = EINVAL;
2919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (-1);
2929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
2939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
2949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if ((arg = malloc(sizeof (smbd_arg_t))) == NULL) {
2959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States syslog(LOG_DEBUG, "smbd_door_dispatch_async[%s]: %m",
2969fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States req_arg->opname);
2979fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (-1);
2989fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
2999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
3009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) memcpy(arg, req_arg, sizeof (smbd_arg_t));
3019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->data = NULL;
3029fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
3039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (req_arg->datalen != 0) {
3049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if ((data = malloc(req_arg->datalen)) == NULL) {
3059fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States free(arg);
3069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States syslog(LOG_DEBUG, "smbd_door_dispatch_async[%s]: %m",
3079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States req_arg->opname);
3089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (-1);
3099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
3109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
3119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) memcpy(data, req_arg->data, req_arg->datalen);
3129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->data = data;
3139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
3149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
3159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_lock(&smbd_doorsvc.sd_mutex);
316c5866007SKeyur Desai arg->magic = SMBD_ARG_MAGIC;
3179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States list_insert_tail(&smbd_doorsvc.sd_async_list, arg);
3189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States ++smbd_doorsvc.sd_async_count;
3199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_unlock(&smbd_doorsvc.sd_mutex);
3209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
3219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) pthread_attr_init(&attr);
3229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
3239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States rc = pthread_create(&tid, &attr, smbd_door_dispatch_op, arg);
3249fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) pthread_attr_destroy(&attr);
3259fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
3269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (rc != 0) {
3279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_lock(&smbd_doorsvc.sd_mutex);
3289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_release_async(arg);
3299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_unlock(&smbd_doorsvc.sd_mutex);
3309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
3319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
3329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (rc);
3339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
3349fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
3359fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
3369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * Remove an entry from the async response pending list and free
3379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * the arg and associated data.
3389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States *
3399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * Must only be called while holding the smbd_doorsvc mutex.
3409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States */
3419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static void
smbd_door_release_async(smbd_arg_t * arg)3429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_release_async(smbd_arg_t *arg)
3439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
3449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (arg != NULL) {
345c5866007SKeyur Desai assert(arg->magic == SMBD_ARG_MAGIC);
346c5866007SKeyur Desai arg->magic = (uint32_t)~SMBD_ARG_MAGIC;
347c5866007SKeyur Desai
3489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States list_remove(&smbd_doorsvc.sd_async_list, arg);
3499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States --smbd_doorsvc.sd_async_count;
3509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States free(arg->data);
351c5866007SKeyur Desai arg->data = NULL;
3529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States free(arg);
3539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
3549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
3559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
3569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
3579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * All door calls are processed here: synchronous or asynchronous:
3589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * - synchronous calls are invoked by direct function call
3599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * - asynchronous calls are invoked from a launched thread
3609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States *
361c5866007SKeyur Desai * If the kernel has attempted to collect a response before the op
362c5866007SKeyur Desai * has completed, the arg will have been marked as response_abort
363c5866007SKeyur Desai * and we can discard the response data and release the arg.
364c5866007SKeyur Desai *
3659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * We send a notification when asynchronous (ASYNC) door calls
3669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * from the kernel (SYSSPACE) have completed.
3679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States */
368*b819cea2SGordon Ross void *
smbd_door_dispatch_op(void * thread_arg)3699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_dispatch_op(void *thread_arg)
3709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
3719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_arg_t *arg = (smbd_arg_t *)thread_arg;
3729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_doorop_t *doorop;
3739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_doorhdr_t *hdr;
3749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States int i;
3759fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
3769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if ((!smbd_online()) || arg == NULL)
3779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (NULL);
3789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
3799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States hdr = &arg->hdr;
3809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->opname = smb_doorhdr_opname(hdr->dh_op);
3819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
3829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States for (i = 0; i < smbd_ndoorop; ++i) {
3839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States doorop = &smbd_doorops[i];
3849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
3859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (hdr->dh_op == doorop->opcode) {
3869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States hdr->dh_door_rc = doorop->op(arg);
3879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States hdr->dh_status = arg->status;
3889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
3899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if ((hdr->dh_flags & SMB_DF_SYSSPACE) &&
3909fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (hdr->dh_flags & SMB_DF_ASYNC)) {
3919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States assert(hdr->dh_op != SMB_DR_ASYNC_RESPONSE);
392c5866007SKeyur Desai
393c5866007SKeyur Desai (void) mutex_lock(&smbd_doorsvc.sd_mutex);
394c5866007SKeyur Desai if (arg->response_abort) {
395c5866007SKeyur Desai free(arg->rbuf);
396c5866007SKeyur Desai arg->rbuf = NULL;
397c5866007SKeyur Desai smbd_door_release_async(arg);
398c5866007SKeyur Desai } else {
399c5866007SKeyur Desai arg->response_ready = B_TRUE;
400c5866007SKeyur Desai }
401c5866007SKeyur Desai (void) mutex_unlock(&smbd_doorsvc.sd_mutex);
402c5866007SKeyur Desai
4039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) smb_kmod_event_notify(hdr->dh_txid);
4049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
4059fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
4069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (NULL);
4079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
4089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
4099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
4109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States syslog(LOG_ERR, "smbd_door_dispatch_op[%s]: invalid op %u",
4119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->opname, hdr->dh_op);
412da6c28aaSamw return (NULL);
413da6c28aaSamw }
414da6c28aaSamw
4159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
4169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * Wrapper for door_return. smbd_door_enter() increments a reference count
4179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * when a door call is dispatched and smbd_door_return() decrements the
4189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * reference count when it completes.
4199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States *
4209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * The reference counting is used in smbd_door_fini() to wait for active
4219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * calls to complete before closing the door.
4229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States */
4239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States void
smbd_door_init(smbd_door_t * sdh,const char * name)4249fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_init(smbd_door_t *sdh, const char *name)
4259fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
426*b819cea2SGordon Ross (void) strlcpy(sdh->sd_name, name, sizeof (sdh->sd_name));
4279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
4289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
4299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States void
smbd_door_enter(smbd_door_t * sdh)4309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_enter(smbd_door_t *sdh)
4319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
4329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_lock(&sdh->sd_mutex);
4339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States ++sdh->sd_ncalls;
4349fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_unlock(&sdh->sd_mutex);
435da6c28aaSamw }
436da6c28aaSamw
437da6c28aaSamw /*
4389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * We have two calls to door_return because the first call (with data)
4399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * can fail, which can leave the door call blocked here. The second
4409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * call (with NULL) is guaranteed to unblock and return to the caller.
4419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States */
4429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States void
smbd_door_return(smbd_door_t * sdh,char * data_ptr,size_t data_size,door_desc_t * desc_ptr,uint_t num_desc)4439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_return(smbd_door_t *sdh, char *data_ptr, size_t data_size,
4449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States door_desc_t *desc_ptr, uint_t num_desc)
4459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
4469fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_lock(&sdh->sd_mutex);
4479fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
4489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (sdh->sd_ncalls == 0)
4499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States syslog(LOG_ERR, "smbd_door_return[%s]: unexpected count=0",
4509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States sdh->sd_name);
4519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States else
4529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States --sdh->sd_ncalls;
4539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
4549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) cond_broadcast(&sdh->sd_cv);
4559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_unlock(&sdh->sd_mutex);
4569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
4579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) door_return(data_ptr, data_size, desc_ptr, num_desc);
4589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) door_return(NULL, 0, NULL, 0);
4599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /* NOTREACHED */
4609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
4619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
4629fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
4639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * A door service is about to terminate.
4649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * Give active requests a small grace period to complete.
4659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States */
4669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States void
smbd_door_fini(smbd_door_t * sdh)4679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_fini(smbd_door_t *sdh)
4689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
4699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States timestruc_t delay;
4709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States int rc = 0;
4719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
4729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_lock(&sdh->sd_mutex);
4739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
4749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States while (rc != ETIME && sdh->sd_ncalls != 0) {
4759fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States delay.tv_sec = 1;
4769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States delay.tv_nsec = 0;
4779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States rc = cond_reltimedwait(&sdh->sd_cv, &sdh->sd_mutex, &delay);
4789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
4799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
4809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (sdh->sd_ncalls != 0)
4819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States syslog(LOG_NOTICE, "smbd_door_fini[%s]: %d remaining",
4829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States sdh->sd_name, sdh->sd_ncalls);
4839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
4849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_unlock(&sdh->sd_mutex);
4859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
4869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
4879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
4889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * Null door operation: always returns success.
4899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * Assumes no request or response data.
490da6c28aaSamw */
491da6c28aaSamw /*ARGSUSED*/
4929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_null(smbd_arg_t * arg)4939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_null(smbd_arg_t *arg)
494da6c28aaSamw {
4959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
4963ad684d6Sjb150015 }
4973ad684d6Sjb150015
4989fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
4999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * Async response handler: setup the rbuf and rsize for the specified
5009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * transaction. This function is used by the kernel to collect the
5019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * response half of an asynchronous door call.
502c5866007SKeyur Desai *
503c5866007SKeyur Desai * If a door client attempts to collect a response before the op has
504c5866007SKeyur Desai * completed (!response_ready), mark the arg as response_abort and
505c5866007SKeyur Desai * set an error. The response will be discarded when the op completes.
5069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States */
5079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_async_response(smbd_arg_t * rsp_arg)5089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_async_response(smbd_arg_t *rsp_arg)
5099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
5109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States list_t *arg_list = &smbd_doorsvc.sd_async_list;
5119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_arg_t *arg;
5129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_lock(&smbd_doorsvc.sd_mutex);
5149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg = list_head(arg_list);
5159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States while (arg != NULL) {
517c5866007SKeyur Desai assert(arg->magic == SMBD_ARG_MAGIC);
518c5866007SKeyur Desai
5199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (arg->hdr.dh_txid == rsp_arg->hdr.dh_txid) {
520c5866007SKeyur Desai if (!arg->response_ready) {
521c5866007SKeyur Desai arg->response_abort = B_TRUE;
522c5866007SKeyur Desai rsp_arg->hdr.dh_door_rc = SMB_DOP_NOT_CALLED;
523c5866007SKeyur Desai syslog(LOG_NOTICE, "doorsvc[%s]: %u not ready",
524c5866007SKeyur Desai arg->opname, arg->hdr.dh_txid);
525c5866007SKeyur Desai break;
526c5866007SKeyur Desai }
527c5866007SKeyur Desai
5289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States rsp_arg->rbuf = arg->rbuf;
5299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States rsp_arg->rsize = arg->rsize;
5309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rbuf = NULL;
5319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rsize = 0;
5329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_door_release_async(arg);
5339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States break;
534da6c28aaSamw }
535da6c28aaSamw
5369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg = list_next(arg_list, arg);
537da6c28aaSamw }
538da6c28aaSamw
5399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) mutex_unlock(&smbd_doorsvc.sd_mutex);
5409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
5419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
5429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_user_nonauth_logon(smbd_arg_t * arg)5449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_user_nonauth_logon(smbd_arg_t *arg)
5459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
546c5866007SKeyur Desai uint32_t sid = 0;
5479fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_common_decode(arg->data, arg->datalen,
5499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States xdr_uint32_t, &sid) != 0)
5509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_DECODE_ERROR);
5519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_user_nonauth_logon(sid);
5539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
5549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
5559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_user_auth_logoff(smbd_arg_t * arg)5579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_user_auth_logoff(smbd_arg_t *arg)
5589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
559c5866007SKeyur Desai uint32_t sid = 0;
5609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_common_decode(arg->data, arg->datalen,
5629fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States xdr_uint32_t, &sid) != 0)
5639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_DECODE_ERROR);
5649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_user_auth_logoff(sid);
5669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
5679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
5689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
5709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * Obtains an access token on successful user authentication.
5719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States */
5729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_user_auth_logon(smbd_arg_t * arg)5739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_user_auth_logon(smbd_arg_t *arg)
5749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
5759fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_logon_t *user_info;
5769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_token_t *token;
5779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States user_info = smb_logon_decode((uint8_t *)arg->data,
5799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->datalen);
5809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (user_info == NULL)
5819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_DECODE_ERROR);
5829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States token = smbd_user_auth_logon(user_info);
5849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_logon_free(user_info);
5869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (token == NULL)
5889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_EMPTYBUF);
5899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5909fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rbuf = (char *)smb_token_encode(token, &arg->rsize);
5919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_token_destroy(token);
5929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (arg->rbuf == NULL)
5949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_ENCODE_ERROR);
5959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
5969fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
5979fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
5989fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_lookup_name(smbd_arg_t * arg)5999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_lookup_name(smbd_arg_t *arg)
6009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
6019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_domain_t dinfo;
6029fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_account_t ainfo;
6039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States lsa_account_t acct;
6049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States char buf[MAXNAMELEN];
6059fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
606c5866007SKeyur Desai bzero(&acct, sizeof (lsa_account_t));
607c5866007SKeyur Desai
6089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_common_decode(arg->data, arg->datalen,
6099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States lsa_account_xdr, &acct) != 0)
6109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_DECODE_ERROR);
6119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (*acct.a_domain == '\0')
6139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) snprintf(buf, MAXNAMELEN, "%s", acct.a_name);
6149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States else if (strchr(acct.a_domain, '.') != NULL)
6159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) snprintf(buf, MAXNAMELEN, "%s@%s", acct.a_name,
6169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States acct.a_domain);
617da6c28aaSamw else
6189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) snprintf(buf, MAXNAMELEN, "%s\\%s", acct.a_domain,
6199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States acct.a_name);
6209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States acct.a_status = lsa_lookup_name(buf, acct.a_sidtype, &ainfo);
6229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (acct.a_status == NT_STATUS_SUCCESS) {
6239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States acct.a_sidtype = ainfo.a_type;
6249fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_sid_tostr(ainfo.a_sid, acct.a_sid);
6259fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) strlcpy(acct.a_name, ainfo.a_name, MAXNAMELEN);
6269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_domain_lookup_name(ainfo.a_domain, &dinfo))
6289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) strlcpy(acct.a_domain, dinfo.di_fqname,
6299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States MAXNAMELEN);
6309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States else
6319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) strlcpy(acct.a_domain, ainfo.a_domain,
6329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States MAXNAMELEN);
6339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_account_free(&ainfo);
634da6c28aaSamw }
635da6c28aaSamw
6369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rbuf = smb_common_encode(&acct, lsa_account_xdr, &arg->rsize);
6379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (arg->rbuf == NULL)
6399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_ENCODE_ERROR);
6409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
6419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
6429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_lookup_sid(smbd_arg_t * arg)6449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_lookup_sid(smbd_arg_t *arg)
6459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
6469fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_domain_t dinfo;
6479fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_account_t ainfo;
6489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States lsa_account_t acct;
6499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_sid_t *sid;
6509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
651c5866007SKeyur Desai bzero(&acct, sizeof (lsa_account_t));
652c5866007SKeyur Desai
6539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_common_decode(arg->data, arg->datalen,
6549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States lsa_account_xdr, &acct) != 0)
6559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_DECODE_ERROR);
6569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States sid = smb_sid_fromstr(acct.a_sid);
6589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States acct.a_status = lsa_lookup_sid(sid, &ainfo);
6599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_sid_free(sid);
6609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (acct.a_status == NT_STATUS_SUCCESS) {
6629fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States acct.a_sidtype = ainfo.a_type;
6639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_sid_tostr(ainfo.a_sid, acct.a_sid);
6649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) strlcpy(acct.a_name, ainfo.a_name, MAXNAMELEN);
6659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_domain_lookup_name(ainfo.a_domain, &dinfo))
6679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) strlcpy(acct.a_domain, dinfo.di_fqname,
6689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States MAXNAMELEN);
6699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States else
6709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (void) strlcpy(acct.a_domain, ainfo.a_domain,
6719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States MAXNAMELEN);
6729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_account_free(&ainfo);
6749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
6759fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rbuf = smb_common_encode(&acct, lsa_account_xdr, &arg->rsize);
6779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (arg->rbuf == NULL)
6799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_ENCODE_ERROR);
6809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
6819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
6829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_join(smbd_arg_t * arg)6849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_join(smbd_arg_t *arg)
6859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
6869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_joininfo_t jdi;
6879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States uint32_t status;
6889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
689c5866007SKeyur Desai bzero(&jdi, sizeof (smb_joininfo_t));
690c5866007SKeyur Desai
6919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_common_decode(arg->data, arg->datalen,
6929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_joininfo_xdr, &jdi) != 0)
6939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_DECODE_ERROR);
6949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States status = smbd_join(&jdi);
6969fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6979fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rbuf = smb_common_encode(&status, xdr_uint32_t, &arg->rsize);
6989fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
6999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (arg->rbuf == NULL)
7009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_ENCODE_ERROR);
7019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
7029fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
7039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_get_dcinfo(smbd_arg_t * arg)7059fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_get_dcinfo(smbd_arg_t *arg)
7069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
7079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_domainex_t dxi;
7089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (!smb_domain_getinfo(&dxi))
7109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_EMPTYBUF);
7119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rbuf = smb_string_encode(dxi.d_dc, &arg->rsize);
7139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (arg->rbuf == NULL)
7159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_ENCODE_ERROR);
7169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
7179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
7189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
7209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * Return the number of snapshots for a dataset
7219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States */
7229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_vss_get_count(smbd_arg_t * arg)7239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_vss_get_count(smbd_arg_t *arg)
7249fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
7259fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_string_t path;
7269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States uint32_t count;
7279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States bzero(&path, sizeof (smb_string_t));
7299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rbuf = NULL;
7309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_string_decode(&path, arg->data, arg->datalen) != 0)
7329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_DECODE_ERROR);
7339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7349fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smbd_vss_get_count(path.buf, &count) == 0)
7359fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rbuf = smb_common_encode(&count, xdr_uint32_t,
7369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States &arg->rsize);
7379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States xdr_free(smb_string_xdr, (char *)&path);
7399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (arg->rbuf == NULL)
7419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_ENCODE_ERROR);
7429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
7439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
7449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
7469fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * Return the count and list of snapshots.
7479fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * The list is in @GMT token format.
7489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States */
7499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_vss_get_snapshots(smbd_arg_t * arg)7509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_vss_get_snapshots(smbd_arg_t *arg)
7519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
7529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States char **gmtp;
7539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_gmttoken_query_t request;
7549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_gmttoken_response_t reply;
7559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States uint_t i;
7569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States bzero(&request, sizeof (smb_gmttoken_query_t));
7589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States bzero(&reply, sizeof (smb_gmttoken_response_t));
7599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_common_decode(arg->data, arg->datalen,
7619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_gmttoken_query_xdr, &request) != 0)
7629fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_DECODE_ERROR);
7639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States reply.gtr_gmttokens.gtr_gmttokens_val = malloc(request.gtq_count *
7659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States sizeof (char *));
7669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States bzero(reply.gtr_gmttokens.gtr_gmttokens_val, request.gtq_count *
7679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States sizeof (char *));
7689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (reply.gtr_gmttokens.gtr_gmttokens_val == NULL) {
7709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States xdr_free(smb_gmttoken_query_xdr, (char *)&request);
7719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_EMPTYBUF);
7729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
7739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_vss_get_snapshots(request.gtq_path, request.gtq_count,
7759fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States &reply.gtr_count,
7769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States &reply.gtr_gmttokens.gtr_gmttokens_len,
7779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States reply.gtr_gmttokens.gtr_gmttokens_val);
7789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rbuf = smb_common_encode(&reply, smb_gmttoken_response_xdr,
7809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States &arg->rsize);
7819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (arg->rbuf == NULL) {
7829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States xdr_free(smb_gmttoken_query_xdr, (char *)&request);
7839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_ENCODE_ERROR);
7849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
7859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States for (i = 0, gmtp = reply.gtr_gmttokens.gtr_gmttokens_val;
7879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States (i < request.gtq_count); i++) {
7889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (*gmtp)
7899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States free(*gmtp);
7909fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States gmtp++;
7919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
7929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States free(reply.gtr_gmttokens.gtr_gmttokens_val);
7949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States xdr_free(smb_gmttoken_query_xdr, (char *)&request);
7959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
7969fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
7979fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
7989fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
7999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * Return the name of the snapshot that matches the dataset path
8009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * and @GMT token.
8019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States */
8029fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_vss_map_gmttoken(smbd_arg_t * arg)8039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_vss_map_gmttoken(smbd_arg_t *arg)
8049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
8059fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States char *snapname;
8069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_gmttoken_snapname_t request;
8079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States bzero(&request, sizeof (smb_gmttoken_snapname_t));
8099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_common_decode(arg->data, arg->datalen,
8119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_gmttoken_snapname_xdr, &request) != 0) {
8129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States xdr_free(smb_gmttoken_snapname_xdr, (char *)&request);
8139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_DECODE_ERROR);
8149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
8159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if ((snapname = malloc(MAXPATHLEN)) == NULL) {
8179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States xdr_free(smb_gmttoken_snapname_xdr, (char *)&request);
8189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (NULL);
8199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
8209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if ((smbd_vss_map_gmttoken(request.gts_path, request.gts_gmttoken,
8229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States snapname) != 0)) {
8239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States *snapname = '\0';
8249fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
8259fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rbuf = smb_string_encode(snapname, &arg->rsize);
8279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States xdr_free(smb_gmttoken_snapname_xdr, (char *)&request);
8289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States free(snapname);
8299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (arg->rbuf == NULL)
8319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_ENCODE_ERROR);
8329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
8339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
8349fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8359fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_ads_find_host(smbd_arg_t * arg)8369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_ads_find_host(smbd_arg_t *arg)
8379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
8389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_ads_host_info_t *hinfo = NULL;
8399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States char *hostname = "";
8409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_string_t fqdn;
8419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States bzero(&fqdn, sizeof (smb_string_t));
8439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_string_decode(&fqdn, arg->data, arg->datalen) != 0)
8459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_DECODE_ERROR);
8469fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8479fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if ((hinfo = smb_ads_find_host(fqdn.buf, NULL)) != NULL)
8489fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States hostname = hinfo->name;
8499fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8509fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States xdr_free(smb_string_xdr, (char *)&fqdn);
8519fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8529fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rbuf = smb_string_encode(hostname, &arg->rsize);
8539fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States free(hinfo);
8549fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8559fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (arg->rbuf == NULL)
8569fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_ENCODE_ERROR);
8579fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
8589fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
8599fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8609fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
8619fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * Query the list of user/group quota entries for a given filesystem.
8629fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States */
8639fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_quota_query(smbd_arg_t * arg)8649fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_quota_query(smbd_arg_t *arg)
8659fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
8669fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_quota_query_t request;
8679fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_quota_response_t reply;
8689fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States uint32_t status;
8699fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8709fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States bzero(&request, sizeof (smb_quota_query_t));
8719fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States bzero(&reply, sizeof (smb_quota_response_t));
8729fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8739fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_common_decode(arg->data, arg->datalen,
8749fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_quota_query_xdr, &request) != 0)
8759fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_DECODE_ERROR);
8769fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8779fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States status = smb_quota_query(&request, &reply);
8789fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States reply.qr_status = status;
8799fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8809fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rbuf = smb_common_encode(&reply, smb_quota_response_xdr,
8819fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States &arg->rsize);
8829fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8839fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States xdr_free(smb_quota_query_xdr, (char *)&request);
8849fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_quota_free(&reply);
8859fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8869fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (arg->rbuf == NULL)
8879fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_ENCODE_ERROR);
8889fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
8899fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
8909fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
8919fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States /*
8929fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States * Set a list of user/group quota entries for a given filesystem.
8939fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States */
8949fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_quota_set(smbd_arg_t * arg)8959fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_quota_set(smbd_arg_t *arg)
8969fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
8979fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_quota_set_t request;
8989fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States uint32_t status = 0;
8999fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
9009fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States bzero(&request, sizeof (smb_quota_set_t));
9019fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
9029fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_common_decode(arg->data, arg->datalen,
9039fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smb_quota_set_xdr, &request) != 0)
9049fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_DECODE_ERROR);
9059fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
9069fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States status = smb_quota_set(&request);
9079fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
9089fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rbuf = smb_common_encode(&status, xdr_uint32_t, &arg->rsize);
9099fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States xdr_free(smb_quota_set_xdr, (char *)&request);
9109fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
9119fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (arg->rbuf == NULL)
9129fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_ENCODE_ERROR);
9139fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
9149fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States }
9159fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
9169fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States static int
smbd_dop_dfs_get_referrals(smbd_arg_t * arg)9179fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States smbd_dop_dfs_get_referrals(smbd_arg_t *arg)
9189fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States {
9199fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States dfs_referral_query_t request;
9209fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States dfs_referral_response_t reply;
9219fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
9229fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States bzero(&request, sizeof (request));
9239fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States bzero(&reply, sizeof (reply));
9249fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
9259fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (smb_common_decode(arg->data, arg->datalen,
9269fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States dfs_referral_query_xdr, &request) != 0)
9279fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_DECODE_ERROR);
9289fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
9299fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States reply.rp_status = dfs_get_referrals((const char *)request.rq_path,
9309fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States request.rq_type, &reply.rp_referrals);
9319fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
9329fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (reply.rp_status != ERROR_SUCCESS)
9339fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States bzero(&reply.rp_referrals, sizeof (dfs_info_t));
9349fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
9359fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States arg->rbuf = smb_common_encode(&reply, dfs_referral_response_xdr,
9369fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States &arg->rsize);
9379fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
9389fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (reply.rp_status == ERROR_SUCCESS)
9399fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States dfs_info_free(&reply.rp_referrals);
9409fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
9419fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States xdr_free(dfs_referral_query_xdr, (char *)&request);
9429fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States
9439fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States if (arg->rbuf == NULL)
9449fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_ENCODE_ERROR);
9459fb67ea3Safshin salek ardakani - Sun Microsystems - Irvine United States return (SMB_DOP_SUCCESS);
946da6c28aaSamw }
947148c5f43SAlan Wright
948148c5f43SAlan Wright static int
smbd_dop_shr_hostaccess(smbd_arg_t * arg)949148c5f43SAlan Wright smbd_dop_shr_hostaccess(smbd_arg_t *arg)
950148c5f43SAlan Wright {
951148c5f43SAlan Wright smb_shr_hostaccess_query_t request;
952148c5f43SAlan Wright uint32_t reply;
953148c5f43SAlan Wright
954148c5f43SAlan Wright bzero(&request, sizeof (request));
955148c5f43SAlan Wright bzero(&reply, sizeof (reply));
956148c5f43SAlan Wright
957148c5f43SAlan Wright if (smb_common_decode(arg->data, arg->datalen,
958148c5f43SAlan Wright smb_shr_hostaccess_query_xdr, &request) != 0)
959148c5f43SAlan Wright return (SMB_DOP_DECODE_ERROR);
960148c5f43SAlan Wright
961148c5f43SAlan Wright reply = smb_shr_hostaccess(&request.shq_ipaddr, request.shq_none,
962148c5f43SAlan Wright request.shq_ro, request.shq_rw, request.shq_flag);
963148c5f43SAlan Wright
964148c5f43SAlan Wright arg->rbuf = smb_common_encode(&reply, xdr_uint32_t, &arg->rsize);
965148c5f43SAlan Wright
966148c5f43SAlan Wright xdr_free(smb_shr_hostaccess_query_xdr, (char *)&request);
967148c5f43SAlan Wright
968148c5f43SAlan Wright if (arg->rbuf == NULL)
969148c5f43SAlan Wright return (SMB_DOP_ENCODE_ERROR);
970148c5f43SAlan Wright return (SMB_DOP_SUCCESS);
971148c5f43SAlan Wright }
972148c5f43SAlan Wright
973148c5f43SAlan Wright static int
smbd_dop_shr_exec(smbd_arg_t * arg)974148c5f43SAlan Wright smbd_dop_shr_exec(smbd_arg_t *arg)
975148c5f43SAlan Wright {
976148c5f43SAlan Wright smb_shr_execinfo_t request;
977148c5f43SAlan Wright int reply;
978148c5f43SAlan Wright
979148c5f43SAlan Wright bzero(&request, sizeof (request));
980148c5f43SAlan Wright bzero(&reply, sizeof (reply));
981148c5f43SAlan Wright
982148c5f43SAlan Wright if (smb_common_decode(arg->data, arg->datalen,
983148c5f43SAlan Wright smb_shr_execinfo_xdr, &request) != 0)
984148c5f43SAlan Wright return (SMB_DOP_DECODE_ERROR);
985148c5f43SAlan Wright
986148c5f43SAlan Wright reply = smb_shr_exec(&request);
987148c5f43SAlan Wright
988148c5f43SAlan Wright if (reply != 0)
989148c5f43SAlan Wright syslog(LOG_NOTICE, "Failed to execute %s command",
990148c5f43SAlan Wright (request.e_type == SMB_EXEC_MAP) ? "map" : "unmap");
991148c5f43SAlan Wright
992148c5f43SAlan Wright arg->rbuf = smb_common_encode(&reply, xdr_int, &arg->rsize);
993148c5f43SAlan Wright
994148c5f43SAlan Wright xdr_free(smb_shr_execinfo_xdr, (char *)&request);
995148c5f43SAlan Wright
996148c5f43SAlan Wright if (arg->rbuf == NULL)
997148c5f43SAlan Wright return (SMB_DOP_ENCODE_ERROR);
998148c5f43SAlan Wright return (SMB_DOP_SUCCESS);
999148c5f43SAlan Wright }
1000