usr/src/uts/common/fs/zfs/sys/zfs_vfsops.h
author ahrens
Mon, 09 Oct 2006 10:56:01 -0700
changeset 2885 c0259887ebbc
parent 789 b348f31ed315
child 3461 c19b22f347d6
permissions -rw-r--r--
6460059 zfs destroy <snapshot> leaves behind kruft 6463788 'zfs recv -d' fails if some ancestors already exist 6464897 assertion failed: "BP_GET_COMPRESS(bp) == compress" zio.c, line:897 6472843 panic when write to zvol snapshot 6475506 panic in dmu_recvbackup due to NULL pointer dereference 6475942 need more assertions in dnode_destroy() 6477102 recvbackup ioctl does not advance file offset 6477103 read-only properties should be passed as nvlist 6477900 want more /etc/system tunables for ZFS performance analysis 6479497 ::abuf_find is broken
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
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     5
 * Common Development and Distribution License, Version 1.0 only
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     6
 * (the "License").  You may not use this file except in compliance
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     7
 * with the License.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     8
 *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
     9
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    10
 * or http://www.opensolaris.org/os/licensing.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    11
 * See the License for the specific language governing permissions
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    12
 * and limitations under the License.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    13
 *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    14
 * When distributing Covered Code, include this CDDL HEADER in each
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    15
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    16
 * If applicable, add the following below this CDDL HEADER, with the
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    17
 * fields enclosed by brackets "[]" replaced with your own identifying
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    18
 * information: Portions Copyright [yyyy] [name of copyright owner]
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    19
 *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    20
 * CDDL HEADER END
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    21
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    22
/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    23
 * Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    24
 * Use is subject to license terms.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    25
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    26
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    27
#ifndef	_SYS_FS_ZFS_VFSOPS_H
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    28
#define	_SYS_FS_ZFS_VFSOPS_H
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    29
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    30
#pragma ident	"%Z%%M%	%I%	%E% SMI"
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    31
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    32
#include <sys/isa_defs.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    33
#include <sys/types32.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    34
#include <sys/list.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    35
#include <sys/vfs.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    36
#include <sys/zil.h>
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    37
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    38
#ifdef	__cplusplus
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    39
extern "C" {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    40
#endif
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    41
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    42
typedef struct zfs_delete_list {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    43
	kmutex_t		z_mutex;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    44
	kcondvar_t		z_cv;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    45
	kcondvar_t		z_quiesce_cv;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    46
	uint8_t			z_drained;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    47
	uint8_t			z_draining;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    48
	uint32_t		z_thread_target;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    49
	uint32_t		z_thread_count;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    50
	uint64_t		z_znode_count;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    51
	list_t			z_znodes;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    52
} zfs_delete_t;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    53
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    54
typedef struct zfsvfs zfsvfs_t;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    55
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    56
struct zfsvfs {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    57
	vfs_t		*z_vfs;		/* generic fs struct */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    58
	zfsvfs_t	*z_parent;	/* parent fs */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    59
	objset_t	*z_os;		/* objset reference */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    60
	uint64_t	z_root;		/* id of root znode */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    61
	uint64_t	z_dqueue;	/* delete queue */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    62
	uint64_t	z_max_blksz;	/* maximum block size for files */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    63
	uint64_t	z_assign;	/* TXG_NOWAIT or set by zil_replay() */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    64
	zilog_t		*z_log;		/* intent log pointer */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    65
	uint_t		z_acl_mode;	/* acl chmod/mode behavior */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    66
	uint_t		z_acl_inherit;	/* acl inheritance behavior */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    67
	boolean_t	z_atime;	/* enable atimes mount option */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    68
	boolean_t	z_unmounted1;	/* unmounted phase 1 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    69
	boolean_t	z_unmounted2;	/* unmounted phase 2 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    70
	uint32_t	z_op_cnt;	/* vnode/vfs operations ref count */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    71
	krwlock_t	z_um_lock;	/* rw lock for umount phase 2 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    72
	zfs_delete_t 	z_delete_head;	/* zfs delete list */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    73
	list_t		z_all_znodes;	/* all vnodes in the fs */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    74
	kmutex_t	z_znodes_lock;	/* lock for z_all_znodes */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    75
	vnode_t		*z_ctldir;	/* .zfs directory pointer */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    76
	boolean_t	z_show_ctldir;	/* expose .zfs in the root dir */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    77
	boolean_t	z_issnap;	/* true if this is a snapshot */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    78
#define	ZFS_OBJ_MTX_SZ	64
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    79
	kmutex_t	z_hold_mtx[ZFS_OBJ_MTX_SZ];	/* znode hold locks */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    80
};
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    81
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    82
/*
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    83
 * The total file ID size is limited to 12 bytes (including the length
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    84
 * field) in the NFSv2 protocol.  For historical reasons, this same limit
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    85
 * is currently being imposed by the Solaris NFSv3 implementation...
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    86
 * although the protocol actually permits a maximum of 64 bytes.  It will
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    87
 * not be possible to expand beyond 12 bytes without abandoning support
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    88
 * of NFSv2 and making some changes to the Solaris NFSv3 implementation.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    89
 *
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    90
 * For the time being, we will partition up the available space as follows:
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    91
 *	2 bytes		fid length (required)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    92
 *	6 bytes		object number (48 bits)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    93
 *	4 bytes		generation number (32 bits)
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    94
 * We reserve only 48 bits for the object number, as this is the limit
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    95
 * currently defined and imposed by the DMU.
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    96
 */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    97
typedef struct zfid_short {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    98
	uint16_t	zf_len;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
    99
	uint8_t		zf_object[6];		/* obj[i] = obj >> (8 * i) */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   100
	uint8_t		zf_gen[4];		/* gen[i] = gen >> (8 * i) */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   101
} zfid_short_t;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   102
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   103
typedef struct zfid_long {
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   104
	zfid_short_t	z_fid;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   105
	uint8_t		zf_setid[6];		/* obj[i] = obj >> (8 * i) */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   106
	uint8_t		zf_setgen[4];		/* gen[i] = gen >> (8 * i) */
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   107
} zfid_long_t;
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   108
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   109
#define	SHORT_FID_LEN	(sizeof (zfid_short_t) - sizeof (uint16_t))
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   110
#define	LONG_FID_LEN	(sizeof (zfid_long_t) - sizeof (uint16_t))
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   111
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   112
#ifdef	__cplusplus
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   113
}
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   114
#endif
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   115
b348f31ed315 PSARC 2002/240 ZFS
ahrens
parents:
diff changeset
   116
#endif	/* _SYS_FS_ZFS_VFSOPS_H */