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 2006 Sun Microsystems, Inc. All rights reserved.
23 * Use is subject to license terms.
26 #pragma ident "%Z%%M% %I% %E% SMI"
29 * replace components in metadevices
33 #include <sys/lvm/md_stripe.h>
36 * replace named device
50 /* should have a set */
52 assert(sp
->setno
== MD_MIN2SET(meta_getminor(np
->dev
)));
55 if (metachkmeta(np
, ep
) != 0)
57 if ((miscname
= metagetmiscname(np
, ep
)) == NULL
)
61 if (strcmp(miscname
, MD_RAID
) == 0) {
62 return (meta_raid_replace(sp
, np
, oldnp
, newnp
, options
, ep
));
63 } else if (strcmp(miscname
, MD_MIRROR
) == 0) {
64 return (meta_mirror_replace(sp
, np
, oldnp
, newnp
, options
, ep
));
66 return (mdmderror(ep
, MDE_UNKNOWN_TYPE
, meta_getminor(np
->dev
),
85 /* should have a set */
87 assert(sp
->setno
== MD_MIN2SET(meta_getminor(np
->dev
)));
90 if (metachkmeta(np
, ep
) != 0)
92 if ((miscname
= metagetmiscname(np
, ep
)) == NULL
)
96 if (strcmp(miscname
, MD_RAID
) == 0) {
97 return (meta_raid_enable(sp
, np
, compnp
, options
, ep
));
98 } else if (strcmp(miscname
, MD_MIRROR
) == 0) {
99 return (meta_mirror_enable(sp
, np
, compnp
, options
, ep
));
101 return (mdmderror(ep
, MDE_UNKNOWN_TYPE
, meta_getminor(np
->dev
),