usr/src/lib/libsec/common/aclutils.c
author amw
Thu, 25 Oct 2007 16:34:29 -0700
changeset 5331 3047ad28a67b
parent 4321 a8930ec16e52
child 7057 d3fa1d6dbef7
permissions -rw-r--r--
PSARC/2007/218 caller_context_t in all VOPs PSARC/2007/227 VFS Feature Registration and ACL on Create PSARC/2007/244 ZFS Case-insensitive support PSARC/2007/315 Extensible Attribute Interfaces PSARC/2007/394 ls(1) new command line options '-/' and '-%': CIFS system attributes support PSARC/2007/403 Modified Access Checks for CIFS PSARC/2007/410 Add system attribute support to chmod(1) PSARC/2007/432 CIFS system attributes support for cp(1), pack(1), unpack(1), compress(1) and uncompress(1) PSARC/2007/444 Rescind SETTABLE Attribute PSARC/2007/459 CIFS system attributes support for cpio(1), pax(1), tar(1) PSARC/2007/546 Update utilities to match CIFS system attributes changes. PSARC/2007/560 ZFS sharesmb property 4890717 want append-only files 6417428 Case-insensitive file system name lookup to support CIFS 6417435 DOS attributes and additional timestamps to support for CIFS 6417442 File system quarantined and modified attributes to support an integrated Anti-Virus service 6417453 FS boolean property for rejecting/allowing invalid UTF-8 sequences in file names 6473733 RFE: Need support for open-deny modes 6473755 RFE: Need ability to reconcile oplock and delegation conflicts 6494624 sharemgr needs to support CIFS shares better 6546705 All vnode operations need to pass caller_context_t 6546706 Need VOP_SETATTR/VOP_GETATTR to support new, optional attributes 6546893 Solaris system attribute support 6550962 ZFS ACL inheritance needs to be enhanced to support Automatic Inheritance 6553589 RFE: VFS Feature Registration facility 6553770 RFE: ZFS support for ACL-on-CREATE (PSARC 2007/227) 6565581 ls(1) should support file system attributes proposed in PSARC/2007/315 6566784 NTFS streams are not copied along with the files. 6576205 cp(1), pack(1) and compress(1) should support file system attributes proposed in PSARC/2007/315 6578875 RFE: kernel interfaces for nbmand need improvement 6578883 RFE: VOP_SHRLOCK needs additional access types 6578885 chmod(1) should support file system attributes proposed in PSARC/2007/315 6578886 RFE: disallow nbmand state to change on remount 6583349 ACL parser needs to support audit/alarm ACE types 6590347 tar(1) should support filesystem attributes proposed in PSARC/2007/315 6597357 *tar* xv@ doesn't show the hidden directory even though it is restored 6597360 *tar* should re-init xattr info if openat() fails during extraction of and extended attribute 6597368 *tar* cannot restore hard linked extended attributes 6597374 *tar* doesn't display "x " when hard linked attributes are restored 6597375 *tar* extended attribute header off by one 6614861 *cpio* incorrectly archives extended system attributes with -@ 6614896 *pax* incorrectly archives extended system attributes with -@ 6615225 *tar* incorrectly archives extended system attributes with -@ 6617183 CIFS Service - PSARC 2006/715
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     1
/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     2
 * CDDL HEADER START
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     3
 *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     4
 * The contents of this file are subject to the terms of the
1462
117f7ea5a828 6355341 tar cannot restore ACLs to UFS
marks
parents: 1420
diff changeset
     5
 * Common Development and Distribution License (the "License").
117f7ea5a828 6355341 tar cannot restore ACLs to UFS
marks
parents: 1420
diff changeset
     6
 * You may not use this file except in compliance with the License.
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     7
 *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     8
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     9
 * or http://www.opensolaris.org/os/licensing.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    10
 * See the License for the specific language governing permissions
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    11
 * and limitations under the License.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    12
 *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    13
 * When distributing Covered Code, include this CDDL HEADER in each
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    14
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    15
 * If applicable, add the following below this CDDL HEADER, with the
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    16
 * fields enclosed by brackets "[]" replaced with your own identifying
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    17
 * information: Portions Copyright [yyyy] [name of copyright owner]
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    18
 *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    19
 * CDDL HEADER END
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    20
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    21
/*
4321
a8930ec16e52 PSARC 2007/064 Unified POSIX and Windows Credentials for Solaris
casper
parents: 1953
diff changeset
    22
 * Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    23
 * Use is subject to license terms.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    24
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    25
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    26
#pragma ident	"%Z%%M%	%I%	%E% SMI"
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    27
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    28
#include <stdlib.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    29
#include <string.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    30
#include <unistd.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    31
#include <limits.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    32
#include <grp.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    33
#include <pwd.h>
1462
117f7ea5a828 6355341 tar cannot restore ACLs to UFS
marks
parents: 1420
diff changeset
    34
#include <strings.h>
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    35
#include <sys/types.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    36
#include <errno.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    37
#include <sys/stat.h>
1420
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
    38
#include <sys/varargs.h>
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    39
#include <locale.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    40
#include <aclutils.h>
5331
3047ad28a67b PSARC/2007/218 caller_context_t in all VOPs
amw
parents: 4321
diff changeset
    41
#include <sys/avl.h>
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    42
#include <acl_common.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    43
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    44
#define	ACL_PATH	0
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    45
#define	ACL_FD		1
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    46
1231
64215f768e86 6354804 The file's ACL was changed when cp it from one ZFS file system to another one.
marks
parents: 789
diff changeset
    47
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    48
typedef union {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    49
	const char *file;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    50
	int  fd;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    51
} acl_inp;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    52
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    53
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    54
/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    55
 * Determine whether a file has a trivial ACL
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    56
 * returns: 	0 = trivial
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    57
 *		1 = nontrivial
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    58
 *		<0 some other system failure, such as ENOENT or EPERM
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    59
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    60
int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    61
acl_trivial(const char *filename)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    62
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    63
	int acl_flavor;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    64
	int aclcnt;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    65
	int cntcmd;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    66
	int val = 0;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    67
	ace_t *acep;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    68
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    69
	acl_flavor = pathconf(filename, _PC_ACL_ENABLED);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    70
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    71
	if (acl_flavor == _ACL_ACE_ENABLED)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    72
		cntcmd = ACE_GETACLCNT;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    73
	else
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    74
		cntcmd = GETACLCNT;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    75
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    76
	aclcnt = acl(filename, cntcmd, 0, NULL);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    77
	if (aclcnt > 0) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    78
		if (acl_flavor == _ACL_ACE_ENABLED) {
1231
64215f768e86 6354804 The file's ACL was changed when cp it from one ZFS file system to another one.
marks
parents: 789
diff changeset
    79
			acep = malloc(sizeof (ace_t) * aclcnt);
64215f768e86 6354804 The file's ACL was changed when cp it from one ZFS file system to another one.
marks
parents: 789
diff changeset
    80
			if (acep == NULL)
64215f768e86 6354804 The file's ACL was changed when cp it from one ZFS file system to another one.
marks
parents: 789
diff changeset
    81
				return (-1);
64215f768e86 6354804 The file's ACL was changed when cp it from one ZFS file system to another one.
marks
parents: 789
diff changeset
    82
			if (acl(filename, ACE_GETACL,
64215f768e86 6354804 The file's ACL was changed when cp it from one ZFS file system to another one.
marks
parents: 789
diff changeset
    83
			    aclcnt, acep) < 0) {
64215f768e86 6354804 The file's ACL was changed when cp it from one ZFS file system to another one.
marks
parents: 789
diff changeset
    84
				free(acep);
64215f768e86 6354804 The file's ACL was changed when cp it from one ZFS file system to another one.
marks
parents: 789
diff changeset
    85
				return (-1);
64215f768e86 6354804 The file's ACL was changed when cp it from one ZFS file system to another one.
marks
parents: 789
diff changeset
    86
			}
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    87
1231
64215f768e86 6354804 The file's ACL was changed when cp it from one ZFS file system to another one.
marks
parents: 789
diff changeset
    88
			val = ace_trivial(acep, aclcnt);
64215f768e86 6354804 The file's ACL was changed when cp it from one ZFS file system to another one.
marks
parents: 789
diff changeset
    89
			free(acep);
64215f768e86 6354804 The file's ACL was changed when cp it from one ZFS file system to another one.
marks
parents: 789
diff changeset
    90
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    91
		} else if (aclcnt > MIN_ACL_ENTRIES)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    92
			val = 1;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    93
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    94
	return (val);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    95
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    96
1462
117f7ea5a828 6355341 tar cannot restore ACLs to UFS
marks
parents: 1420
diff changeset
    97
1477
18d318bc863e 6389529 libsec fails to compile with gcc
marks
parents: 1462
diff changeset
    98
static int
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    99
cacl_get(acl_inp inp, int get_flag, int type, acl_t **aclp)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   100
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   101
	const char *fname;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   102
	int fd;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   103
	int ace_acl = 0;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   104
	int error;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   105
	int getcmd, cntcmd;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   106
	acl_t *acl_info;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   107
	int	save_errno;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   108
	int	stat_error;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   109
	struct stat64 statbuf;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   110
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   111
	*aclp = NULL;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   112
	if (type == ACL_PATH) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   113
		fname = inp.file;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   114
		ace_acl = pathconf(fname, _PC_ACL_ENABLED);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   115
	} else {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   116
		fd = inp.fd;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   117
		ace_acl = fpathconf(fd, _PC_ACL_ENABLED);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   118
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   119
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   120
	/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   121
	 * if acl's aren't supported then
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   122
	 * send it through the old GETACL interface
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   123
	 */
1666
07697c578888 6401243 ZFS ACLs should not break third party filesystems
marks
parents: 1477
diff changeset
   124
	if (ace_acl == 0 || ace_acl == -1) {
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   125
		ace_acl = _ACL_ACLENT_ENABLED;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   126
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   127
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   128
	if (ace_acl & _ACL_ACE_ENABLED) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   129
		cntcmd = ACE_GETACLCNT;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   130
		getcmd = ACE_GETACL;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   131
		acl_info = acl_alloc(ACE_T);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   132
	} else {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   133
		cntcmd = GETACLCNT;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   134
		getcmd = GETACL;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   135
		acl_info = acl_alloc(ACLENT_T);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   136
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   137
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   138
	if (acl_info == NULL)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   139
		return (-1);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   140
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   141
	if (type == ACL_PATH) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   142
		acl_info->acl_cnt = acl(fname, cntcmd, 0, NULL);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   143
	} else {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   144
		acl_info->acl_cnt = facl(fd, cntcmd, 0, NULL);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   145
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   146
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   147
	save_errno = errno;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   148
	if (acl_info->acl_cnt < 0) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   149
		acl_free(acl_info);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   150
		errno = save_errno;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   151
		return (-1);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   152
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   153
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   154
	if (acl_info->acl_cnt == 0) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   155
		acl_free(acl_info);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   156
		errno = save_errno;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   157
		return (0);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   158
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   159
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   160
	acl_info->acl_aclp =
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   161
	    malloc(acl_info->acl_cnt * acl_info->acl_entry_size);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   162
	save_errno = errno;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   163
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   164
	if (acl_info->acl_aclp == NULL) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   165
		acl_free(acl_info);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   166
		errno = save_errno;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   167
		return (-1);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   168
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   169
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   170
	if (type == ACL_PATH) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   171
		stat_error = stat64(fname, &statbuf);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   172
		error = acl(fname, getcmd, acl_info->acl_cnt,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   173
		    acl_info->acl_aclp);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   174
	} else {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   175
		stat_error = fstat64(fd, &statbuf);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   176
		error = facl(fd, getcmd, acl_info->acl_cnt,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   177
		    acl_info->acl_aclp);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   178
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   179
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   180
	save_errno = errno;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   181
	if (error == -1) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   182
		acl_free(acl_info);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   183
		errno = save_errno;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   184
		return (-1);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   185
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   186
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   187
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   188
	if (stat_error == 0) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   189
		acl_info->acl_flags =
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   190
		    (S_ISDIR(statbuf.st_mode) ? ACL_IS_DIR : 0);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   191
	} else
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   192
		acl_info->acl_flags = 0;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   193
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   194
	switch (acl_info->acl_type) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   195
	case ACLENT_T:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   196
		if (acl_info->acl_cnt <= MIN_ACL_ENTRIES)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   197
			acl_info->acl_flags |= ACL_IS_TRIVIAL;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   198
		break;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   199
	case ACE_T:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   200
		if (ace_trivial(acl_info->acl_aclp, acl_info->acl_cnt) == 0)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   201
			acl_info->acl_flags |= ACL_IS_TRIVIAL;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   202
		break;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   203
	default:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   204
		errno = EINVAL;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   205
		acl_free(acl_info);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   206
		return (-1);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   207
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   208
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   209
	if ((acl_info->acl_flags & ACL_IS_TRIVIAL) &&
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   210
	    (get_flag & ACL_NO_TRIVIAL)) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   211
		acl_free(acl_info);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   212
		errno = 0;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   213
		return (0);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   214
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   215
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   216
	*aclp = acl_info;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   217
	return (0);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   218
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   219
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   220
/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   221
 * return -1 on failure, otherwise the number of acl
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   222
 * entries is returned
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   223
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   224
int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   225
acl_get(const char *path, int get_flag, acl_t **aclp)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   226
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   227
	acl_inp acl_inp;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   228
	acl_inp.file = path;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   229
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   230
	return (cacl_get(acl_inp, get_flag, ACL_PATH, aclp));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   231
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   232
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   233
int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   234
facl_get(int fd, int get_flag, acl_t **aclp)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   235
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   236
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   237
	acl_inp acl_inp;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   238
	acl_inp.fd = fd;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   239
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   240
	return (cacl_get(acl_inp, get_flag, ACL_FD, aclp));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   241
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   242
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   243
/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   244
 * Set an ACL, translates acl to ace_t when appropriate.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   245
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   246
static int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   247
cacl_set(acl_inp *acl_inp, acl_t *aclp, int type)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   248
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   249
	int error = 0;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   250
	int acl_flavor_target;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   251
	struct stat64 statbuf;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   252
	int stat_error;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   253
	int isdir;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   254
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   255
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   256
	if (type == ACL_PATH) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   257
		stat_error = stat64(acl_inp->file, &statbuf);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   258
		if (stat_error)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   259
			return (-1);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   260
		acl_flavor_target = pathconf(acl_inp->file, _PC_ACL_ENABLED);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   261
	} else {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   262
		stat_error = fstat64(acl_inp->fd, &statbuf);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   263
		if (stat_error)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   264
			return (-1);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   265
		acl_flavor_target = fpathconf(acl_inp->fd, _PC_ACL_ENABLED);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   266
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   267
1666
07697c578888 6401243 ZFS ACLs should not break third party filesystems
marks
parents: 1477
diff changeset
   268
	/*
07697c578888 6401243 ZFS ACLs should not break third party filesystems
marks
parents: 1477
diff changeset
   269
	 * If target returns an error or 0 from pathconf call then
07697c578888 6401243 ZFS ACLs should not break third party filesystems
marks
parents: 1477
diff changeset
   270
	 * fall back to UFS/POSIX Draft interface.
07697c578888 6401243 ZFS ACLs should not break third party filesystems
marks
parents: 1477
diff changeset
   271
	 * In the case of 0 we will then fail in either acl(2) or
07697c578888 6401243 ZFS ACLs should not break third party filesystems
marks
parents: 1477
diff changeset
   272
	 * acl_translate().  We could erroneously get 0 back from
07697c578888 6401243 ZFS ACLs should not break third party filesystems
marks
parents: 1477
diff changeset
   273
	 * a file system that is using fs_pathconf() and not answering
07697c578888 6401243 ZFS ACLs should not break third party filesystems
marks
parents: 1477
diff changeset
   274
	 * the _PC_ACL_ENABLED question itself.
07697c578888 6401243 ZFS ACLs should not break third party filesystems
marks
parents: 1477
diff changeset
   275
	 */
07697c578888 6401243 ZFS ACLs should not break third party filesystems
marks
parents: 1477
diff changeset
   276
	if (acl_flavor_target == 0 || acl_flavor_target == -1)
07697c578888 6401243 ZFS ACLs should not break third party filesystems
marks
parents: 1477
diff changeset
   277
		acl_flavor_target = _ACL_ACLENT_ENABLED;
07697c578888 6401243 ZFS ACLs should not break third party filesystems
marks
parents: 1477
diff changeset
   278
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   279
	isdir = S_ISDIR(statbuf.st_mode);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   280
1462
117f7ea5a828 6355341 tar cannot restore ACLs to UFS
marks
parents: 1420
diff changeset
   281
	if ((error = acl_translate(aclp, acl_flavor_target, isdir,
117f7ea5a828 6355341 tar cannot restore ACLs to UFS
marks
parents: 1420
diff changeset
   282
	    statbuf.st_uid, statbuf.st_gid)) != 0) {
117f7ea5a828 6355341 tar cannot restore ACLs to UFS
marks
parents: 1420
diff changeset
   283
		return (error);
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   284
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   285
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   286
	if (type == ACL_PATH) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   287
		error = acl(acl_inp->file,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   288
		    (aclp->acl_type == ACE_T) ? ACE_SETACL : SETACL,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   289
		    aclp->acl_cnt, aclp->acl_aclp);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   290
	} else {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   291
		error = facl(acl_inp->fd,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   292
		    (aclp->acl_type == ACE_T) ? ACE_SETACL : SETACL,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   293
		    aclp->acl_cnt, aclp->acl_aclp);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   294
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   295
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   296
	return (error);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   297
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   298
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   299
int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   300
acl_set(const char *path, acl_t *aclp)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   301
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   302
	acl_inp acl_inp;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   303
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   304
	acl_inp.file = path;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   305
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   306
	return (cacl_set(&acl_inp, aclp, ACL_PATH));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   307
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   308
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   309
int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   310
facl_set(int fd, acl_t *aclp)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   311
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   312
	acl_inp acl_inp;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   313
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   314
	acl_inp.fd = fd;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   315
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   316
	return (cacl_set(&acl_inp, aclp, ACL_FD));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   317
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   318
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   319
int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   320
acl_cnt(acl_t *aclp)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   321
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   322
	return (aclp->acl_cnt);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   323
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   324
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   325
int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   326
acl_type(acl_t *aclp)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   327
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   328
	return (aclp->acl_type);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   329
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   330
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   331
acl_t *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   332
acl_dup(acl_t *aclp)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   333
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   334
	acl_t *newaclp;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   335
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   336
	newaclp = acl_alloc(aclp->acl_type);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   337
	if (newaclp == NULL)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   338
		return (NULL);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   339
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   340
	newaclp->acl_aclp = malloc(aclp->acl_entry_size * aclp->acl_cnt);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   341
	if (newaclp->acl_aclp == NULL) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   342
		acl_free(newaclp);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   343
		return (NULL);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   344
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   345
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   346
	(void) memcpy(newaclp->acl_aclp,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   347
	    aclp->acl_aclp, aclp->acl_entry_size * aclp->acl_cnt);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   348
	newaclp->acl_cnt = aclp->acl_cnt;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   349
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   350
	return (newaclp);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   351
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   352
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   353
int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   354
acl_flags(acl_t *aclp)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   355
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   356
	return (aclp->acl_flags);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   357
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   358
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   359
void *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   360
acl_data(acl_t *aclp)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   361
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   362
	return (aclp->acl_aclp);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   363
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   364
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   365
/*
1953
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   366
 * Take an acl array and build an acl_t.
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   367
 */
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   368
acl_t *
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   369
acl_to_aclp(enum acl_type type, void *acl, int count)
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   370
{
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   371
	acl_t *aclp;
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   372
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   373
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   374
	aclp = acl_alloc(type);
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   375
	if (aclp == NULL)
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   376
		return (aclp);
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   377
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   378
	aclp->acl_aclp = acl;
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   379
	aclp->acl_cnt = count;
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   380
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   381
	return (aclp);
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   382
}
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   383
7d218c488035 6421216 ufsrestore should use acl_set() for setting ACLs
marks
parents: 1666
diff changeset
   384
/*
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   385
 * Remove an ACL from a file and create a trivial ACL based
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   386
 * off of the mode argument.  After acl has been set owner/group
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   387
 * are updated to match owner,group arguments
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   388
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   389
int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   390
acl_strip(const char *file, uid_t owner, gid_t group, mode_t mode)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   391
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   392
	int	error = 0;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   393
	aclent_t min_acl[MIN_ACL_ENTRIES];
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   394
	ace_t	min_ace_acl[6];	/* owner, group, everyone + complement denies */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   395
	int	acl_flavor;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   396
	int	aclcnt;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   397
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   398
	acl_flavor = pathconf(file, _PC_ACL_ENABLED);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   399
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   400
	/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   401
	 * force it through aclent flavor when file system doesn't
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   402
	 * understand question
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   403
	 */
1666
07697c578888 6401243 ZFS ACLs should not break third party filesystems
marks
parents: 1477
diff changeset
   404
	if (acl_flavor == 0 || acl_flavor == -1)
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   405
		acl_flavor = _ACL_ACLENT_ENABLED;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   406
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   407
	if (acl_flavor & _ACL_ACLENT_ENABLED) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   408
		min_acl[0].a_type = USER_OBJ;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   409
		min_acl[0].a_id   = owner;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   410
		min_acl[0].a_perm = ((mode & 0700) >> 6);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   411
		min_acl[1].a_type = GROUP_OBJ;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   412
		min_acl[1].a_id   = group;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   413
		min_acl[1].a_perm = ((mode & 0070) >> 3);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   414
		min_acl[2].a_type = CLASS_OBJ;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   415
		min_acl[2].a_id   = (uid_t)-1;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   416
		min_acl[2].a_perm = ((mode & 0070) >> 3);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   417
		min_acl[3].a_type = OTHER_OBJ;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   418
		min_acl[3].a_id   = (uid_t)-1;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   419
		min_acl[3].a_perm = (mode & 0007);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   420
		aclcnt = 4;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   421
		error = acl(file, SETACL, aclcnt, min_acl);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   422
	} else if (acl_flavor & _ACL_ACE_ENABLED) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   423
		(void) memcpy(min_ace_acl, trivial_acl, sizeof (ace_t) * 6);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   424
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   425
		/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   426
		 * Make aces match request mode
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   427
		 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   428
		adjust_ace_pair(&min_ace_acl[0], (mode & 0700) >> 6);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   429
		adjust_ace_pair(&min_ace_acl[2], (mode & 0070) >> 3);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   430
		adjust_ace_pair(&min_ace_acl[4], mode & 0007);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   431
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   432
		error = acl(file, ACE_SETACL, 6, min_ace_acl);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   433
	} else {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   434
		errno = EINVAL;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   435
		error = 1;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   436
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   437
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   438
	if (error == 0)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   439
		error = chown(file, owner, group);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   440
	return (error);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   441
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   442
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   443
static int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   444
ace_match(void *entry1, void *entry2)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   445
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   446
	ace_t *p1 = (ace_t *)entry1;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   447
	ace_t *p2 = (ace_t *)entry2;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   448
	ace_t ace1, ace2;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   449
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   450
	ace1 = *p1;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   451
	ace2 = *p2;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   452
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   453
	/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   454
	 * Need to fixup who field for abstrations for
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   455
	 * accurate comparison, since field is undefined.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   456
	 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   457
	if (ace1.a_flags & (ACE_OWNER|ACE_GROUP|ACE_EVERYONE))
4321
a8930ec16e52 PSARC 2007/064 Unified POSIX and Windows Credentials for Solaris
casper
parents: 1953
diff changeset
   458
		ace1.a_who = (uid_t)-1;
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   459
	if (ace2.a_flags & (ACE_OWNER|ACE_GROUP|ACE_EVERYONE))
4321
a8930ec16e52 PSARC 2007/064 Unified POSIX and Windows Credentials for Solaris
casper
parents: 1953
diff changeset
   460
		ace2.a_who = (uid_t)-1;
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   461
	return (memcmp(&ace1, &ace2, sizeof (ace_t)));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   462
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   463
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   464
static int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   465
aclent_match(void *entry1, void *entry2)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   466
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   467
	aclent_t *aclent1 = (aclent_t *)entry1;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   468
	aclent_t *aclent2 = (aclent_t *)entry2;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   469
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   470
	return (memcmp(aclent1, aclent2, sizeof (aclent_t)));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   471
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   472
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   473
/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   474
 * Find acl entries in acl that correspond to removeacl.  Search
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   475
 * is started from slot.  The flag argument indicates whether to
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   476
 * remove all matches or just the first match.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   477
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   478
int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   479
acl_removeentries(acl_t *acl, acl_t *removeacl, int start_slot, int flag)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   480
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   481
	int i, j;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   482
	int match;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   483
	int (*acl_match)(void *acl1, void *acl2);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   484
	void *acl_entry, *remove_entry;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   485
	void *start;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   486
	int found = 0;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   487
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   488
	if (flag != ACL_REMOVE_ALL && flag != ACL_REMOVE_FIRST)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   489
		flag = ACL_REMOVE_FIRST;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   490
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   491
	if (acl == NULL || removeacl == NULL)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   492
		return (EACL_NO_ACL_ENTRY);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   493
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   494
	if (acl->acl_type != removeacl->acl_type)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   495
		return (EACL_DIFF_TYPE);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   496
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   497
	if (acl->acl_type == ACLENT_T)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   498
		acl_match = aclent_match;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   499
	else
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   500
		acl_match = ace_match;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   501
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   502
	for (i = 0, remove_entry = removeacl->acl_aclp;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   503
	    i != removeacl->acl_cnt; i++) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   504
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   505
		j = 0;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   506
		acl_entry = (char *)acl->acl_aclp +
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   507
		    (acl->acl_entry_size * start_slot);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   508
		for (;;) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   509
			match = acl_match(acl_entry, remove_entry);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   510
			if (match == 0)  {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   511
				found++;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   512
				start = (char *)acl_entry +
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   513
				    acl->acl_entry_size;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   514
				(void) memmove(acl_entry, start,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   515
				    acl->acl_entry_size *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   516
				    acl->acl_cnt-- - (j + 1));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   517
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   518
				if (flag == ACL_REMOVE_FIRST)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   519
					break;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   520
				/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   521
				 * List has changed, restart search from
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   522
				 * beginning.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   523
				 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   524
				acl_entry = acl->acl_aclp;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   525
				j = 0;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   526
				continue;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   527
			}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   528
			acl_entry = ((char *)acl_entry + acl->acl_entry_size);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   529
			if (++j >= acl->acl_cnt) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   530
				break;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   531
			}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   532
		}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   533
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   534
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   535
	return ((found == 0) ? EACL_NO_ACL_ENTRY : 0);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   536
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   537
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   538
/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   539
 * Replace entires entries in acl1 with the corresponding entries
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   540
 * in newentries.  The where argument specifies where to begin
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   541
 * the replacement.  If the where argument is 1 greater than the
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   542
 * number of acl entries in acl1 then they are appended.  If the
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   543
 * where argument is 2+ greater than the number of acl entries then
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   544
 * EACL_INVALID_SLOT is returned.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   545
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   546
int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   547
acl_modifyentries(acl_t *acl1, acl_t *newentries, int where)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   548
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   549
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   550
	int slot;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   551
	int slots_needed;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   552
	int slots_left;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   553
	int newsize;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   554
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   555
	if (acl1 == NULL || newentries == NULL)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   556
		return (EACL_NO_ACL_ENTRY);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   557
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   558
	if (where < 0 || where >= acl1->acl_cnt)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   559
		return (EACL_INVALID_SLOT);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   560
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   561
	if (acl1->acl_type != newentries->acl_type)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   562
		return (EACL_DIFF_TYPE);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   563
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   564
	slot = where;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   565
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   566
	slots_left = acl1->acl_cnt - slot + 1;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   567
	if (slots_left < newentries->acl_cnt) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   568
		slots_needed = newentries->acl_cnt - slots_left;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   569
		newsize = (acl1->acl_entry_size * acl1->acl_cnt) +
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   570
		    (acl1->acl_entry_size * slots_needed);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   571
		acl1->acl_aclp = realloc(acl1->acl_aclp, newsize);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   572
		if (acl1->acl_aclp == NULL)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   573
			return (-1);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   574
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   575
	(void) memcpy((char *)acl1->acl_aclp + (acl1->acl_entry_size * slot),
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   576
	    newentries->acl_aclp,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   577
	    newentries->acl_entry_size * newentries->acl_cnt);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   578
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   579
	/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   580
	 * Did ACL grow?
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   581
	 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   582
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   583
	if ((slot + newentries->acl_cnt) > acl1->acl_cnt) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   584
		acl1->acl_cnt = slot + newentries->acl_cnt;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   585
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   586
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   587
	return (0);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   588
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   589
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   590
/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   591
 * Add acl2 entries into acl1.  The where argument specifies where
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   592
 * to add the entries.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   593
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   594
int
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   595
acl_addentries(acl_t *acl1, acl_t *acl2, int where)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   596
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   597
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   598
	int newsize;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   599
	int len;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   600
	void *start;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   601
	void *to;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   602
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   603
	if (acl1 == NULL || acl2 == NULL)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   604
		return (EACL_NO_ACL_ENTRY);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   605
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   606
	if (acl1->acl_type != acl2->acl_type)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   607
		return (EACL_DIFF_TYPE);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   608
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   609
	/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   610
	 * allow where to specify 1 past last slot for an append operation
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   611
	 * but anything greater is an error.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   612
	 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   613
	if (where < 0 || where > acl1->acl_cnt)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   614
		return (EACL_INVALID_SLOT);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   615
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   616
	newsize = (acl2->acl_entry_size * acl2->acl_cnt) +
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   617
	    (acl1->acl_entry_size * acl1->acl_cnt);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   618
	acl1->acl_aclp = realloc(acl1->acl_aclp, newsize);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   619
	if (acl1->acl_aclp == NULL)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   620
		return (-1);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   621
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   622
	/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   623
	 * first push down entries where new ones will be inserted
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   624
	 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   625
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   626
	to = (void *)((char *)acl1->acl_aclp +
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   627
	    ((where + acl2->acl_cnt) * acl1->acl_entry_size));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   628
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   629
	start = (void *)((char *)acl1->acl_aclp +
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   630
	    where * acl1->acl_entry_size);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   631
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   632
	if (where < acl1->acl_cnt) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   633
		len = (acl1->acl_cnt - where) * acl1->acl_entry_size;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   634
		(void) memmove(to, start, len);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   635
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   636
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   637
	/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   638
	 * now stick in new entries.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   639
	 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   640
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   641
	(void) memmove(start, acl2->acl_aclp,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   642
	    acl2->acl_cnt * acl2->acl_entry_size);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   643
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   644
	acl1->acl_cnt += acl2->acl_cnt;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   645
	return (0);
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   646
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   647
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   648
/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   649
 * return text for an ACL error.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   650
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   651
char *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   652
acl_strerror(int errnum)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   653
{
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   654
	switch (errnum) {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   655
	case EACL_GRP_ERROR:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   656
		return (dgettext(TEXT_DOMAIN,
1420
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   657
		    "There is more than one group or default group entry"));
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   658
	case EACL_USER_ERROR:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   659
		return (dgettext(TEXT_DOMAIN,
1420
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   660
		    "There is more than one user or default user entry"));
789
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   661
	case EACL_OTHER_ERROR:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   662
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   663
		    "There is more than one other entry"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   664
	case EACL_CLASS_ERROR:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   665
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   666
		    "There is more than one mask entry"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   667
	case EACL_DUPLICATE_ERROR:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   668
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   669
		    "Duplicate user or group entries"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   670
	case EACL_MISS_ERROR:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   671
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   672
		    "Missing user/group owner, other, mask entry"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   673
	case EACL_MEM_ERROR:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   674
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   675
		    "Memory error"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   676
	case EACL_ENTRY_ERROR:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   677
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   678
		    "Unrecognized entry type"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   679
	case EACL_INHERIT_ERROR:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   680
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   681
		    "Invalid inheritance flags"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   682
	case EACL_FLAGS_ERROR:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   683
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   684
		    "Unrecognized entry flags"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   685
	case EACL_PERM_MASK_ERROR:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   686
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   687
		    "Invalid ACL permissions"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   688
	case EACL_COUNT_ERROR:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   689
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   690
		    "Invalid ACL count"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   691
	case EACL_INVALID_SLOT:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   692
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   693
		    "Invalid ACL entry number specified"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   694
	case EACL_NO_ACL_ENTRY:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   695
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   696
		    "ACL entry doesn't exist"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   697
	case EACL_DIFF_TYPE:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   698
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   699
		    "ACL type's are different"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   700
	case EACL_INVALID_USER_GROUP:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   701
		return (dgettext(TEXT_DOMAIN, "Invalid user or group"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   702
	case EACL_INVALID_STR:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   703
		return (dgettext(TEXT_DOMAIN, "ACL string is invalid"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   704
	case EACL_FIELD_NOT_BLANK:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   705
		return (dgettext(TEXT_DOMAIN, "Field expected to be blank"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   706
	case EACL_INVALID_ACCESS_TYPE:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   707
		return (dgettext(TEXT_DOMAIN, "Invalid access type"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   708
	case EACL_UNKNOWN_DATA:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   709
		return (dgettext(TEXT_DOMAIN, "Unrecognized entry"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   710
	case EACL_MISSING_FIELDS:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   711
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   712
		    "ACL specification missing required fields"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   713
	case EACL_INHERIT_NOTDIR:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   714
		return (dgettext(TEXT_DOMAIN,
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   715
		    "Inheritance flags are only allowed on directories"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   716
	case -1:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   717
		return (strerror(errno));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   718
	default:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   719
		errno = EINVAL;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   720
		return (dgettext(TEXT_DOMAIN, "Unknown error"));
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   721
	}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   722
}
1420
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   723
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   724
extern int yyinteractive;
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   725
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   726
/* PRINTFLIKE1 */
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   727
void
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   728
acl_error(const char *fmt, ...)
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   729
{
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   730
	va_list va;
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   731
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   732
	if (yyinteractive == 0)
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   733
		return;
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   734
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   735
	va_start(va, fmt);
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   736
	(void) vfprintf(stderr, fmt, va);
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   737
	va_end(va);
4cb3c26a37e0 PSARC/2006/043 ls -V
marks
parents: 1231
diff changeset
   738
}