usr/src/uts/common/fs/nfs/nfs_acl_vnops.c
author jpk
Fri, 24 Mar 2006 12:29:20 -0800
changeset 1676 37f4a3e2bd99
parent 573 7e2aa87c24de
permissions -rw-r--r--
PSARC/2002/762 Layered Trusted Solaris PSARC/2005/060 TSNET: Trusted Networking with Security Labels PSARC/2005/259 Layered Trusted Solaris Label Interfaces PSARC/2005/573 Solaris Trusted Extensions for Printing PSARC/2005/691 Trusted Extensions for Device Allocation PSARC/2005/723 Solaris Trusted Extensions Filesystem Labeling PSARC/2006/009 Labeled Auditing PSARC/2006/155 Trusted Extensions RBAC Changes PSARC/2006/191 is_system_labeled 6293271 Zone processes should use zone_kcred instead of kcred 6394554 integrate Solaris Trusted Extensions
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     1
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     2
 * CDDL HEADER START
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     3
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     4
 * The contents of this file are subject to the terms of the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     5
 * Common Development and Distribution License, Version 1.0 only
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     6
 * (the "License").  You may not use this file except in compliance
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     7
 * with the License.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     8
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     9
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    10
 * or http://www.opensolaris.org/os/licensing.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    11
 * See the License for the specific language governing permissions
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    12
 * and limitations under the License.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    13
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    14
 * When distributing Covered Code, include this CDDL HEADER in each
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    15
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    16
 * If applicable, add the following below this CDDL HEADER, with the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    17
 * fields enclosed by brackets "[]" replaced with your own identifying
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    18
 * information: Portions Copyright [yyyy] [name of copyright owner]
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    19
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    20
 * CDDL HEADER END
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    21
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    22
/*
503
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
    23
 * Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    24
 * Use is subject to license terms.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    25
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    26
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    27
#pragma ident	"%Z%%M%	%I%	%E% SMI"
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    28
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    29
#include <sys/param.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    30
#include <sys/types.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    31
#include <sys/systm.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    32
#include <sys/cred.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    33
#include <sys/proc.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    34
#include <sys/user.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    35
#include <sys/time.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    36
#include <sys/vnode.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    37
#include <sys/vfs.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    38
#include <sys/file.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    39
#include <sys/uio.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    40
#include <sys/buf.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    41
#include <sys/mman.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    42
#include <sys/tiuser.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    43
#include <sys/pathname.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    44
#include <sys/dirent.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    45
#include <sys/conf.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    46
#include <sys/debug.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    47
#include <sys/unistd.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    48
#include <sys/vmsystm.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    49
#include <sys/fcntl.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    50
#include <sys/flock.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    51
#include <sys/swap.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    52
#include <sys/errno.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    53
#include <sys/sysmacros.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    54
#include <sys/disp.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    55
#include <sys/kmem.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    56
#include <sys/cmn_err.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    57
#include <sys/vtrace.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    58
#include <sys/pathconf.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    59
#include <sys/dnlc.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    60
#include <sys/acl.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    61
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    62
#include <rpc/types.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    63
#include <rpc/auth.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    64
#include <rpc/clnt.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    65
#include <rpc/xdr.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    66
#include <nfs/nfs.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    67
#include <nfs/nfs_clnt.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    68
#include <nfs/rnode.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    69
#include <nfs/nfs_acl.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    70
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    71
#include <vm/hat.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    72
#include <vm/as.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    73
#include <vm/page.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    74
#include <vm/pvn.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    75
#include <vm/seg.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    76
#include <vm/seg_map.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    77
#include <vm/seg_kmem.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    78
#include <vm/seg_vn.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    79
#include <vm/rm.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    80
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    81
#include <fs/fs_subr.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    82
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    83
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    84
 * The order and contents of this structure must be kept in sync with that of
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    85
 * aclreqcnt_v2_tmpl in nfs_stats.c
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    86
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    87
char *aclnames_v2[] = {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    88
	"null", "getacl", "setacl", "getattr", "access", "getxattrdir"
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    89
};
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    90
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    91
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    92
 * This table maps from NFS protocol number into call type.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    93
 * Zero means a "Lookup" type call
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    94
 * One  means a "Read" type call
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    95
 * Two  means a "Write" type call
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    96
 * This is used to select a default time-out.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    97
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    98
uchar_t acl_call_type_v2[] = {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    99
	0, 0, 1, 0, 0, 0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   100
};
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   101
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   102
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   103
 * Similar table, but to determine which timer to use
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   104
 * (only real reads and writes!)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   105
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   106
uchar_t acl_timer_type_v2[] = {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   107
	0, 0, 0, 0, 0, 0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   108
};
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   109
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   110
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   111
 * This table maps from acl operation into a call type
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   112
 * for the semisoft mount option.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   113
 * Zero means do not repeat operation.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   114
 * One  means repeat.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   115
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   116
uchar_t acl_ss_call_type_v2[] = {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   117
	0, 0, 1, 0, 0, 0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   118
};
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   119
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   120
static int nfs_acl_dup_cache(vsecattr_t *, vsecattr_t *);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   121
static void nfs_acl_dup_res(rnode_t *, vsecattr_t *);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   122
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   123
/* ARGSUSED */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   124
int
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   125
acl_getacl2(vnode_t *vp, vsecattr_t *vsp, int flag, cred_t *cr)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   126
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   127
	int error;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   128
	GETACL2args args;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   129
	GETACL2res res;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   130
	int doqueue;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   131
	vattr_t va;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   132
	rnode_t *rp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   133
	failinfo_t fi;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   134
	hrtime_t t;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   135
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   136
	rp = VTOR(vp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   137
	if (rp->r_secattr != NULL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   138
		error = nfs_validate_caches(vp, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   139
		if (error)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   140
			return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   141
		mutex_enter(&rp->r_statelock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   142
		if (rp->r_secattr != NULL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   143
			if (nfs_acl_dup_cache(vsp, rp->r_secattr)) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   144
				mutex_exit(&rp->r_statelock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   145
				return (0);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   146
			}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   147
		}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   148
		mutex_exit(&rp->r_statelock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   149
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   150
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   151
	args.mask = vsp->vsa_mask;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   152
	args.fh = *VTOFH(vp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   153
	fi.vp = vp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   154
	fi.fhp = (caddr_t)&args.fh;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   155
	fi.copyproc = nfscopyfh;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   156
	fi.lookupproc = nfslookup;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   157
	fi.xattrdirproc = acl_getxattrdir2;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   158
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   159
	res.resok.acl.vsa_aclentp = NULL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   160
	res.resok.acl.vsa_dfaclentp = NULL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   161
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   162
	doqueue = 1;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   163
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   164
	t = gethrtime();
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   165
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   166
	error = acl2call(VTOMI(vp), ACLPROC2_GETACL,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   167
	    xdr_GETACL2args, (caddr_t)&args,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   168
	    xdr_GETACL2res, (caddr_t)&res, cr,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   169
	    &doqueue, &res.status, 0, &fi);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   170
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   171
	if (error)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   172
		return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   173
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   174
	error = geterrno(res.status);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   175
	if (!error) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   176
		(void) nfs_cache_fattr(vp, &res.resok.attr, &va, t, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   177
		nfs_acl_dup_res(rp, &res.resok.acl);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   178
		*vsp = res.resok.acl;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   179
	} else {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   180
		PURGE_STALE_FH(error, vp, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   181
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   182
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   183
	return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   184
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   185
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   186
/* ARGSUSED */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   187
int
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   188
acl_setacl2(vnode_t *vp, vsecattr_t *vsp, int flag, cred_t *cr)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   189
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   190
	int error;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   191
	SETACL2args args;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   192
	SETACL2res res;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   193
	int doqueue;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   194
	vattr_t va;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   195
	rnode_t *rp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   196
	hrtime_t t;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   197
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   198
	args.fh = *VTOFH(vp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   199
	args.acl = *vsp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   200
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   201
	doqueue = 1;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   202
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   203
	t = gethrtime();
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   204
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   205
	error = acl2call(VTOMI(vp), ACLPROC2_SETACL,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   206
	    xdr_SETACL2args, (caddr_t)&args,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   207
	    xdr_SETACL2res, (caddr_t)&res, cr,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   208
	    &doqueue, &res.status, 0, NULL);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   209
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   210
	/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   211
	 * On success, adding the arguments to setsecattr into the cache have
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   212
	 * not proven adequate.  On error, we cannot depend on cache.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   213
	 * Simply flush the cache to force the next getsecattr
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   214
	 * to go over the wire.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   215
	 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   216
	rp = VTOR(vp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   217
	mutex_enter(&rp->r_statelock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   218
	if (rp->r_secattr != NULL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   219
		nfs_acl_free(rp->r_secattr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   220
		rp->r_secattr = NULL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   221
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   222
	mutex_exit(&rp->r_statelock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   223
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   224
	if (error)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   225
		return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   226
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   227
	error = geterrno(res.status);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   228
	if (!error) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   229
		(void) nfs_cache_fattr(vp, &res.resok.attr, &va, t, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   230
	} else {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   231
		PURGE_STALE_FH(error, vp, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   232
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   233
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   234
	return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   235
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   236
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   237
int
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   238
acl_getattr2_otw(vnode_t *vp, vattr_t *vap, cred_t *cr)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   239
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   240
	int error;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   241
	GETATTR2args args;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   242
	GETATTR2res res;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   243
	int doqueue;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   244
	failinfo_t fi;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   245
	hrtime_t t;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   246
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   247
	args.fh = *VTOFH(vp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   248
	fi.vp = vp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   249
	fi.fhp = (caddr_t)&args.fh;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   250
	fi.copyproc = nfscopyfh;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   251
	fi.lookupproc = nfslookup;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   252
	fi.xattrdirproc = acl_getxattrdir2;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   253
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   254
	doqueue = 1;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   255
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   256
	t = gethrtime();
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   257
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   258
	error = acl2call(VTOMI(vp), ACLPROC2_GETATTR,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   259
	    xdr_GETATTR2args, (caddr_t)&args,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   260
	    xdr_GETATTR2res, (caddr_t)&res, cr,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   261
	    &doqueue, &res.status, 0, &fi);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   262
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   263
	if (error)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   264
		return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   265
	error = geterrno(res.status);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   266
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   267
	if (!error) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   268
		error = nfs_cache_fattr(vp, &res.resok.attr, vap, t, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   269
	} else {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   270
		PURGE_STALE_FH(error, vp, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   271
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   272
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   273
	return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   274
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   275
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   276
/* ARGSUSED */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   277
int
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   278
acl_access2(vnode_t *vp, int mode, int flags, cred_t *cr)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   279
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   280
	int error;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   281
	ACCESS2args args;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   282
	ACCESS2res res;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   283
	int doqueue;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   284
	uint32 acc;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   285
	rnode_t *rp;
573
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   286
	cred_t *cred, *ncr, *ncrfree = NULL;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   287
	vattr_t va;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   288
	failinfo_t fi;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   289
	nfs_access_type_t cacc;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   290
	hrtime_t t;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   291
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   292
	acc = 0;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   293
	if (mode & VREAD)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   294
		acc |= ACCESS2_READ;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   295
	if (mode & VWRITE) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   296
		if (vn_is_readonly(vp) && !IS_DEVVP(vp))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   297
			return (EROFS);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   298
		if (vp->v_type == VDIR)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   299
			acc |= ACCESS2_DELETE;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   300
		acc |= ACCESS2_MODIFY | ACCESS2_EXTEND;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   301
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   302
	if (mode & VEXEC) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   303
		if (vp->v_type == VDIR)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   304
			acc |= ACCESS2_LOOKUP;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   305
		else
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   306
			acc |= ACCESS2_EXECUTE;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   307
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   308
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   309
	rp = VTOR(vp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   310
	if (vp->v_type == VDIR) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   311
		args.access = ACCESS2_READ | ACCESS2_DELETE | ACCESS2_MODIFY |
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   312
		    ACCESS2_EXTEND | ACCESS2_LOOKUP;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   313
	} else {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   314
		args.access = ACCESS2_READ | ACCESS2_MODIFY | ACCESS2_EXTEND |
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   315
		    ACCESS2_EXECUTE;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   316
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   317
	args.fh = *VTOFH(vp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   318
	fi.vp = vp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   319
	fi.fhp = (caddr_t)&args.fh;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   320
	fi.copyproc = nfscopyfh;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   321
	fi.lookupproc = nfslookup;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   322
	fi.xattrdirproc = acl_getxattrdir2;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   323
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   324
	cred = cr;
573
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   325
	/*
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   326
	 * ncr and ncrfree both initially
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   327
	 * point to the memory area returned
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   328
	 * by crnetadjust();
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   329
	 * ncrfree not NULL when exiting means
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   330
	 * that we need to release it
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   331
	 */
503
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   332
	ncr = crnetadjust(cred);
573
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   333
	ncrfree = ncr;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   334
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   335
tryagain:
503
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   336
	if (rp->r_acache != NULL) {
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   337
		cacc = nfs_access_check(rp, acc, cr);
573
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   338
		if (cacc == NFS_ACCESS_ALLOWED) {
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   339
			if (ncrfree != NULL)
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   340
				crfree(ncrfree);
503
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   341
			return (0);
573
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   342
		}
503
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   343
		if (cacc == NFS_ACCESS_DENIED) {
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   344
			/*
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   345
			 * If the cred can be adjusted, try again
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   346
			 * with the new cred.
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   347
			 */
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   348
			if (ncr != NULL) {
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   349
				cred = ncr;
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   350
				ncr = NULL;
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   351
				goto tryagain;
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   352
			}
573
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   353
			if (ncrfree != NULL)
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   354
				crfree(ncrfree);
503
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   355
			return (EACCES);
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   356
		}
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   357
	}
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   358
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   359
	doqueue = 1;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   360
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   361
	t = gethrtime();
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   362
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   363
	error = acl2call(VTOMI(vp), ACLPROC2_ACCESS,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   364
	    xdr_ACCESS2args, (caddr_t)&args,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   365
	    xdr_ACCESS2res, (caddr_t)&res, cred,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   366
	    &doqueue, &res.status, 0, &fi);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   367
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   368
	if (error) {
573
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   369
		if (ncrfree != NULL)
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   370
			crfree(ncrfree);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   371
		return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   372
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   373
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   374
	error = geterrno(res.status);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   375
	if (!error) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   376
		(void) nfs_cache_fattr(vp, &res.resok.attr, &va, t, cr);
503
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   377
		nfs_access_cache(rp, args.access, res.resok.access, cred);
573
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   378
		/*
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   379
		 * we just cached results with cred; if cred is the
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   380
		 * adjusted credentials from crnetadjust, we do not want
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   381
		 * to release them before exiting: hence setting ncrfree
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   382
		 * to NULL
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   383
		 */
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   384
		if (cred != cr)
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   385
			ncrfree = NULL;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   386
		if ((acc & res.resok.access) != acc) {
503
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   387
			/*
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   388
			 * If the cred can be adjusted, try again
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   389
			 * with the new cred.
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   390
			 */
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   391
			if (ncr != NULL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   392
				cred = ncr;
503
00662521f7b5 6226092 getcwd() not consistent when dealing with NFS directories and setuid applications
sdussud
parents: 0
diff changeset
   393
				ncr = NULL;
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   394
				goto tryagain;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   395
			}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   396
			error = EACCES;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   397
		}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   398
	} else {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   399
		PURGE_STALE_FH(error, vp, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   400
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   401
573
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   402
	if (ncrfree != NULL)
7e2aa87c24de 6322778 memleaks at crdup/crnetadjust
sdussud
parents: 503
diff changeset
   403
		crfree(ncrfree);
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   404
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   405
	return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   406
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   407
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   408
static int xattr_lookup_neg_cache = 1;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   409
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   410
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   411
 * Look up a hidden attribute directory over the wire; the vnode
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   412
 * we start with could be a file or directory.  We have to be
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   413
 * tricky in recording the name in the rnode r_path - we use the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   414
 * magic name XATTR_RPATH and rely on code in failover_lookup() to
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   415
 * detect this and use this routine to do the same lookup on
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   416
 * remapping.  DNLC is easier: slashes are legal, so we use
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   417
 * XATTR_DIR_NAME as UFS does.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   418
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   419
int
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   420
acl_getxattrdir2(vnode_t *vp, vnode_t **vpp, bool_t create, cred_t *cr,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   421
	int rfscall_flags)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   422
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   423
	int error;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   424
	GETXATTRDIR2args args;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   425
	GETXATTRDIR2res res;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   426
	int doqueue;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   427
	failinfo_t fi;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   428
	hrtime_t t;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   429
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   430
	args.fh = *VTOFH(vp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   431
	args.create = create;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   432
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   433
	fi.vp = vp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   434
	fi.fhp = NULL;		/* no need to update, filehandle not copied */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   435
	fi.copyproc = nfscopyfh;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   436
	fi.lookupproc = nfslookup;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   437
	fi.xattrdirproc = acl_getxattrdir2;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   438
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   439
	doqueue = 1;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   440
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   441
	t = gethrtime();
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   442
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   443
	error = acl2call(VTOMI(vp), ACLPROC2_GETXATTRDIR,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   444
	    xdr_GETXATTRDIR2args, (caddr_t)&args,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   445
	    xdr_GETXATTRDIR2res, (caddr_t)&res, cr,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   446
	    &doqueue, &res.status, rfscall_flags, &fi);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   447
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   448
	if (!error) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   449
		error = geterrno(res.status);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   450
		if (!error) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   451
			*vpp = makenfsnode(&res.resok.fh, &res.resok.attr,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   452
			    vp->v_vfsp, t, cr, VTOR(vp)->r_path, XATTR_RPATH);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   453
			mutex_enter(&(*vpp)->v_lock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   454
			(*vpp)->v_flag |= V_XATTRDIR;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   455
			mutex_exit(&(*vpp)->v_lock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   456
			if (!(rfscall_flags & RFSCALL_SOFT))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   457
				dnlc_update(vp, XATTR_DIR_NAME, *vpp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   458
		} else {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   459
			PURGE_STALE_FH(error, vp, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   460
			if (error == ENOENT && xattr_lookup_neg_cache)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   461
				dnlc_enter(vp, XATTR_DIR_NAME, DNLC_NO_VNODE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   462
		}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   463
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   464
	return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   465
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   466
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   467
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   468
 * The order and contents of this structure must be kept in sync with that of
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   469
 * aclreqcnt_v3_tmpl in nfs_stats.c
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   470
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   471
char *aclnames_v3[] = {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   472
	"null", "getacl", "setacl", "getxattrdir"
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   473
};
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   474
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   475
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   476
 * This table maps from NFS protocol number into call type.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   477
 * Zero means a "Lookup" type call
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   478
 * One  means a "Read" type call
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   479
 * Two  means a "Write" type call
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   480
 * This is used to select a default time-out.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   481
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   482
uchar_t acl_call_type_v3[] = {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   483
	0, 0, 1, 0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   484
};
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   485
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   486
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   487
 * This table maps from acl operation into a call type
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   488
 * for the semisoft mount option.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   489
 * Zero means do not repeat operation.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   490
 * One  means repeat.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   491
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   492
uchar_t acl_ss_call_type_v3[] = {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   493
	0, 0, 1, 0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   494
};
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   495
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   496
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   497
 * Similar table, but to determine which timer to use
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   498
 * (only real reads and writes!)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   499
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   500
uchar_t acl_timer_type_v3[] = {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   501
	0, 0, 0, 0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   502
};
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   503
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   504
/* ARGSUSED */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   505
int
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   506
acl_getacl3(vnode_t *vp, vsecattr_t *vsp, int flag, cred_t *cr)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   507
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   508
	int error;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   509
	GETACL3args args;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   510
	GETACL3res res;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   511
	int doqueue;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   512
	rnode_t *rp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   513
	failinfo_t fi;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   514
	hrtime_t t;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   515
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   516
	rp = VTOR(vp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   517
	if (rp->r_secattr != NULL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   518
		error = nfs3_validate_caches(vp, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   519
		if (error)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   520
			return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   521
		mutex_enter(&rp->r_statelock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   522
		if (rp->r_secattr != NULL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   523
			if (nfs_acl_dup_cache(vsp, rp->r_secattr)) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   524
				mutex_exit(&rp->r_statelock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   525
				return (0);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   526
			}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   527
		}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   528
		mutex_exit(&rp->r_statelock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   529
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   530
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   531
	args.mask = vsp->vsa_mask;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   532
	args.fh = *VTOFH3(vp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   533
	fi.vp = vp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   534
	fi.fhp = (caddr_t)&args.fh;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   535
	fi.copyproc = nfs3copyfh;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   536
	fi.lookupproc = nfs3lookup;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   537
	fi.xattrdirproc = acl_getxattrdir3;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   538
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   539
	res.resok.acl.vsa_aclentp = NULL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   540
	res.resok.acl.vsa_dfaclentp = NULL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   541
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   542
	doqueue = 1;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   543
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   544
	t = gethrtime();
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   545
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   546
	error = acl3call(VTOMI(vp), ACLPROC3_GETACL,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   547
	    xdr_GETACL3args, (caddr_t)&args,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   548
	    xdr_GETACL3res, (caddr_t)&res, cr,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   549
	    &doqueue, &res.status, 0, &fi);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   550
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   551
	if (error)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   552
		return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   553
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   554
	error = geterrno3(res.status);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   555
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   556
	if (!error) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   557
		nfs3_cache_post_op_attr(vp, &res.resok.attr, t, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   558
		nfs_acl_dup_res(rp, &res.resok.acl);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   559
		*vsp = res.resok.acl;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   560
	} else {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   561
		nfs3_cache_post_op_attr(vp, &res.resfail.attr, t, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   562
		PURGE_STALE_FH(error, vp, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   563
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   564
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   565
	return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   566
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   567
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   568
/* ARGSUSED */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   569
int
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   570
acl_setacl3(vnode_t *vp, vsecattr_t *vsp, int flag, cred_t *cr)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   571
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   572
	int error;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   573
	SETACL3args args;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   574
	SETACL3res res;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   575
	rnode_t *rp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   576
	int doqueue;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   577
	hrtime_t t;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   578
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   579
	args.fh = *VTOFH3(vp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   580
	args.acl = *vsp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   581
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   582
	doqueue = 1;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   583
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   584
	t = gethrtime();
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   585
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   586
	error = acl3call(VTOMI(vp), ACLPROC3_SETACL,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   587
	    xdr_SETACL3args, (caddr_t)&args,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   588
	    xdr_SETACL3res, (caddr_t)&res, cr,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   589
	    &doqueue, &res.status, 0, NULL);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   590
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   591
	/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   592
	 * On success, adding the arguments to setsecattr into the cache have
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   593
	 * not proven adequate.  On error, we cannot depend on cache.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   594
	 * Simply flush the cache to force the next getsecattr
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   595
	 * to go over the wire.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   596
	 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   597
	rp = VTOR(vp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   598
	mutex_enter(&rp->r_statelock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   599
	if (rp->r_secattr != NULL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   600
		nfs_acl_free(rp->r_secattr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   601
		rp->r_secattr = NULL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   602
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   603
	mutex_exit(&rp->r_statelock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   604
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   605
	if (error)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   606
		return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   607
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   608
	error = geterrno3(res.status);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   609
	if (!error) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   610
		nfs3_cache_post_op_attr(vp, &res.resok.attr, t, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   611
	} else {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   612
		nfs3_cache_post_op_attr(vp, &res.resfail.attr, t, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   613
		PURGE_STALE_FH(error, vp, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   614
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   615
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   616
	return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   617
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   618
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   619
int
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   620
acl_getxattrdir3(vnode_t *vp, vnode_t **vpp, bool_t create, cred_t *cr,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   621
	int rfscall_flags)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   622
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   623
	int error;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   624
	GETXATTRDIR3args args;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   625
	GETXATTRDIR3res res;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   626
	int doqueue;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   627
	struct vattr vattr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   628
	vnode_t *nvp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   629
	failinfo_t fi;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   630
	hrtime_t t;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   631
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   632
	args.fh = *VTOFH3(vp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   633
	args.create = create;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   634
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   635
	fi.vp = vp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   636
	fi.fhp = (caddr_t)&args.fh;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   637
	fi.copyproc = nfs3copyfh;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   638
	fi.lookupproc = nfs3lookup;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   639
	fi.xattrdirproc = acl_getxattrdir3;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   640
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   641
	doqueue = 1;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   642
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   643
	t = gethrtime();
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   644
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   645
	error = acl3call(VTOMI(vp), ACLPROC3_GETXATTRDIR,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   646
	    xdr_GETXATTRDIR3args, (caddr_t)&args,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   647
	    xdr_GETXATTRDIR3res, (caddr_t)&res, cr,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   648
	    &doqueue, &res.status, rfscall_flags, &fi);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   649
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   650
	if (error)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   651
		return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   652
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   653
	error = geterrno3(res.status);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   654
	if (!error) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   655
		if (res.resok.attr.attributes) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   656
			nvp = makenfs3node(&res.resok.fh,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   657
			    &res.resok.attr.attr,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   658
			    vp->v_vfsp, t, cr, VTOR(vp)->r_path, XATTR_RPATH);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   659
		} else {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   660
			nvp = makenfs3node(&res.resok.fh, NULL,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   661
			    vp->v_vfsp, t, cr, VTOR(vp)->r_path, XATTR_RPATH);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   662
			if (nvp->v_type == VNON) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   663
				vattr.va_mask = AT_TYPE;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   664
				error = nfs3getattr(nvp, &vattr, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   665
				if (error) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   666
					VN_RELE(nvp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   667
					return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   668
				}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   669
				nvp->v_type = vattr.va_type;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   670
			}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   671
		}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   672
		mutex_enter(&nvp->v_lock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   673
		nvp->v_flag |= V_XATTRDIR;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   674
		mutex_exit(&nvp->v_lock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   675
		if (!(rfscall_flags & RFSCALL_SOFT))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   676
			dnlc_update(vp, XATTR_DIR_NAME, nvp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   677
		*vpp = nvp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   678
	} else {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   679
		PURGE_STALE_FH(error, vp, cr);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   680
		if (error == ENOENT && xattr_lookup_neg_cache)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   681
			dnlc_enter(vp, XATTR_DIR_NAME, DNLC_NO_VNODE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   682
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   683
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   684
	return (error);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   685
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   686
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   687
void
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   688
nfs_acl_free(vsecattr_t *vsp)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   689
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   690
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   691
	if (vsp->vsa_aclentp != NULL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   692
		kmem_free(vsp->vsa_aclentp, vsp->vsa_aclcnt *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   693
		    sizeof (aclent_t));
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   694
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   695
	if (vsp->vsa_dfaclentp != NULL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   696
		kmem_free(vsp->vsa_dfaclentp, vsp->vsa_dfaclcnt *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   697
		    sizeof (aclent_t));
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   698
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   699
	kmem_free(vsp, sizeof (*vsp));
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   700
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   701
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   702
static int
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   703
nfs_acl_dup_cache(vsecattr_t *vsp, vsecattr_t *rvsp)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   704
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   705
	size_t aclsize;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   706
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   707
	if ((rvsp->vsa_mask & vsp->vsa_mask) != vsp->vsa_mask)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   708
		return (0);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   709
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   710
	if (vsp->vsa_mask & VSA_ACL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   711
		ASSERT(rvsp->vsa_mask & VSA_ACLCNT);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   712
		aclsize = rvsp->vsa_aclcnt * sizeof (aclent_t);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   713
		vsp->vsa_aclentp = kmem_alloc(aclsize, KM_SLEEP);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   714
		bcopy(rvsp->vsa_aclentp, vsp->vsa_aclentp, aclsize);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   715
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   716
	if (vsp->vsa_mask & VSA_ACLCNT)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   717
		vsp->vsa_aclcnt = rvsp->vsa_aclcnt;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   718
	if (vsp->vsa_mask & VSA_DFACL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   719
		ASSERT(rvsp->vsa_mask & VSA_DFACLCNT);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   720
		aclsize = rvsp->vsa_dfaclcnt * sizeof (aclent_t);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   721
		vsp->vsa_dfaclentp = kmem_alloc(aclsize, KM_SLEEP);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   722
		bcopy(rvsp->vsa_dfaclentp, vsp->vsa_dfaclentp, aclsize);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   723
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   724
	if (vsp->vsa_mask & VSA_DFACLCNT)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   725
		vsp->vsa_dfaclcnt = rvsp->vsa_dfaclcnt;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   726
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   727
	return (1);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   728
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   729
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   730
static void
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   731
nfs_acl_dup_res_impl(kmutex_t *statelock, vsecattr_t **rspp, vsecattr_t *vsp)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   732
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   733
	size_t aclsize;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   734
	vsecattr_t *rvsp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   735
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   736
	mutex_enter(statelock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   737
	if (*rspp != NULL)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   738
		rvsp = *rspp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   739
	else {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   740
		rvsp = kmem_zalloc(sizeof (*rvsp), KM_NOSLEEP);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   741
		if (rvsp == NULL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   742
			mutex_exit(statelock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   743
			return;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   744
		}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   745
		*rspp = rvsp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   746
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   747
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   748
	if (vsp->vsa_mask & VSA_ACL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   749
		if (rvsp->vsa_aclentp != NULL &&
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   750
		    rvsp->vsa_aclcnt != vsp->vsa_aclcnt) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   751
			aclsize = rvsp->vsa_aclcnt * sizeof (aclent_t);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   752
			kmem_free(rvsp->vsa_aclentp, aclsize);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   753
			rvsp->vsa_aclentp = NULL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   754
		}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   755
		if (vsp->vsa_aclcnt > 0) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   756
			aclsize = vsp->vsa_aclcnt * sizeof (aclent_t);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   757
			if (rvsp->vsa_aclentp == NULL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   758
				rvsp->vsa_aclentp = kmem_alloc(aclsize,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   759
				    KM_SLEEP);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   760
			}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   761
			bcopy(vsp->vsa_aclentp, rvsp->vsa_aclentp, aclsize);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   762
		}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   763
		rvsp->vsa_aclcnt = vsp->vsa_aclcnt;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   764
		rvsp->vsa_mask |= VSA_ACL | VSA_ACLCNT;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   765
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   766
	if (vsp->vsa_mask & VSA_ACLCNT) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   767
		if (rvsp->vsa_aclentp != NULL &&
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   768
		    rvsp->vsa_aclcnt != vsp->vsa_aclcnt) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   769
			aclsize = rvsp->vsa_aclcnt * sizeof (aclent_t);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   770
			kmem_free(rvsp->vsa_aclentp, aclsize);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   771
			rvsp->vsa_aclentp = NULL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   772
			rvsp->vsa_mask &= ~VSA_ACL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   773
		}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   774
		rvsp->vsa_aclcnt = vsp->vsa_aclcnt;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   775
		rvsp->vsa_mask |= VSA_ACLCNT;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   776
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   777
	if (vsp->vsa_mask & VSA_DFACL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   778
		if (rvsp->vsa_dfaclentp != NULL &&
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   779
		    rvsp->vsa_dfaclcnt != vsp->vsa_dfaclcnt) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   780
			aclsize = rvsp->vsa_dfaclcnt * sizeof (aclent_t);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   781
			kmem_free(rvsp->vsa_dfaclentp, aclsize);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   782
			rvsp->vsa_dfaclentp = NULL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   783
		}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   784
		if (vsp->vsa_dfaclcnt > 0) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   785
			aclsize = vsp->vsa_dfaclcnt * sizeof (aclent_t);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   786
			if (rvsp->vsa_dfaclentp == NULL) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   787
				rvsp->vsa_dfaclentp = kmem_alloc(aclsize,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   788
				    KM_SLEEP);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   789
			}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   790
			bcopy(vsp->vsa_dfaclentp, rvsp->vsa_dfaclentp, aclsize);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   791
		}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   792
		rvsp->vsa_dfaclcnt = vsp->vsa_dfaclcnt;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   793
		rvsp->vsa_mask |= VSA_DFACL | VSA_DFACLCNT;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   794
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   795
	if (vsp->vsa_mask & VSA_DFACLCNT) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   796
		if (rvsp->vsa_dfaclentp != NULL &&
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   797
		    rvsp->vsa_dfaclcnt != vsp->vsa_dfaclcnt) {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   798
			aclsize = rvsp->vsa_dfaclcnt * sizeof (aclent_t);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   799
			kmem_free(rvsp->vsa_dfaclentp, aclsize);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   800
			rvsp->vsa_dfaclentp = NULL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   801
			rvsp->vsa_mask &= ~VSA_DFACL;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   802
		}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   803
		rvsp->vsa_dfaclcnt = vsp->vsa_dfaclcnt;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   804
		rvsp->vsa_mask |= VSA_DFACLCNT;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   805
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   806
	mutex_exit(statelock);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   807
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   808
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   809
static void
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   810
nfs_acl_dup_res(rnode_t *rp, vsecattr_t *vsp)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   811
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   812
	nfs_acl_dup_res_impl(&rp->r_statelock, &rp->r_secattr, vsp);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   813
}