1 /* 2 * GRUB -- GRand Unified Bootloader 3 * Copyright (C) 1999,2000,2001,2002,2003,2004 Free Software Foundation, Inc. 4 * 5 * This program is free software; you can redistribute it and/or modify 6 * it under the terms of the GNU General Public License as published by 7 * the Free Software Foundation; either version 2 of the License, or 8 * (at your option) any later version. 9 * 10 * This program is distributed in the hope that it will be useful, 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 * GNU General Public License for more details. 14 * 15 * You should have received a copy of the GNU General Public License 16 * along with this program; if not, write to the Free Software 17 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 18 */ 19 /* 20 * Copyright 2009 Sun Microsystems, Inc. All rights reserved. 21 * Use is subject to license terms. 22 */ 23 24 #ifndef _SYS_FS_ZFS_H 25 #define _SYS_FS_ZFS_H 26 27 /* 28 * On-disk version number. 29 */ 30 #define SPA_VERSION 15ULL 31 32 /* 33 * The following are configuration names used in the nvlist describing a pool's 34 * configuration. 35 */ 36 #define ZPOOL_CONFIG_VERSION "version" 37 #define ZPOOL_CONFIG_POOL_NAME "name" 38 #define ZPOOL_CONFIG_POOL_STATE "state" 39 #define ZPOOL_CONFIG_POOL_TXG "txg" 40 #define ZPOOL_CONFIG_POOL_GUID "pool_guid" 41 #define ZPOOL_CONFIG_CREATE_TXG "create_txg" 42 #define ZPOOL_CONFIG_TOP_GUID "top_guid" 43 #define ZPOOL_CONFIG_VDEV_TREE "vdev_tree" 44 #define ZPOOL_CONFIG_TYPE "type" 45 #define ZPOOL_CONFIG_CHILDREN "children" 46 #define ZPOOL_CONFIG_ID "id" 47 #define ZPOOL_CONFIG_GUID "guid" 48 #define ZPOOL_CONFIG_PATH "path" 49 #define ZPOOL_CONFIG_DEVID "devid" 50 #define ZPOOL_CONFIG_METASLAB_ARRAY "metaslab_array" 51 #define ZPOOL_CONFIG_METASLAB_SHIFT "metaslab_shift" 52 #define ZPOOL_CONFIG_ASHIFT "ashift" 53 #define ZPOOL_CONFIG_ASIZE "asize" 54 #define ZPOOL_CONFIG_DTL "DTL" 55 #define ZPOOL_CONFIG_STATS "stats" 56 #define ZPOOL_CONFIG_WHOLE_DISK "whole_disk" 57 #define ZPOOL_CONFIG_ERRCOUNT "error_count" 58 #define ZPOOL_CONFIG_NOT_PRESENT "not_present" 59 #define ZPOOL_CONFIG_SPARES "spares" 60 #define ZPOOL_CONFIG_IS_SPARE "is_spare" 61 #define ZPOOL_CONFIG_NPARITY "nparity" 62 #define ZPOOL_CONFIG_PHYS_PATH "phys_path" 63 #define ZPOOL_CONFIG_L2CACHE "l2cache" 64 /* 65 * The persistent vdev state is stored as separate values rather than a single 66 * 'vdev_state' entry. This is because a device can be in multiple states, such 67 * as offline and degraded. 68 */ 69 #define ZPOOL_CONFIG_OFFLINE "offline" 70 #define ZPOOL_CONFIG_FAULTED "faulted" 71 #define ZPOOL_CONFIG_DEGRADED "degraded" 72 #define ZPOOL_CONFIG_REMOVED "removed" 73 74 #define VDEV_TYPE_ROOT "root" 75 #define VDEV_TYPE_MIRROR "mirror" 76 #define VDEV_TYPE_REPLACING "replacing" 77 #define VDEV_TYPE_RAIDZ "raidz" 78 #define VDEV_TYPE_DISK "disk" 79 #define VDEV_TYPE_FILE "file" 80 #define VDEV_TYPE_MISSING "missing" 81 #define VDEV_TYPE_SPARE "spare" 82 #define VDEV_TYPE_L2CACHE "l2cache" 83 84 /* 85 * pool state. The following states are written to disk as part of the normal 86 * SPA lifecycle: ACTIVE, EXPORTED, DESTROYED, SPARE, L2CACHE. The remaining 87 * states are software abstractions used at various levels to communicate pool 88 * state. 89 */ 90 typedef enum pool_state { 91 POOL_STATE_ACTIVE = 0, /* In active use */ 92 POOL_STATE_EXPORTED, /* Explicitly exported */ 93 POOL_STATE_DESTROYED, /* Explicitly destroyed */ 94 POOL_STATE_SPARE, /* Reserved for hot spare use */ 95 POOL_STATE_L2CACHE, /* Level 2 ARC device */ 96 POOL_STATE_UNINITIALIZED, /* Internal spa_t state */ 97 POOL_STATE_UNAVAIL, /* Internal libzfs state */ 98 POOL_STATE_POTENTIALLY_ACTIVE /* Internal libzfs state */ 99 } pool_state_t; 100 101 #endif /* _SYS_FS_ZFS_H */ 102