blob: 17b93c10c81c2231c9d447a5300c0171325c6576 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Jorgen Lundman9b4a1f92012-07-19 20:48:25 +00002/*
3 * GRUB -- GRand Unified Bootloader
4 * Copyright (C) 1999,2000,2001,2002,2003,2004 Free Software Foundation, Inc.
Jorgen Lundman9b4a1f92012-07-19 20:48:25 +00005 */
6/*
7 * Copyright (c) 2007, 2011, Oracle and/or its affiliates. All rights reserved.
8 */
9
10#ifndef GRUB_ZFS_HEADER
11#define GRUB_ZFS_HEADER 1
12
13
14/*
15 * On-disk version number.
16 */
17#define SPA_VERSION 28ULL
18
19/*
20 * The following are configuration names used in the nvlist describing a pool's
21 * configuration.
22 */
23#define ZPOOL_CONFIG_VERSION "version"
24#define ZPOOL_CONFIG_POOL_NAME "name"
25#define ZPOOL_CONFIG_POOL_STATE "state"
26#define ZPOOL_CONFIG_POOL_TXG "txg"
27#define ZPOOL_CONFIG_POOL_GUID "pool_guid"
28#define ZPOOL_CONFIG_CREATE_TXG "create_txg"
29#define ZPOOL_CONFIG_TOP_GUID "top_guid"
30#define ZPOOL_CONFIG_VDEV_TREE "vdev_tree"
31#define ZPOOL_CONFIG_TYPE "type"
32#define ZPOOL_CONFIG_CHILDREN "children"
33#define ZPOOL_CONFIG_ID "id"
34#define ZPOOL_CONFIG_GUID "guid"
35#define ZPOOL_CONFIG_PATH "path"
36#define ZPOOL_CONFIG_DEVID "devid"
37#define ZPOOL_CONFIG_METASLAB_ARRAY "metaslab_array"
38#define ZPOOL_CONFIG_METASLAB_SHIFT "metaslab_shift"
39#define ZPOOL_CONFIG_ASHIFT "ashift"
40#define ZPOOL_CONFIG_ASIZE "asize"
41#define ZPOOL_CONFIG_DTL "DTL"
42#define ZPOOL_CONFIG_STATS "stats"
43#define ZPOOL_CONFIG_WHOLE_DISK "whole_disk"
44#define ZPOOL_CONFIG_ERRCOUNT "error_count"
45#define ZPOOL_CONFIG_NOT_PRESENT "not_present"
46#define ZPOOL_CONFIG_SPARES "spares"
47#define ZPOOL_CONFIG_IS_SPARE "is_spare"
48#define ZPOOL_CONFIG_NPARITY "nparity"
49#define ZPOOL_CONFIG_PHYS_PATH "phys_path"
50#define ZPOOL_CONFIG_L2CACHE "l2cache"
51#define ZPOOL_CONFIG_HOLE_ARRAY "hole_array"
52#define ZPOOL_CONFIG_VDEV_CHILDREN "vdev_children"
53#define ZPOOL_CONFIG_IS_HOLE "is_hole"
54#define ZPOOL_CONFIG_DDT_HISTOGRAM "ddt_histogram"
55#define ZPOOL_CONFIG_DDT_OBJ_STATS "ddt_object_stats"
56#define ZPOOL_CONFIG_DDT_STATS "ddt_stats"
57/*
58 * The persistent vdev state is stored as separate values rather than a single
59 * 'vdev_state' entry. This is because a device can be in multiple states, such
60 * as offline and degraded.
61 */
62#define ZPOOL_CONFIG_OFFLINE "offline"
63#define ZPOOL_CONFIG_FAULTED "faulted"
64#define ZPOOL_CONFIG_DEGRADED "degraded"
65#define ZPOOL_CONFIG_REMOVED "removed"
66
67#define VDEV_TYPE_ROOT "root"
68#define VDEV_TYPE_MIRROR "mirror"
69#define VDEV_TYPE_REPLACING "replacing"
70#define VDEV_TYPE_RAIDZ "raidz"
71#define VDEV_TYPE_DISK "disk"
72#define VDEV_TYPE_FILE "file"
73#define VDEV_TYPE_MISSING "missing"
74#define VDEV_TYPE_HOLE "hole"
75#define VDEV_TYPE_SPARE "spare"
76#define VDEV_TYPE_L2CACHE "l2cache"
77
78/*
79 * pool state. The following states are written to disk as part of the normal
80 * SPA lifecycle: ACTIVE, EXPORTED, DESTROYED, SPARE, L2CACHE. The remaining
81 * states are software abstractions used at various levels to communicate pool
82 * state.
83 */
84typedef enum pool_state {
85 POOL_STATE_ACTIVE = 0, /* In active use */
86 POOL_STATE_EXPORTED, /* Explicitly exported */
87 POOL_STATE_DESTROYED, /* Explicitly destroyed */
88 POOL_STATE_SPARE, /* Reserved for hot spare use */
89 POOL_STATE_L2CACHE, /* Level 2 ARC device */
90 POOL_STATE_UNINITIALIZED, /* Internal spa_t state */
91 POOL_STATE_UNAVAIL, /* Internal libzfs state */
92 POOL_STATE_POTENTIALLY_ACTIVE /* Internal libzfs state */
93} pool_state_t;
94
95struct zfs_data;
96
97int zfs_fetch_nvlist(device_t dev, char **nvlist);
98int zfs_getmdnobj(device_t dev, const char *fsfilename,
99 uint64_t *mdnobj);
100
101char *zfs_nvlist_lookup_string(char *nvlist, char *name);
102char *zfs_nvlist_lookup_nvlist(char *nvlist, char *name);
103int zfs_nvlist_lookup_uint64(char *nvlist, char *name,
104 uint64_t *out);
105char *zfs_nvlist_lookup_nvlist_array(char *nvlist, char *name,
106 size_t index);
107int zfs_nvlist_lookup_nvlist_array_get_nelm(char *nvlist, char *name);
108
109#endif /* ! GRUB_ZFS_HEADER */