4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
22 * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
23 * Use is subject to license terms.
26 #include <sys/zfs_context.h>
28 #include <sys/vdev_impl.h>
30 #include <sys/fs/zfs.h>
33 * Virtual device vector for the pool's root vdev.
37 * We should be able to tolerate one failure with absolutely no damage
38 * to our metadata. Two failures will take out space maps, a bunch of
39 * indirect block trees, meta dnodes, dnodes, etc. Probably not a happy
40 * place to live. When we get smarter, we can liberalize this policy.
41 * e.g. If we haven't lost two consecutive top-level vdevs, then we are
42 * probably fine. Adding bean counters during alloc/free can make this
43 * future guesswork more accurate.
46 too_many_errors(vdev_t
*vd
, int numerrors
)
48 ASSERT3U(numerrors
, <=, vd
->vdev_children
);
49 return (numerrors
> 0);
53 vdev_root_open(vdev_t
*vd
, uint64_t *asize
, uint64_t *ashift
)
59 if (vd
->vdev_children
== 0) {
60 vd
->vdev_stat
.vs_aux
= VDEV_AUX_BAD_LABEL
;
64 for (c
= 0; c
< vd
->vdev_children
; c
++) {
65 vdev_t
*cvd
= vd
->vdev_child
[c
];
68 if ((error
= vdev_open(cvd
)) != 0 &&
76 if (too_many_errors(vd
, numerrors
)) {
77 vd
->vdev_stat
.vs_aux
= VDEV_AUX_NO_REPLICAS
;
88 vdev_root_close(vdev_t
*vd
)
92 for (c
= 0; c
< vd
->vdev_children
; c
++)
93 vdev_close(vd
->vdev_child
[c
]);
97 vdev_root_state_change(vdev_t
*vd
, int faulted
, int degraded
)
99 if (too_many_errors(vd
, faulted
)) {
100 vdev_set_state(vd
, B_FALSE
, VDEV_STATE_CANT_OPEN
,
101 VDEV_AUX_NO_REPLICAS
);
102 } else if (degraded
) {
103 vdev_set_state(vd
, B_FALSE
, VDEV_STATE_DEGRADED
, VDEV_AUX_NONE
);
105 vdev_set_state(vd
, B_FALSE
, VDEV_STATE_HEALTHY
, VDEV_AUX_NONE
);
109 vdev_ops_t vdev_root_ops
= {
113 NULL
, /* io_start - not applicable to the root */
114 NULL
, /* io_done - not applicable to the root */
115 vdev_root_state_change
,
116 VDEV_TYPE_ROOT
, /* name of this vdev type */
117 B_FALSE
/* not a leaf vdev */