Home | History | Annotate | Line # | Download | only in fs
      1  1.1     haad /*
      2  1.1     haad  * CDDL HEADER START
      3  1.1     haad  *
      4  1.1     haad  * The contents of this file are subject to the terms of the
      5  1.1     haad  * Common Development and Distribution License (the "License").
      6  1.1     haad  * You may not use this file except in compliance with the License.
      7  1.1     haad  *
      8  1.1     haad  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
      9  1.1     haad  * or http://www.opensolaris.org/os/licensing.
     10  1.1     haad  * See the License for the specific language governing permissions
     11  1.1     haad  * and limitations under the License.
     12  1.1     haad  *
     13  1.1     haad  * When distributing Covered Code, include this CDDL HEADER in each
     14  1.1     haad  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
     15  1.1     haad  * If applicable, add the following below this CDDL HEADER, with the
     16  1.1     haad  * fields enclosed by brackets "[]" replaced with your own identifying
     17  1.1     haad  * information: Portions Copyright [yyyy] [name of copyright owner]
     18  1.1     haad  *
     19  1.1     haad  * CDDL HEADER END
     20  1.1     haad  */
     21  1.3     haad 
     22  1.1     haad /*
     23  1.5      chs  * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
     24  1.5      chs  * Copyright (c) 2011, 2014 by Delphix. All rights reserved.
     25  1.5      chs  * Copyright 2011 Nexenta Systems, Inc.  All rights reserved.
     26  1.5      chs  * Copyright (c) 2013, Joyent, Inc. All rights reserved.
     27  1.5      chs  * Copyright (c) 2012, Martin Matuska <mm (at) FreeBSD.org>. All rights reserved.
     28  1.5      chs  * Copyright (c) 2014 Integros [integros.com]
     29  1.1     haad  */
     30  1.1     haad 
     31  1.5      chs /* Portions Copyright 2010 Robert Milkowski */
     32  1.5      chs 
     33  1.1     haad #ifndef	_SYS_FS_ZFS_H
     34  1.1     haad #define	_SYS_FS_ZFS_H
     35  1.1     haad 
     36  1.5      chs #include <sys/types.h>
     37  1.5      chs #include <sys/ioccom.h>
     38  1.3     haad #include <sys/time.h>
     39  1.3     haad 
     40  1.1     haad #ifdef	__cplusplus
     41  1.1     haad extern "C" {
     42  1.1     haad #endif
     43  1.1     haad 
     44  1.1     haad /*
     45  1.1     haad  * Types and constants shared between userland and the kernel.
     46  1.1     haad  */
     47  1.1     haad 
     48  1.1     haad /*
     49  1.1     haad  * Each dataset can be one of the following types.  These constants can be
     50  1.1     haad  * combined into masks that can be passed to various functions.
     51  1.1     haad  */
     52  1.1     haad typedef enum {
     53  1.5      chs 	ZFS_TYPE_FILESYSTEM	= (1 << 0),
     54  1.5      chs 	ZFS_TYPE_SNAPSHOT	= (1 << 1),
     55  1.5      chs 	ZFS_TYPE_VOLUME		= (1 << 2),
     56  1.5      chs 	ZFS_TYPE_POOL		= (1 << 3),
     57  1.5      chs 	ZFS_TYPE_BOOKMARK	= (1 << 4)
     58  1.1     haad } zfs_type_t;
     59  1.1     haad 
     60  1.5      chs /*
     61  1.5      chs  * NB: lzc_dataset_type should be updated whenever a new objset type is added,
     62  1.5      chs  * if it represents a real type of a dataset that can be created from userland.
     63  1.5      chs  */
     64  1.5      chs typedef enum dmu_objset_type {
     65  1.5      chs 	DMU_OST_NONE,
     66  1.5      chs 	DMU_OST_META,
     67  1.5      chs 	DMU_OST_ZFS,
     68  1.5      chs 	DMU_OST_ZVOL,
     69  1.5      chs 	DMU_OST_OTHER,			/* For testing only! */
     70  1.5      chs 	DMU_OST_ANY,			/* Be careful! */
     71  1.5      chs 	DMU_OST_NUMTYPES
     72  1.5      chs } dmu_objset_type_t;
     73  1.5      chs 
     74  1.1     haad #define	ZFS_TYPE_DATASET	\
     75  1.1     haad 	(ZFS_TYPE_FILESYSTEM | ZFS_TYPE_VOLUME | ZFS_TYPE_SNAPSHOT)
     76  1.1     haad 
     77  1.5      chs /*
     78  1.5      chs  * All of these include the terminating NUL byte.
     79  1.5      chs  */
     80  1.3     haad #define	ZAP_MAXNAMELEN 256
     81  1.3     haad #define	ZAP_MAXVALUELEN (1024 * 8)
     82  1.3     haad #define	ZAP_OLDMAXVALUELEN 1024
     83  1.5      chs #define	ZFS_MAX_DATASET_NAME_LEN 256
     84  1.3     haad 
     85  1.1     haad /*
     86  1.1     haad  * Dataset properties are identified by these constants and must be added to
     87  1.1     haad  * the end of this list to ensure that external consumers are not affected
     88  1.1     haad  * by the change. If you make any changes to this list, be sure to update
     89  1.1     haad  * the property table in usr/src/common/zfs/zfs_prop.c.
     90  1.1     haad  */
     91  1.1     haad typedef enum {
     92  1.1     haad 	ZFS_PROP_TYPE,
     93  1.1     haad 	ZFS_PROP_CREATION,
     94  1.1     haad 	ZFS_PROP_USED,
     95  1.1     haad 	ZFS_PROP_AVAILABLE,
     96  1.1     haad 	ZFS_PROP_REFERENCED,
     97  1.1     haad 	ZFS_PROP_COMPRESSRATIO,
     98  1.1     haad 	ZFS_PROP_MOUNTED,
     99  1.1     haad 	ZFS_PROP_ORIGIN,
    100  1.1     haad 	ZFS_PROP_QUOTA,
    101  1.1     haad 	ZFS_PROP_RESERVATION,
    102  1.1     haad 	ZFS_PROP_VOLSIZE,
    103  1.1     haad 	ZFS_PROP_VOLBLOCKSIZE,
    104  1.1     haad 	ZFS_PROP_RECORDSIZE,
    105  1.1     haad 	ZFS_PROP_MOUNTPOINT,
    106  1.1     haad 	ZFS_PROP_SHARENFS,
    107  1.1     haad 	ZFS_PROP_CHECKSUM,
    108  1.1     haad 	ZFS_PROP_COMPRESSION,
    109  1.1     haad 	ZFS_PROP_ATIME,
    110  1.1     haad 	ZFS_PROP_DEVICES,
    111  1.1     haad 	ZFS_PROP_EXEC,
    112  1.1     haad 	ZFS_PROP_SETUID,
    113  1.1     haad 	ZFS_PROP_READONLY,
    114  1.1     haad 	ZFS_PROP_ZONED,
    115  1.1     haad 	ZFS_PROP_SNAPDIR,
    116  1.1     haad 	ZFS_PROP_ACLMODE,
    117  1.1     haad 	ZFS_PROP_ACLINHERIT,
    118  1.1     haad 	ZFS_PROP_CREATETXG,		/* not exposed to the user */
    119  1.1     haad 	ZFS_PROP_NAME,			/* not exposed to the user */
    120  1.1     haad 	ZFS_PROP_CANMOUNT,
    121  1.1     haad 	ZFS_PROP_ISCSIOPTIONS,		/* not exposed to the user */
    122  1.1     haad 	ZFS_PROP_XATTR,
    123  1.1     haad 	ZFS_PROP_NUMCLONES,		/* not exposed to the user */
    124  1.1     haad 	ZFS_PROP_COPIES,
    125  1.1     haad 	ZFS_PROP_VERSION,
    126  1.1     haad 	ZFS_PROP_UTF8ONLY,
    127  1.1     haad 	ZFS_PROP_NORMALIZE,
    128  1.1     haad 	ZFS_PROP_CASE,
    129  1.1     haad 	ZFS_PROP_VSCAN,
    130  1.1     haad 	ZFS_PROP_NBMAND,
    131  1.1     haad 	ZFS_PROP_SHARESMB,
    132  1.1     haad 	ZFS_PROP_REFQUOTA,
    133  1.1     haad 	ZFS_PROP_REFRESERVATION,
    134  1.1     haad 	ZFS_PROP_GUID,
    135  1.1     haad 	ZFS_PROP_PRIMARYCACHE,
    136  1.1     haad 	ZFS_PROP_SECONDARYCACHE,
    137  1.1     haad 	ZFS_PROP_USEDSNAP,
    138  1.1     haad 	ZFS_PROP_USEDDS,
    139  1.1     haad 	ZFS_PROP_USEDCHILD,
    140  1.1     haad 	ZFS_PROP_USEDREFRESERV,
    141  1.3     haad 	ZFS_PROP_USERACCOUNTING,	/* not exposed to the user */
    142  1.3     haad 	ZFS_PROP_STMF_SHAREINFO,	/* not exposed to the user */
    143  1.3     haad 	ZFS_PROP_DEFER_DESTROY,
    144  1.3     haad 	ZFS_PROP_USERREFS,
    145  1.3     haad 	ZFS_PROP_LOGBIAS,
    146  1.3     haad 	ZFS_PROP_UNIQUE,		/* not exposed to the user */
    147  1.3     haad 	ZFS_PROP_OBJSETID,		/* not exposed to the user */
    148  1.3     haad 	ZFS_PROP_DEDUP,
    149  1.3     haad 	ZFS_PROP_MLSLABEL,
    150  1.5      chs 	ZFS_PROP_SYNC,
    151  1.5      chs 	ZFS_PROP_REFRATIO,
    152  1.5      chs 	ZFS_PROP_WRITTEN,
    153  1.5      chs 	ZFS_PROP_CLONES,
    154  1.5      chs 	ZFS_PROP_LOGICALUSED,
    155  1.5      chs 	ZFS_PROP_LOGICALREFERENCED,
    156  1.5      chs 	ZFS_PROP_INCONSISTENT,		/* not exposed to the user */
    157  1.5      chs 	ZFS_PROP_VOLMODE,
    158  1.5      chs 	ZFS_PROP_FILESYSTEM_LIMIT,
    159  1.5      chs 	ZFS_PROP_SNAPSHOT_LIMIT,
    160  1.5      chs 	ZFS_PROP_FILESYSTEM_COUNT,
    161  1.5      chs 	ZFS_PROP_SNAPSHOT_COUNT,
    162  1.5      chs 	ZFS_PROP_REDUNDANT_METADATA,
    163  1.5      chs 	ZFS_PROP_PREV_SNAP,
    164  1.5      chs 	ZFS_PROP_RECEIVE_RESUME_TOKEN,
    165  1.1     haad 	ZFS_NUM_PROPS
    166  1.1     haad } zfs_prop_t;
    167  1.1     haad 
    168  1.3     haad typedef enum {
    169  1.3     haad 	ZFS_PROP_USERUSED,
    170  1.3     haad 	ZFS_PROP_USERQUOTA,
    171  1.3     haad 	ZFS_PROP_GROUPUSED,
    172  1.3     haad 	ZFS_PROP_GROUPQUOTA,
    173  1.3     haad 	ZFS_NUM_USERQUOTA_PROPS
    174  1.3     haad } zfs_userquota_prop_t;
    175  1.3     haad 
    176  1.3     haad extern const char *zfs_userquota_prop_prefixes[ZFS_NUM_USERQUOTA_PROPS];
    177  1.3     haad 
    178  1.1     haad /*
    179  1.1     haad  * Pool properties are identified by these constants and must be added to the
    180  1.1     haad  * end of this list to ensure that external consumers are not affected
    181  1.1     haad  * by the change. If you make any changes to this list, be sure to update
    182  1.1     haad  * the property table in usr/src/common/zfs/zpool_prop.c.
    183  1.1     haad  */
    184  1.1     haad typedef enum {
    185  1.1     haad 	ZPOOL_PROP_NAME,
    186  1.1     haad 	ZPOOL_PROP_SIZE,
    187  1.1     haad 	ZPOOL_PROP_CAPACITY,
    188  1.1     haad 	ZPOOL_PROP_ALTROOT,
    189  1.1     haad 	ZPOOL_PROP_HEALTH,
    190  1.1     haad 	ZPOOL_PROP_GUID,
    191  1.1     haad 	ZPOOL_PROP_VERSION,
    192  1.1     haad 	ZPOOL_PROP_BOOTFS,
    193  1.1     haad 	ZPOOL_PROP_DELEGATION,
    194  1.1     haad 	ZPOOL_PROP_AUTOREPLACE,
    195  1.1     haad 	ZPOOL_PROP_CACHEFILE,
    196  1.1     haad 	ZPOOL_PROP_FAILUREMODE,
    197  1.1     haad 	ZPOOL_PROP_LISTSNAPS,
    198  1.3     haad 	ZPOOL_PROP_AUTOEXPAND,
    199  1.3     haad 	ZPOOL_PROP_DEDUPDITTO,
    200  1.3     haad 	ZPOOL_PROP_DEDUPRATIO,
    201  1.3     haad 	ZPOOL_PROP_FREE,
    202  1.3     haad 	ZPOOL_PROP_ALLOCATED,
    203  1.5      chs 	ZPOOL_PROP_READONLY,
    204  1.5      chs 	ZPOOL_PROP_COMMENT,
    205  1.5      chs 	ZPOOL_PROP_EXPANDSZ,
    206  1.5      chs 	ZPOOL_PROP_FREEING,
    207  1.5      chs 	ZPOOL_PROP_FRAGMENTATION,
    208  1.5      chs 	ZPOOL_PROP_LEAKED,
    209  1.5      chs 	ZPOOL_PROP_MAXBLOCKSIZE,
    210  1.1     haad 	ZPOOL_NUM_PROPS
    211  1.1     haad } zpool_prop_t;
    212  1.1     haad 
    213  1.5      chs /* Small enough to not hog a whole line of printout in zpool(1M). */
    214  1.5      chs #define	ZPROP_MAX_COMMENT	32
    215  1.5      chs 
    216  1.1     haad #define	ZPROP_CONT		-2
    217  1.1     haad #define	ZPROP_INVAL		-1
    218  1.1     haad 
    219  1.1     haad #define	ZPROP_VALUE		"value"
    220  1.1     haad #define	ZPROP_SOURCE		"source"
    221  1.1     haad 
    222  1.1     haad typedef enum {
    223  1.1     haad 	ZPROP_SRC_NONE = 0x1,
    224  1.1     haad 	ZPROP_SRC_DEFAULT = 0x2,
    225  1.1     haad 	ZPROP_SRC_TEMPORARY = 0x4,
    226  1.1     haad 	ZPROP_SRC_LOCAL = 0x8,
    227  1.3     haad 	ZPROP_SRC_INHERITED = 0x10,
    228  1.3     haad 	ZPROP_SRC_RECEIVED = 0x20
    229  1.1     haad } zprop_source_t;
    230  1.1     haad 
    231  1.3     haad #define	ZPROP_SRC_ALL	0x3f
    232  1.3     haad 
    233  1.3     haad #define	ZPROP_SOURCE_VAL_RECVD	"$recvd"
    234  1.3     haad #define	ZPROP_N_MORE_ERRORS	"N_MORE_ERRORS"
    235  1.3     haad /*
    236  1.3     haad  * Dataset flag implemented as a special entry in the props zap object
    237  1.3     haad  * indicating that the dataset has received properties on or after
    238  1.3     haad  * SPA_VERSION_RECVD_PROPS. The first such receive blows away local properties
    239  1.3     haad  * just as it did in earlier versions, and thereafter, local properties are
    240  1.3     haad  * preserved.
    241  1.3     haad  */
    242  1.3     haad #define	ZPROP_HAS_RECVD		"$hasrecvd"
    243  1.3     haad 
    244  1.3     haad typedef enum {
    245  1.3     haad 	ZPROP_ERR_NOCLEAR = 0x1, /* failure to clear existing props */
    246  1.3     haad 	ZPROP_ERR_NORESTORE = 0x2 /* failure to restore props on error */
    247  1.3     haad } zprop_errflags_t;
    248  1.1     haad 
    249  1.1     haad typedef int (*zprop_func)(int, void *);
    250  1.1     haad 
    251  1.1     haad /*
    252  1.1     haad  * Properties to be set on the root file system of a new pool
    253  1.1     haad  * are stuffed into their own nvlist, which is then included in
    254  1.1     haad  * the properties nvlist with the pool properties.
    255  1.1     haad  */
    256  1.1     haad #define	ZPOOL_ROOTFS_PROPS	"root-props-nvl"
    257  1.1     haad 
    258  1.1     haad /*
    259  1.1     haad  * Dataset property functions shared between libzfs and kernel.
    260  1.1     haad  */
    261  1.1     haad const char *zfs_prop_default_string(zfs_prop_t);
    262  1.1     haad uint64_t zfs_prop_default_numeric(zfs_prop_t);
    263  1.1     haad boolean_t zfs_prop_readonly(zfs_prop_t);
    264  1.1     haad boolean_t zfs_prop_inheritable(zfs_prop_t);
    265  1.1     haad boolean_t zfs_prop_setonce(zfs_prop_t);
    266  1.1     haad const char *zfs_prop_to_name(zfs_prop_t);
    267  1.1     haad zfs_prop_t zfs_name_to_prop(const char *);
    268  1.1     haad boolean_t zfs_prop_user(const char *);
    269  1.3     haad boolean_t zfs_prop_userquota(const char *);
    270  1.1     haad int zfs_prop_index_to_string(zfs_prop_t, uint64_t, const char **);
    271  1.1     haad int zfs_prop_string_to_index(zfs_prop_t, const char *, uint64_t *);
    272  1.3     haad uint64_t zfs_prop_random_value(zfs_prop_t, uint64_t seed);
    273  1.1     haad boolean_t zfs_prop_valid_for_type(int, zfs_type_t);
    274  1.1     haad 
    275  1.1     haad /*
    276  1.1     haad  * Pool property functions shared between libzfs and kernel.
    277  1.1     haad  */
    278  1.1     haad zpool_prop_t zpool_name_to_prop(const char *);
    279  1.1     haad const char *zpool_prop_to_name(zpool_prop_t);
    280  1.1     haad const char *zpool_prop_default_string(zpool_prop_t);
    281  1.1     haad uint64_t zpool_prop_default_numeric(zpool_prop_t);
    282  1.1     haad boolean_t zpool_prop_readonly(zpool_prop_t);
    283  1.5      chs boolean_t zpool_prop_feature(const char *);
    284  1.5      chs boolean_t zpool_prop_unsupported(const char *name);
    285  1.1     haad int zpool_prop_index_to_string(zpool_prop_t, uint64_t, const char **);
    286  1.1     haad int zpool_prop_string_to_index(zpool_prop_t, const char *, uint64_t *);
    287  1.3     haad uint64_t zpool_prop_random_value(zpool_prop_t, uint64_t seed);
    288  1.1     haad 
    289  1.1     haad /*
    290  1.1     haad  * Definitions for the Delegation.
    291  1.1     haad  */
    292  1.1     haad typedef enum {
    293  1.1     haad 	ZFS_DELEG_WHO_UNKNOWN = 0,
    294  1.1     haad 	ZFS_DELEG_USER = 'u',
    295  1.1     haad 	ZFS_DELEG_USER_SETS = 'U',
    296  1.1     haad 	ZFS_DELEG_GROUP = 'g',
    297  1.1     haad 	ZFS_DELEG_GROUP_SETS = 'G',
    298  1.1     haad 	ZFS_DELEG_EVERYONE = 'e',
    299  1.1     haad 	ZFS_DELEG_EVERYONE_SETS = 'E',
    300  1.1     haad 	ZFS_DELEG_CREATE = 'c',
    301  1.1     haad 	ZFS_DELEG_CREATE_SETS = 'C',
    302  1.1     haad 	ZFS_DELEG_NAMED_SET = 's',
    303  1.1     haad 	ZFS_DELEG_NAMED_SET_SETS = 'S'
    304  1.1     haad } zfs_deleg_who_type_t;
    305  1.1     haad 
    306  1.1     haad typedef enum {
    307  1.1     haad 	ZFS_DELEG_NONE = 0,
    308  1.1     haad 	ZFS_DELEG_PERM_LOCAL = 1,
    309  1.1     haad 	ZFS_DELEG_PERM_DESCENDENT = 2,
    310  1.1     haad 	ZFS_DELEG_PERM_LOCALDESCENDENT = 3,
    311  1.1     haad 	ZFS_DELEG_PERM_CREATE = 4
    312  1.1     haad } zfs_deleg_inherit_t;
    313  1.1     haad 
    314  1.1     haad #define	ZFS_DELEG_PERM_UID	"uid"
    315  1.1     haad #define	ZFS_DELEG_PERM_GID	"gid"
    316  1.1     haad #define	ZFS_DELEG_PERM_GROUPS	"groups"
    317  1.1     haad 
    318  1.3     haad #define	ZFS_MLSLABEL_DEFAULT	"none"
    319  1.3     haad 
    320  1.3     haad #define	ZFS_SMB_ACL_SRC		"src"
    321  1.3     haad #define	ZFS_SMB_ACL_TARGET	"target"
    322  1.3     haad 
    323  1.1     haad typedef enum {
    324  1.1     haad 	ZFS_CANMOUNT_OFF = 0,
    325  1.1     haad 	ZFS_CANMOUNT_ON = 1,
    326  1.1     haad 	ZFS_CANMOUNT_NOAUTO = 2
    327  1.1     haad } zfs_canmount_type_t;
    328  1.1     haad 
    329  1.3     haad typedef enum {
    330  1.3     haad 	ZFS_LOGBIAS_LATENCY = 0,
    331  1.3     haad 	ZFS_LOGBIAS_THROUGHPUT = 1
    332  1.3     haad } zfs_logbias_op_t;
    333  1.3     haad 
    334  1.1     haad typedef enum zfs_share_op {
    335  1.1     haad 	ZFS_SHARE_NFS = 0,
    336  1.1     haad 	ZFS_UNSHARE_NFS = 1,
    337  1.1     haad 	ZFS_SHARE_SMB = 2,
    338  1.1     haad 	ZFS_UNSHARE_SMB = 3
    339  1.1     haad } zfs_share_op_t;
    340  1.1     haad 
    341  1.3     haad typedef enum zfs_smb_acl_op {
    342  1.3     haad 	ZFS_SMB_ACL_ADD,
    343  1.3     haad 	ZFS_SMB_ACL_REMOVE,
    344  1.3     haad 	ZFS_SMB_ACL_RENAME,
    345  1.3     haad 	ZFS_SMB_ACL_PURGE
    346  1.3     haad } zfs_smb_acl_op_t;
    347  1.3     haad 
    348  1.1     haad typedef enum zfs_cache_type {
    349  1.1     haad 	ZFS_CACHE_NONE = 0,
    350  1.1     haad 	ZFS_CACHE_METADATA = 1,
    351  1.1     haad 	ZFS_CACHE_ALL = 2
    352  1.1     haad } zfs_cache_type_t;
    353  1.1     haad 
    354  1.5      chs typedef enum {
    355  1.5      chs 	ZFS_SYNC_STANDARD = 0,
    356  1.5      chs 	ZFS_SYNC_ALWAYS = 1,
    357  1.5      chs 	ZFS_SYNC_DISABLED = 2
    358  1.5      chs } zfs_sync_type_t;
    359  1.5      chs 
    360  1.5      chs typedef enum {
    361  1.5      chs 	ZFS_VOLMODE_DEFAULT = 0,
    362  1.5      chs 	ZFS_VOLMODE_GEOM = 1,
    363  1.5      chs 	ZFS_VOLMODE_DEV = 2,
    364  1.5      chs 	ZFS_VOLMODE_NONE = 3
    365  1.5      chs } zfs_volmode_t;
    366  1.5      chs 
    367  1.5      chs typedef enum {
    368  1.5      chs 	ZFS_REDUNDANT_METADATA_ALL,
    369  1.5      chs 	ZFS_REDUNDANT_METADATA_MOST
    370  1.5      chs } zfs_redundant_metadata_type_t;
    371  1.1     haad 
    372  1.1     haad /*
    373  1.1     haad  * On-disk version number.
    374  1.1     haad  */
    375  1.1     haad #define	SPA_VERSION_1			1ULL
    376  1.1     haad #define	SPA_VERSION_2			2ULL
    377  1.1     haad #define	SPA_VERSION_3			3ULL
    378  1.1     haad #define	SPA_VERSION_4			4ULL
    379  1.1     haad #define	SPA_VERSION_5			5ULL
    380  1.1     haad #define	SPA_VERSION_6			6ULL
    381  1.1     haad #define	SPA_VERSION_7			7ULL
    382  1.1     haad #define	SPA_VERSION_8			8ULL
    383  1.1     haad #define	SPA_VERSION_9			9ULL
    384  1.1     haad #define	SPA_VERSION_10			10ULL
    385  1.1     haad #define	SPA_VERSION_11			11ULL
    386  1.1     haad #define	SPA_VERSION_12			12ULL
    387  1.1     haad #define	SPA_VERSION_13			13ULL
    388  1.1     haad #define	SPA_VERSION_14			14ULL
    389  1.3     haad #define	SPA_VERSION_15			15ULL
    390  1.3     haad #define	SPA_VERSION_16			16ULL
    391  1.3     haad #define	SPA_VERSION_17			17ULL
    392  1.3     haad #define	SPA_VERSION_18			18ULL
    393  1.3     haad #define	SPA_VERSION_19			19ULL
    394  1.3     haad #define	SPA_VERSION_20			20ULL
    395  1.3     haad #define	SPA_VERSION_21			21ULL
    396  1.3     haad #define	SPA_VERSION_22			22ULL
    397  1.3     haad #define	SPA_VERSION_23			23ULL
    398  1.5      chs #define	SPA_VERSION_24			24ULL
    399  1.5      chs #define	SPA_VERSION_25			25ULL
    400  1.5      chs #define	SPA_VERSION_26			26ULL
    401  1.5      chs #define	SPA_VERSION_27			27ULL
    402  1.5      chs #define	SPA_VERSION_28			28ULL
    403  1.5      chs #define	SPA_VERSION_5000		5000ULL
    404  1.5      chs 
    405  1.1     haad /*
    406  1.1     haad  * When bumping up SPA_VERSION, make sure GRUB ZFS understands the on-disk
    407  1.3     haad  * format change. Go to usr/src/grub/grub-0.97/stage2/{zfs-include/, fsys_zfs*},
    408  1.3     haad  * and do the appropriate changes.  Also bump the version number in
    409  1.3     haad  * usr/src/grub/capability.
    410  1.1     haad  */
    411  1.5      chs #define	SPA_VERSION			SPA_VERSION_5000
    412  1.5      chs #define	SPA_VERSION_STRING		"5000"
    413  1.1     haad 
    414  1.1     haad /*
    415  1.1     haad  * Symbolic names for the changes that caused a SPA_VERSION switch.
    416  1.1     haad  * Used in the code when checking for presence or absence of a feature.
    417  1.1     haad  * Feel free to define multiple symbolic names for each version if there
    418  1.1     haad  * were multiple changes to on-disk structures during that version.
    419  1.1     haad  *
    420  1.1     haad  * NOTE: When checking the current SPA_VERSION in your code, be sure
    421  1.1     haad  *       to use spa_version() since it reports the version of the
    422  1.1     haad  *       last synced uberblock.  Checking the in-flight version can
    423  1.1     haad  *       be dangerous in some cases.
    424  1.1     haad  */
    425  1.1     haad #define	SPA_VERSION_INITIAL		SPA_VERSION_1
    426  1.1     haad #define	SPA_VERSION_DITTO_BLOCKS	SPA_VERSION_2
    427  1.1     haad #define	SPA_VERSION_SPARES		SPA_VERSION_3
    428  1.3     haad #define	SPA_VERSION_RAIDZ2		SPA_VERSION_3
    429  1.5      chs #define	SPA_VERSION_BPOBJ_ACCOUNT	SPA_VERSION_3
    430  1.1     haad #define	SPA_VERSION_RAIDZ_DEFLATE	SPA_VERSION_3
    431  1.1     haad #define	SPA_VERSION_DNODE_BYTES		SPA_VERSION_3
    432  1.1     haad #define	SPA_VERSION_ZPOOL_HISTORY	SPA_VERSION_4
    433  1.1     haad #define	SPA_VERSION_GZIP_COMPRESSION	SPA_VERSION_5
    434  1.1     haad #define	SPA_VERSION_BOOTFS		SPA_VERSION_6
    435  1.1     haad #define	SPA_VERSION_SLOGS		SPA_VERSION_7
    436  1.1     haad #define	SPA_VERSION_DELEGATED_PERMS	SPA_VERSION_8
    437  1.1     haad #define	SPA_VERSION_FUID		SPA_VERSION_9
    438  1.1     haad #define	SPA_VERSION_REFRESERVATION	SPA_VERSION_9
    439  1.1     haad #define	SPA_VERSION_REFQUOTA		SPA_VERSION_9
    440  1.1     haad #define	SPA_VERSION_UNIQUE_ACCURATE	SPA_VERSION_9
    441  1.1     haad #define	SPA_VERSION_L2CACHE		SPA_VERSION_10
    442  1.1     haad #define	SPA_VERSION_NEXT_CLONES		SPA_VERSION_11
    443  1.1     haad #define	SPA_VERSION_ORIGIN		SPA_VERSION_11
    444  1.1     haad #define	SPA_VERSION_DSL_SCRUB		SPA_VERSION_11
    445  1.1     haad #define	SPA_VERSION_SNAP_PROPS		SPA_VERSION_12
    446  1.1     haad #define	SPA_VERSION_USED_BREAKDOWN	SPA_VERSION_13
    447  1.1     haad #define	SPA_VERSION_PASSTHROUGH_X	SPA_VERSION_14
    448  1.3     haad #define	SPA_VERSION_USERSPACE		SPA_VERSION_15
    449  1.3     haad #define	SPA_VERSION_STMF_PROP		SPA_VERSION_16
    450  1.3     haad #define	SPA_VERSION_RAIDZ3		SPA_VERSION_17
    451  1.3     haad #define	SPA_VERSION_USERREFS		SPA_VERSION_18
    452  1.3     haad #define	SPA_VERSION_HOLES		SPA_VERSION_19
    453  1.3     haad #define	SPA_VERSION_ZLE_COMPRESSION	SPA_VERSION_20
    454  1.3     haad #define	SPA_VERSION_DEDUP		SPA_VERSION_21
    455  1.3     haad #define	SPA_VERSION_RECVD_PROPS		SPA_VERSION_22
    456  1.3     haad #define	SPA_VERSION_SLIM_ZIL		SPA_VERSION_23
    457  1.5      chs #define	SPA_VERSION_SA			SPA_VERSION_24
    458  1.5      chs #define	SPA_VERSION_SCAN		SPA_VERSION_25
    459  1.5      chs #define	SPA_VERSION_DIR_CLONES		SPA_VERSION_26
    460  1.5      chs #define	SPA_VERSION_DEADLISTS		SPA_VERSION_26
    461  1.5      chs #define	SPA_VERSION_FAST_SNAP		SPA_VERSION_27
    462  1.5      chs #define	SPA_VERSION_MULTI_REPLACE	SPA_VERSION_28
    463  1.5      chs #define	SPA_VERSION_BEFORE_FEATURES	SPA_VERSION_28
    464  1.5      chs #define	SPA_VERSION_FEATURES		SPA_VERSION_5000
    465  1.5      chs 
    466  1.5      chs #define	SPA_VERSION_IS_SUPPORTED(v) \
    467  1.5      chs 	(((v) >= SPA_VERSION_INITIAL && (v) <= SPA_VERSION_BEFORE_FEATURES) || \
    468  1.5      chs 	((v) >= SPA_VERSION_FEATURES && (v) <= SPA_VERSION))
    469  1.1     haad 
    470  1.1     haad /*
    471  1.1     haad  * ZPL version - rev'd whenever an incompatible on-disk format change
    472  1.1     haad  * occurs.  This is independent of SPA/DMU/ZAP versioning.  You must
    473  1.1     haad  * also update the version_table[] and help message in zfs_prop.c.
    474  1.1     haad  *
    475  1.1     haad  * When changing, be sure to teach GRUB how to read the new format!
    476  1.3     haad  * See usr/src/grub/grub-0.97/stage2/{zfs-include/,fsys_zfs*}
    477  1.1     haad  */
    478  1.1     haad #define	ZPL_VERSION_1			1ULL
    479  1.1     haad #define	ZPL_VERSION_2			2ULL
    480  1.1     haad #define	ZPL_VERSION_3			3ULL
    481  1.3     haad #define	ZPL_VERSION_4			4ULL
    482  1.5      chs #define	ZPL_VERSION_5			5ULL
    483  1.5      chs #define	ZPL_VERSION			ZPL_VERSION_5
    484  1.5      chs #define	ZPL_VERSION_STRING		"5"
    485  1.1     haad 
    486  1.1     haad #define	ZPL_VERSION_INITIAL		ZPL_VERSION_1
    487  1.1     haad #define	ZPL_VERSION_DIRENT_TYPE		ZPL_VERSION_2
    488  1.1     haad #define	ZPL_VERSION_FUID		ZPL_VERSION_3
    489  1.1     haad #define	ZPL_VERSION_NORMALIZATION	ZPL_VERSION_3
    490  1.1     haad #define	ZPL_VERSION_SYSATTR		ZPL_VERSION_3
    491  1.3     haad #define	ZPL_VERSION_USERSPACE		ZPL_VERSION_4
    492  1.5      chs #define	ZPL_VERSION_SA			ZPL_VERSION_5
    493  1.3     haad 
    494  1.3     haad /* Rewind request information */
    495  1.3     haad #define	ZPOOL_NO_REWIND		1  /* No policy - default behavior */
    496  1.3     haad #define	ZPOOL_NEVER_REWIND	2  /* Do not search for best txg or rewind */
    497  1.3     haad #define	ZPOOL_TRY_REWIND	4  /* Search for best txg, but do not rewind */
    498  1.3     haad #define	ZPOOL_DO_REWIND		8  /* Rewind to best txg w/in deferred frees */
    499  1.3     haad #define	ZPOOL_EXTREME_REWIND	16 /* Allow extreme measures to find best txg */
    500  1.3     haad #define	ZPOOL_REWIND_MASK	28 /* All the possible rewind bits */
    501  1.3     haad #define	ZPOOL_REWIND_POLICIES	31 /* All the possible policy bits */
    502  1.3     haad 
    503  1.3     haad typedef struct zpool_rewind_policy {
    504  1.3     haad 	uint32_t	zrp_request;	/* rewind behavior requested */
    505  1.3     haad 	uint64_t	zrp_maxmeta;	/* max acceptable meta-data errors */
    506  1.3     haad 	uint64_t	zrp_maxdata;	/* max acceptable data errors */
    507  1.3     haad 	uint64_t	zrp_txg;	/* specific txg to load */
    508  1.3     haad } zpool_rewind_policy_t;
    509  1.1     haad 
    510  1.1     haad /*
    511  1.1     haad  * The following are configuration names used in the nvlist describing a pool's
    512  1.1     haad  * configuration.
    513  1.1     haad  */
    514  1.1     haad #define	ZPOOL_CONFIG_VERSION		"version"
    515  1.1     haad #define	ZPOOL_CONFIG_POOL_NAME		"name"
    516  1.1     haad #define	ZPOOL_CONFIG_POOL_STATE		"state"
    517  1.1     haad #define	ZPOOL_CONFIG_POOL_TXG		"txg"
    518  1.1     haad #define	ZPOOL_CONFIG_POOL_GUID		"pool_guid"
    519  1.1     haad #define	ZPOOL_CONFIG_CREATE_TXG		"create_txg"
    520  1.1     haad #define	ZPOOL_CONFIG_TOP_GUID		"top_guid"
    521  1.1     haad #define	ZPOOL_CONFIG_VDEV_TREE		"vdev_tree"
    522  1.1     haad #define	ZPOOL_CONFIG_TYPE		"type"
    523  1.1     haad #define	ZPOOL_CONFIG_CHILDREN		"children"
    524  1.1     haad #define	ZPOOL_CONFIG_ID			"id"
    525  1.1     haad #define	ZPOOL_CONFIG_GUID		"guid"
    526  1.1     haad #define	ZPOOL_CONFIG_PATH		"path"
    527  1.1     haad #define	ZPOOL_CONFIG_DEVID		"devid"
    528  1.1     haad #define	ZPOOL_CONFIG_METASLAB_ARRAY	"metaslab_array"
    529  1.1     haad #define	ZPOOL_CONFIG_METASLAB_SHIFT	"metaslab_shift"
    530  1.1     haad #define	ZPOOL_CONFIG_ASHIFT		"ashift"
    531  1.1     haad #define	ZPOOL_CONFIG_ASIZE		"asize"
    532  1.1     haad #define	ZPOOL_CONFIG_DTL		"DTL"
    533  1.5      chs #define	ZPOOL_CONFIG_SCAN_STATS		"scan_stats"	/* not stored on disk */
    534  1.5      chs #define	ZPOOL_CONFIG_VDEV_STATS		"vdev_stats"	/* not stored on disk */
    535  1.1     haad #define	ZPOOL_CONFIG_WHOLE_DISK		"whole_disk"
    536  1.1     haad #define	ZPOOL_CONFIG_ERRCOUNT		"error_count"
    537  1.1     haad #define	ZPOOL_CONFIG_NOT_PRESENT	"not_present"
    538  1.1     haad #define	ZPOOL_CONFIG_SPARES		"spares"
    539  1.1     haad #define	ZPOOL_CONFIG_IS_SPARE		"is_spare"
    540  1.1     haad #define	ZPOOL_CONFIG_NPARITY		"nparity"
    541  1.1     haad #define	ZPOOL_CONFIG_HOSTID		"hostid"
    542  1.1     haad #define	ZPOOL_CONFIG_HOSTNAME		"hostname"
    543  1.5      chs #define	ZPOOL_CONFIG_LOADED_TIME	"initial_load_time"
    544  1.1     haad #define	ZPOOL_CONFIG_UNSPARE		"unspare"
    545  1.1     haad #define	ZPOOL_CONFIG_PHYS_PATH		"phys_path"
    546  1.1     haad #define	ZPOOL_CONFIG_IS_LOG		"is_log"
    547  1.1     haad #define	ZPOOL_CONFIG_L2CACHE		"l2cache"
    548  1.3     haad #define	ZPOOL_CONFIG_HOLE_ARRAY		"hole_array"
    549  1.3     haad #define	ZPOOL_CONFIG_VDEV_CHILDREN	"vdev_children"
    550  1.3     haad #define	ZPOOL_CONFIG_IS_HOLE		"is_hole"
    551  1.3     haad #define	ZPOOL_CONFIG_DDT_HISTOGRAM	"ddt_histogram"
    552  1.3     haad #define	ZPOOL_CONFIG_DDT_OBJ_STATS	"ddt_object_stats"
    553  1.3     haad #define	ZPOOL_CONFIG_DDT_STATS		"ddt_stats"
    554  1.3     haad #define	ZPOOL_CONFIG_SPLIT		"splitcfg"
    555  1.3     haad #define	ZPOOL_CONFIG_ORIG_GUID		"orig_guid"
    556  1.3     haad #define	ZPOOL_CONFIG_SPLIT_GUID		"split_guid"
    557  1.3     haad #define	ZPOOL_CONFIG_SPLIT_LIST		"guid_list"
    558  1.5      chs #define	ZPOOL_CONFIG_REMOVING		"removing"
    559  1.5      chs #define	ZPOOL_CONFIG_RESILVER_TXG	"resilver_txg"
    560  1.5      chs #define	ZPOOL_CONFIG_COMMENT		"comment"
    561  1.1     haad #define	ZPOOL_CONFIG_SUSPENDED		"suspended"	/* not stored on disk */
    562  1.1     haad #define	ZPOOL_CONFIG_TIMESTAMP		"timestamp"	/* not stored on disk */
    563  1.1     haad #define	ZPOOL_CONFIG_BOOTFS		"bootfs"	/* not stored on disk */
    564  1.5      chs #define	ZPOOL_CONFIG_MISSING_DEVICES	"missing_vdevs"	/* not stored on disk */
    565  1.5      chs #define	ZPOOL_CONFIG_LOAD_INFO		"load_info"	/* not stored on disk */
    566  1.5      chs #define	ZPOOL_CONFIG_REWIND_INFO	"rewind_info"	/* not stored on disk */
    567  1.5      chs #define	ZPOOL_CONFIG_UNSUP_FEAT		"unsup_feat"	/* not stored on disk */
    568  1.5      chs #define	ZPOOL_CONFIG_ENABLED_FEAT	"enabled_feat"	/* not stored on disk */
    569  1.5      chs #define	ZPOOL_CONFIG_CAN_RDONLY		"can_rdonly"	/* not stored on disk */
    570  1.5      chs #define	ZPOOL_CONFIG_FEATURES_FOR_READ	"features_for_read"
    571  1.5      chs #define	ZPOOL_CONFIG_FEATURE_STATS	"feature_stats"	/* not stored on disk */
    572  1.5      chs #define	ZPOOL_CONFIG_VDEV_TOP_ZAP	"com.delphix:vdev_zap_top"
    573  1.5      chs #define	ZPOOL_CONFIG_VDEV_LEAF_ZAP	"com.delphix:vdev_zap_leaf"
    574  1.5      chs #define	ZPOOL_CONFIG_HAS_PER_VDEV_ZAPS	"com.delphix:has_per_vdev_zaps"
    575  1.1     haad /*
    576  1.1     haad  * The persistent vdev state is stored as separate values rather than a single
    577  1.1     haad  * 'vdev_state' entry.  This is because a device can be in multiple states, such
    578  1.1     haad  * as offline and degraded.
    579  1.1     haad  */
    580  1.1     haad #define	ZPOOL_CONFIG_OFFLINE		"offline"
    581  1.1     haad #define	ZPOOL_CONFIG_FAULTED		"faulted"
    582  1.1     haad #define	ZPOOL_CONFIG_DEGRADED		"degraded"
    583  1.1     haad #define	ZPOOL_CONFIG_REMOVED		"removed"
    584  1.3     haad #define	ZPOOL_CONFIG_FRU		"fru"
    585  1.3     haad #define	ZPOOL_CONFIG_AUX_STATE		"aux_state"
    586  1.3     haad 
    587  1.3     haad /* Rewind policy parameters */
    588  1.3     haad #define	ZPOOL_REWIND_POLICY		"rewind-policy"
    589  1.3     haad #define	ZPOOL_REWIND_REQUEST		"rewind-request"
    590  1.3     haad #define	ZPOOL_REWIND_REQUEST_TXG	"rewind-request-txg"
    591  1.3     haad #define	ZPOOL_REWIND_META_THRESH	"rewind-meta-thresh"
    592  1.3     haad #define	ZPOOL_REWIND_DATA_THRESH	"rewind-data-thresh"
    593  1.3     haad 
    594  1.3     haad /* Rewind data discovered */
    595  1.3     haad #define	ZPOOL_CONFIG_LOAD_TIME		"rewind_txg_ts"
    596  1.3     haad #define	ZPOOL_CONFIG_LOAD_DATA_ERRORS	"verify_data_errors"
    597  1.3     haad #define	ZPOOL_CONFIG_REWIND_TIME	"seconds_of_rewind"
    598  1.1     haad 
    599  1.1     haad #define	VDEV_TYPE_ROOT			"root"
    600  1.1     haad #define	VDEV_TYPE_MIRROR		"mirror"
    601  1.1     haad #define	VDEV_TYPE_REPLACING		"replacing"
    602  1.1     haad #define	VDEV_TYPE_RAIDZ			"raidz"
    603  1.1     haad #define	VDEV_TYPE_DISK			"disk"
    604  1.1     haad #define	VDEV_TYPE_FILE			"file"
    605  1.1     haad #define	VDEV_TYPE_MISSING		"missing"
    606  1.3     haad #define	VDEV_TYPE_HOLE			"hole"
    607  1.1     haad #define	VDEV_TYPE_SPARE			"spare"
    608  1.1     haad #define	VDEV_TYPE_LOG			"log"
    609  1.1     haad #define	VDEV_TYPE_L2CACHE		"l2cache"
    610  1.1     haad 
    611  1.1     haad /*
    612  1.1     haad  * This is needed in userland to report the minimum necessary device size.
    613  1.5      chs  *
    614  1.5      chs  * Note that the zfs test suite uses 64MB vdevs.
    615  1.1     haad  */
    616  1.1     haad #define	SPA_MINDEVSIZE		(64ULL << 20)
    617  1.1     haad 
    618  1.1     haad /*
    619  1.5      chs  * Set if the fragmentation has not yet been calculated. This can happen
    620  1.5      chs  * because the space maps have not been upgraded or the histogram feature
    621  1.5      chs  * is not enabled.
    622  1.5      chs  */
    623  1.5      chs #define	ZFS_FRAG_INVALID	UINT64_MAX
    624  1.5      chs 
    625  1.5      chs /*
    626  1.1     haad  * The location of the pool configuration repository, shared between kernel and
    627  1.1     haad  * userland.
    628  1.1     haad  */
    629  1.5      chs #ifdef __FreeBSD__
    630  1.5      chs #define	ZPOOL_CACHE		"/boot/zfs/zpool.cache"
    631  1.5      chs #endif
    632  1.5      chs #ifdef __NetBSD__
    633  1.6  hannken #define	ZPOOL_CACHE		"/etc/zfs/zpool.cache"
    634  1.5      chs #endif
    635  1.1     haad 
    636  1.1     haad /*
    637  1.1     haad  * vdev states are ordered from least to most healthy.
    638  1.1     haad  * A vdev that's CANT_OPEN or below is considered unusable.
    639  1.1     haad  */
    640  1.1     haad typedef enum vdev_state {
    641  1.1     haad 	VDEV_STATE_UNKNOWN = 0,	/* Uninitialized vdev			*/
    642  1.1     haad 	VDEV_STATE_CLOSED,	/* Not currently open			*/
    643  1.1     haad 	VDEV_STATE_OFFLINE,	/* Not allowed to open			*/
    644  1.1     haad 	VDEV_STATE_REMOVED,	/* Explicitly removed from system	*/
    645  1.1     haad 	VDEV_STATE_CANT_OPEN,	/* Tried to open, but failed		*/
    646  1.1     haad 	VDEV_STATE_FAULTED,	/* External request to fault device	*/
    647  1.1     haad 	VDEV_STATE_DEGRADED,	/* Replicated vdev with unhealthy kids	*/
    648  1.1     haad 	VDEV_STATE_HEALTHY	/* Presumed good			*/
    649  1.1     haad } vdev_state_t;
    650  1.1     haad 
    651  1.1     haad #define	VDEV_STATE_ONLINE	VDEV_STATE_HEALTHY
    652  1.1     haad 
    653  1.1     haad /*
    654  1.1     haad  * vdev aux states.  When a vdev is in the CANT_OPEN state, the aux field
    655  1.1     haad  * of the vdev stats structure uses these constants to distinguish why.
    656  1.1     haad  */
    657  1.1     haad typedef enum vdev_aux {
    658  1.1     haad 	VDEV_AUX_NONE,		/* no error				*/
    659  1.1     haad 	VDEV_AUX_OPEN_FAILED,	/* ldi_open_*() or vn_open() failed	*/
    660  1.1     haad 	VDEV_AUX_CORRUPT_DATA,	/* bad label or disk contents		*/
    661  1.1     haad 	VDEV_AUX_NO_REPLICAS,	/* insufficient number of replicas	*/
    662  1.1     haad 	VDEV_AUX_BAD_GUID_SUM,	/* vdev guid sum doesn't match		*/
    663  1.1     haad 	VDEV_AUX_TOO_SMALL,	/* vdev size is too small		*/
    664  1.1     haad 	VDEV_AUX_BAD_LABEL,	/* the label is OK but invalid		*/
    665  1.1     haad 	VDEV_AUX_VERSION_NEWER,	/* on-disk version is too new		*/
    666  1.1     haad 	VDEV_AUX_VERSION_OLDER,	/* on-disk version is too old		*/
    667  1.5      chs 	VDEV_AUX_UNSUP_FEAT,	/* unsupported features			*/
    668  1.1     haad 	VDEV_AUX_SPARED,	/* hot spare used in another pool	*/
    669  1.1     haad 	VDEV_AUX_ERR_EXCEEDED,	/* too many errors			*/
    670  1.1     haad 	VDEV_AUX_IO_FAILURE,	/* experienced I/O failure		*/
    671  1.3     haad 	VDEV_AUX_BAD_LOG,	/* cannot read log chain(s)		*/
    672  1.3     haad 	VDEV_AUX_EXTERNAL,	/* external diagnosis			*/
    673  1.5      chs 	VDEV_AUX_SPLIT_POOL,	/* vdev was split off into another pool	*/
    674  1.5      chs 	VDEV_AUX_ASHIFT_TOO_BIG /* vdev's min block size is too large   */
    675  1.1     haad } vdev_aux_t;
    676  1.1     haad 
    677  1.1     haad /*
    678  1.1     haad  * pool state.  The following states are written to disk as part of the normal
    679  1.1     haad  * SPA lifecycle: ACTIVE, EXPORTED, DESTROYED, SPARE, L2CACHE.  The remaining
    680  1.1     haad  * states are software abstractions used at various levels to communicate
    681  1.1     haad  * pool state.
    682  1.1     haad  */
    683  1.1     haad typedef enum pool_state {
    684  1.1     haad 	POOL_STATE_ACTIVE = 0,		/* In active use		*/
    685  1.1     haad 	POOL_STATE_EXPORTED,		/* Explicitly exported		*/
    686  1.1     haad 	POOL_STATE_DESTROYED,		/* Explicitly destroyed		*/
    687  1.1     haad 	POOL_STATE_SPARE,		/* Reserved for hot spare use	*/
    688  1.1     haad 	POOL_STATE_L2CACHE,		/* Level 2 ARC device		*/
    689  1.1     haad 	POOL_STATE_UNINITIALIZED,	/* Internal spa_t state		*/
    690  1.1     haad 	POOL_STATE_UNAVAIL,		/* Internal libzfs state	*/
    691  1.1     haad 	POOL_STATE_POTENTIALLY_ACTIVE	/* Internal libzfs state	*/
    692  1.1     haad } pool_state_t;
    693  1.1     haad 
    694  1.1     haad /*
    695  1.5      chs  * Scan Functions.
    696  1.1     haad  */
    697  1.5      chs typedef enum pool_scan_func {
    698  1.5      chs 	POOL_SCAN_NONE,
    699  1.5      chs 	POOL_SCAN_SCRUB,
    700  1.5      chs 	POOL_SCAN_RESILVER,
    701  1.5      chs 	POOL_SCAN_FUNCS
    702  1.5      chs } pool_scan_func_t;
    703  1.1     haad 
    704  1.1     haad /*
    705  1.1     haad  * ZIO types.  Needed to interpret vdev statistics below.
    706  1.1     haad  */
    707  1.1     haad typedef enum zio_type {
    708  1.1     haad 	ZIO_TYPE_NULL = 0,
    709  1.1     haad 	ZIO_TYPE_READ,
    710  1.1     haad 	ZIO_TYPE_WRITE,
    711  1.1     haad 	ZIO_TYPE_FREE,
    712  1.1     haad 	ZIO_TYPE_CLAIM,
    713  1.1     haad 	ZIO_TYPE_IOCTL,
    714  1.1     haad 	ZIO_TYPES
    715  1.1     haad } zio_type_t;
    716  1.1     haad 
    717  1.1     haad /*
    718  1.5      chs  * Pool statistics.  Note: all fields should be 64-bit because this
    719  1.5      chs  * is passed between kernel and userland as an nvlist uint64 array.
    720  1.5      chs  */
    721  1.5      chs typedef struct pool_scan_stat {
    722  1.5      chs 	/* values stored on disk */
    723  1.5      chs 	uint64_t	pss_func;	/* pool_scan_func_t */
    724  1.5      chs 	uint64_t	pss_state;	/* dsl_scan_state_t */
    725  1.5      chs 	uint64_t	pss_start_time;	/* scan start time */
    726  1.5      chs 	uint64_t	pss_end_time;	/* scan end time */
    727  1.5      chs 	uint64_t	pss_to_examine;	/* total bytes to scan */
    728  1.5      chs 	uint64_t	pss_examined;	/* total examined bytes	*/
    729  1.5      chs 	uint64_t	pss_to_process; /* total bytes to process */
    730  1.5      chs 	uint64_t	pss_processed;	/* total processed bytes */
    731  1.5      chs 	uint64_t	pss_errors;	/* scan errors	*/
    732  1.5      chs 
    733  1.5      chs 	/* values not stored on disk */
    734  1.5      chs 	uint64_t	pss_pass_exam;	/* examined bytes per scan pass */
    735  1.5      chs 	uint64_t	pss_pass_start;	/* start time of a scan pass */
    736  1.5      chs } pool_scan_stat_t;
    737  1.5      chs 
    738  1.5      chs typedef enum dsl_scan_state {
    739  1.5      chs 	DSS_NONE,
    740  1.5      chs 	DSS_SCANNING,
    741  1.5      chs 	DSS_FINISHED,
    742  1.5      chs 	DSS_CANCELED,
    743  1.5      chs 	DSS_NUM_STATES
    744  1.5      chs } dsl_scan_state_t;
    745  1.5      chs 
    746  1.5      chs 
    747  1.5      chs /*
    748  1.1     haad  * Vdev statistics.  Note: all fields should be 64-bit because this
    749  1.1     haad  * is passed between kernel and userland as an nvlist uint64 array.
    750  1.1     haad  */
    751  1.1     haad typedef struct vdev_stat {
    752  1.1     haad 	hrtime_t	vs_timestamp;		/* time since vdev load	*/
    753  1.1     haad 	uint64_t	vs_state;		/* vdev state		*/
    754  1.1     haad 	uint64_t	vs_aux;			/* see vdev_aux_t	*/
    755  1.1     haad 	uint64_t	vs_alloc;		/* space allocated	*/
    756  1.1     haad 	uint64_t	vs_space;		/* total capacity	*/
    757  1.1     haad 	uint64_t	vs_dspace;		/* deflated capacity	*/
    758  1.1     haad 	uint64_t	vs_rsize;		/* replaceable dev size */
    759  1.5      chs 	uint64_t	vs_esize;		/* expandable dev size */
    760  1.1     haad 	uint64_t	vs_ops[ZIO_TYPES];	/* operation count	*/
    761  1.1     haad 	uint64_t	vs_bytes[ZIO_TYPES];	/* bytes read/written	*/
    762  1.1     haad 	uint64_t	vs_read_errors;		/* read errors		*/
    763  1.1     haad 	uint64_t	vs_write_errors;	/* write errors		*/
    764  1.1     haad 	uint64_t	vs_checksum_errors;	/* checksum errors	*/
    765  1.1     haad 	uint64_t	vs_self_healed;		/* self-healed bytes	*/
    766  1.5      chs 	uint64_t	vs_scan_removing;	/* removing?	*/
    767  1.5      chs 	uint64_t	vs_scan_processed;	/* scan processed bytes	*/
    768  1.5      chs  	uint64_t	vs_configured_ashift;	/* TLV vdev_ashift      */
    769  1.5      chs  	uint64_t	vs_logical_ashift;	/* vdev_logical_ashift  */
    770  1.5      chs  	uint64_t	vs_physical_ashift;	/* vdev_physical_ashift */
    771  1.5      chs 	uint64_t	vs_fragmentation;	/* device fragmentation */
    772  1.1     haad } vdev_stat_t;
    773  1.5      chs #define VDEV_STAT_VALID(field, uint64_t_field_count) \
    774  1.5      chs     ((uint64_t_field_count * sizeof(uint64_t)) >= \
    775  1.5      chs      (offsetof(vdev_stat_t, field) + sizeof(((vdev_stat_t *)NULL)->field)))
    776  1.1     haad 
    777  1.3     haad /*
    778  1.3     haad  * DDT statistics.  Note: all fields should be 64-bit because this
    779  1.3     haad  * is passed between kernel and userland as an nvlist uint64 array.
    780  1.3     haad  */
    781  1.3     haad typedef struct ddt_object {
    782  1.3     haad 	uint64_t	ddo_count;	/* number of elments in ddt 	*/
    783  1.3     haad 	uint64_t	ddo_dspace;	/* size of ddt on disk		*/
    784  1.3     haad 	uint64_t	ddo_mspace;	/* size of ddt in-core		*/
    785  1.3     haad } ddt_object_t;
    786  1.3     haad 
    787  1.3     haad typedef struct ddt_stat {
    788  1.3     haad 	uint64_t	dds_blocks;	/* blocks			*/
    789  1.3     haad 	uint64_t	dds_lsize;	/* logical size			*/
    790  1.3     haad 	uint64_t	dds_psize;	/* physical size		*/
    791  1.3     haad 	uint64_t	dds_dsize;	/* deflated allocated size	*/
    792  1.3     haad 	uint64_t	dds_ref_blocks;	/* referenced blocks		*/
    793  1.3     haad 	uint64_t	dds_ref_lsize;	/* referenced lsize * refcnt	*/
    794  1.3     haad 	uint64_t	dds_ref_psize;	/* referenced psize * refcnt	*/
    795  1.3     haad 	uint64_t	dds_ref_dsize;	/* referenced dsize * refcnt	*/
    796  1.3     haad } ddt_stat_t;
    797  1.3     haad 
    798  1.3     haad typedef struct ddt_histogram {
    799  1.3     haad 	ddt_stat_t	ddh_stat[64];	/* power-of-two histogram buckets */
    800  1.3     haad } ddt_histogram_t;
    801  1.3     haad 
    802  1.1     haad #define	ZVOL_DRIVER	"zvol"
    803  1.1     haad #define	ZFS_DRIVER	"zfs"
    804  1.5      chs #define	ZFS_DEV_NAME	"zfs"
    805  1.5      chs #define	ZFS_DEV		"/dev/" ZFS_DEV_NAME
    806  1.5      chs #define	ZFS_DISK_ROOT	"/dev/dsk"
    807  1.5      chs #define	ZFS_DISK_ROOTD	ZFS_DISK_ROOT "/"
    808  1.5      chs #define	ZFS_RDISK_ROOT	"/dev/rdsk"
    809  1.5      chs #define	ZFS_RDISK_ROOTD	ZFS_RDISK_ROOT "/"
    810  1.1     haad 
    811  1.3     haad /* general zvol path */
    812  1.3     haad #define	ZVOL_DIR		"/dev/zvol"
    813  1.3     haad /* expansion */
    814  1.3     haad #define	ZVOL_PSEUDO_DEV		"/devices/pseudo/zfs@0:"
    815  1.3     haad /* for dump and swap */
    816  1.3     haad #define	ZVOL_FULL_DEV_DIR	ZVOL_DIR "/dsk/"
    817  1.3     haad #define	ZVOL_FULL_RDEV_DIR	ZVOL_DIR "/rdsk/"
    818  1.1     haad 
    819  1.1     haad #define	ZVOL_PROP_NAME		"name"
    820  1.3     haad #define	ZVOL_DEFAULT_BLOCKSIZE	8192
    821  1.1     haad 
    822  1.1     haad /*
    823  1.1     haad  * /dev/zfs ioctl numbers.
    824  1.1     haad  */
    825  1.1     haad typedef enum zfs_ioc {
    826  1.5      chs 	ZFS_IOC_FIRST =	0,
    827  1.5      chs 	ZFS_IOC_POOL_CREATE = ZFS_IOC_FIRST,
    828  1.1     haad 	ZFS_IOC_POOL_DESTROY,
    829  1.1     haad 	ZFS_IOC_POOL_IMPORT,
    830  1.1     haad 	ZFS_IOC_POOL_EXPORT,
    831  1.1     haad 	ZFS_IOC_POOL_CONFIGS,
    832  1.1     haad 	ZFS_IOC_POOL_STATS,
    833  1.1     haad 	ZFS_IOC_POOL_TRYIMPORT,
    834  1.5      chs 	ZFS_IOC_POOL_SCAN,
    835  1.1     haad 	ZFS_IOC_POOL_FREEZE,
    836  1.1     haad 	ZFS_IOC_POOL_UPGRADE,
    837  1.1     haad 	ZFS_IOC_POOL_GET_HISTORY,
    838  1.1     haad 	ZFS_IOC_VDEV_ADD,
    839  1.1     haad 	ZFS_IOC_VDEV_REMOVE,
    840  1.1     haad 	ZFS_IOC_VDEV_SET_STATE,
    841  1.1     haad 	ZFS_IOC_VDEV_ATTACH,
    842  1.1     haad 	ZFS_IOC_VDEV_DETACH,
    843  1.1     haad 	ZFS_IOC_VDEV_SETPATH,
    844  1.3     haad 	ZFS_IOC_VDEV_SETFRU,
    845  1.1     haad 	ZFS_IOC_OBJSET_STATS,
    846  1.1     haad 	ZFS_IOC_OBJSET_ZPLPROPS,
    847  1.1     haad 	ZFS_IOC_DATASET_LIST_NEXT,
    848  1.1     haad 	ZFS_IOC_SNAPSHOT_LIST_NEXT,
    849  1.1     haad 	ZFS_IOC_SET_PROP,
    850  1.1     haad 	ZFS_IOC_CREATE,
    851  1.1     haad 	ZFS_IOC_DESTROY,
    852  1.1     haad 	ZFS_IOC_ROLLBACK,
    853  1.1     haad 	ZFS_IOC_RENAME,
    854  1.1     haad 	ZFS_IOC_RECV,
    855  1.1     haad 	ZFS_IOC_SEND,
    856  1.1     haad 	ZFS_IOC_INJECT_FAULT,
    857  1.1     haad 	ZFS_IOC_CLEAR_FAULT,
    858  1.1     haad 	ZFS_IOC_INJECT_LIST_NEXT,
    859  1.1     haad 	ZFS_IOC_ERROR_LOG,
    860  1.1     haad 	ZFS_IOC_CLEAR,
    861  1.1     haad 	ZFS_IOC_PROMOTE,
    862  1.1     haad 	ZFS_IOC_DESTROY_SNAPS,
    863  1.1     haad 	ZFS_IOC_SNAPSHOT,
    864  1.1     haad 	ZFS_IOC_DSOBJ_TO_DSNAME,
    865  1.1     haad 	ZFS_IOC_OBJ_TO_PATH,
    866  1.1     haad 	ZFS_IOC_POOL_SET_PROPS,
    867  1.1     haad 	ZFS_IOC_POOL_GET_PROPS,
    868  1.1     haad 	ZFS_IOC_SET_FSACL,
    869  1.1     haad 	ZFS_IOC_GET_FSACL,
    870  1.1     haad 	ZFS_IOC_SHARE,
    871  1.3     haad 	ZFS_IOC_INHERIT_PROP,
    872  1.3     haad 	ZFS_IOC_SMB_ACL,
    873  1.3     haad 	ZFS_IOC_USERSPACE_ONE,
    874  1.3     haad 	ZFS_IOC_USERSPACE_MANY,
    875  1.3     haad 	ZFS_IOC_USERSPACE_UPGRADE,
    876  1.3     haad 	ZFS_IOC_HOLD,
    877  1.3     haad 	ZFS_IOC_RELEASE,
    878  1.3     haad 	ZFS_IOC_GET_HOLDS,
    879  1.3     haad 	ZFS_IOC_OBJSET_RECVD_PROPS,
    880  1.5      chs 	ZFS_IOC_VDEV_SPLIT,
    881  1.5      chs 	ZFS_IOC_NEXT_OBJ,
    882  1.5      chs 	ZFS_IOC_DIFF,
    883  1.5      chs 	ZFS_IOC_TMP_SNAPSHOT,
    884  1.5      chs 	ZFS_IOC_OBJ_TO_STATS,
    885  1.5      chs 	ZFS_IOC_JAIL,
    886  1.5      chs 	ZFS_IOC_UNJAIL,
    887  1.5      chs 	ZFS_IOC_POOL_REGUID,
    888  1.5      chs 	ZFS_IOC_SPACE_WRITTEN,
    889  1.5      chs 	ZFS_IOC_SPACE_SNAPS,
    890  1.5      chs 	ZFS_IOC_SEND_PROGRESS,
    891  1.5      chs 	ZFS_IOC_POOL_REOPEN,
    892  1.5      chs 	ZFS_IOC_LOG_HISTORY,
    893  1.5      chs 	ZFS_IOC_SEND_NEW,
    894  1.5      chs 	ZFS_IOC_SEND_SPACE,
    895  1.5      chs 	ZFS_IOC_CLONE,
    896  1.5      chs 	ZFS_IOC_BOOKMARK,
    897  1.5      chs 	ZFS_IOC_GET_BOOKMARKS,
    898  1.5      chs 	ZFS_IOC_DESTROY_BOOKMARKS,
    899  1.5      chs 	ZFS_IOC_NEXTBOOT,
    900  1.5      chs 	ZFS_IOC_LAST
    901  1.1     haad } zfs_ioc_t;
    902  1.1     haad 
    903  1.1     haad /*
    904  1.1     haad  * Internal SPA load state.  Used by FMA diagnosis engine.
    905  1.1     haad  */
    906  1.1     haad typedef enum {
    907  1.3     haad 	SPA_LOAD_NONE,		/* no load in progress	*/
    908  1.3     haad 	SPA_LOAD_OPEN,		/* normal open		*/
    909  1.3     haad 	SPA_LOAD_IMPORT,	/* import in progress	*/
    910  1.3     haad 	SPA_LOAD_TRYIMPORT,	/* tryimport in progress */
    911  1.3     haad 	SPA_LOAD_RECOVER,	/* recovery requested	*/
    912  1.5      chs 	SPA_LOAD_ERROR,		/* load failed		*/
    913  1.5      chs 	SPA_LOAD_CREATE		/* creation in progress */
    914  1.1     haad } spa_load_state_t;
    915  1.1     haad 
    916  1.1     haad /*
    917  1.1     haad  * Bookmark name values.
    918  1.1     haad  */
    919  1.1     haad #define	ZPOOL_ERR_LIST		"error list"
    920  1.1     haad #define	ZPOOL_ERR_DATASET	"dataset"
    921  1.1     haad #define	ZPOOL_ERR_OBJECT	"object"
    922  1.1     haad 
    923  1.1     haad #define	HIS_MAX_RECORD_LEN	(MAXPATHLEN + MAXPATHLEN + 1)
    924  1.1     haad 
    925  1.1     haad /*
    926  1.1     haad  * The following are names used in the nvlist describing
    927  1.1     haad  * the pool's history log.
    928  1.1     haad  */
    929  1.1     haad #define	ZPOOL_HIST_RECORD	"history record"
    930  1.1     haad #define	ZPOOL_HIST_TIME		"history time"
    931  1.1     haad #define	ZPOOL_HIST_CMD		"history command"
    932  1.1     haad #define	ZPOOL_HIST_WHO		"history who"
    933  1.1     haad #define	ZPOOL_HIST_ZONE		"history zone"
    934  1.1     haad #define	ZPOOL_HIST_HOST		"history hostname"
    935  1.1     haad #define	ZPOOL_HIST_TXG		"history txg"
    936  1.1     haad #define	ZPOOL_HIST_INT_EVENT	"history internal event"
    937  1.1     haad #define	ZPOOL_HIST_INT_STR	"history internal str"
    938  1.5      chs #define	ZPOOL_HIST_INT_NAME	"internal_name"
    939  1.5      chs #define	ZPOOL_HIST_IOCTL	"ioctl"
    940  1.5      chs #define	ZPOOL_HIST_INPUT_NVL	"in_nvl"
    941  1.5      chs #define	ZPOOL_HIST_OUTPUT_NVL	"out_nvl"
    942  1.5      chs #define	ZPOOL_HIST_DSNAME	"dsname"
    943  1.5      chs #define	ZPOOL_HIST_DSID		"dsid"
    944  1.1     haad 
    945  1.1     haad /*
    946  1.1     haad  * Flags for ZFS_IOC_VDEV_SET_STATE
    947  1.1     haad  */
    948  1.1     haad #define	ZFS_ONLINE_CHECKREMOVE	0x1
    949  1.1     haad #define	ZFS_ONLINE_UNSPARE	0x2
    950  1.1     haad #define	ZFS_ONLINE_FORCEFAULT	0x4
    951  1.3     haad #define	ZFS_ONLINE_EXPAND	0x8
    952  1.1     haad #define	ZFS_OFFLINE_TEMPORARY	0x1
    953  1.1     haad 
    954  1.1     haad /*
    955  1.5      chs  * Flags for ZFS_IOC_POOL_IMPORT
    956  1.5      chs  */
    957  1.5      chs #define	ZFS_IMPORT_NORMAL	0x0
    958  1.5      chs #define	ZFS_IMPORT_VERBATIM	0x1
    959  1.5      chs #define	ZFS_IMPORT_ANY_HOST	0x2
    960  1.5      chs #define	ZFS_IMPORT_MISSING_LOG	0x4
    961  1.5      chs #define	ZFS_IMPORT_ONLY		0x8
    962  1.5      chs 
    963  1.5      chs /*
    964  1.1     haad  * Sysevent payload members.  ZFS will generate the following sysevents with the
    965  1.1     haad  * given payloads:
    966  1.1     haad  *
    967  1.1     haad  *	ESC_ZFS_RESILVER_START
    968  1.1     haad  *	ESC_ZFS_RESILVER_END
    969  1.1     haad  *	ESC_ZFS_POOL_DESTROY
    970  1.5      chs  *	ESC_ZFS_POOL_REGUID
    971  1.1     haad  *
    972  1.1     haad  *		ZFS_EV_POOL_NAME	DATA_TYPE_STRING
    973  1.1     haad  *		ZFS_EV_POOL_GUID	DATA_TYPE_UINT64
    974  1.1     haad  *
    975  1.1     haad  *	ESC_ZFS_VDEV_REMOVE
    976  1.1     haad  *	ESC_ZFS_VDEV_CLEAR
    977  1.1     haad  *	ESC_ZFS_VDEV_CHECK
    978  1.1     haad  *
    979  1.1     haad  *		ZFS_EV_POOL_NAME	DATA_TYPE_STRING
    980  1.1     haad  *		ZFS_EV_POOL_GUID	DATA_TYPE_UINT64
    981  1.1     haad  *		ZFS_EV_VDEV_PATH	DATA_TYPE_STRING	(optional)
    982  1.1     haad  *		ZFS_EV_VDEV_GUID	DATA_TYPE_UINT64
    983  1.1     haad  */
    984  1.1     haad #define	ZFS_EV_POOL_NAME	"pool_name"
    985  1.1     haad #define	ZFS_EV_POOL_GUID	"pool_guid"
    986  1.1     haad #define	ZFS_EV_VDEV_PATH	"vdev_path"
    987  1.1     haad #define	ZFS_EV_VDEV_GUID	"vdev_guid"
    988  1.1     haad 
    989  1.1     haad #ifdef	__cplusplus
    990  1.1     haad }
    991  1.1     haad #endif
    992  1.1     haad 
    993  1.1     haad #endif	/* _SYS_FS_ZFS_H */
    994