vgcreate.c revision 1.1 1 1.1 haad /* $NetBSD: vgcreate.c,v 1.1 2008/12/22 00:19:09 haad Exp $ */
2 1.1 haad
3 1.1 haad /*
4 1.1 haad * Copyright (C) 2001-2004 Sistina Software, Inc. All rights reserved.
5 1.1 haad * Copyright (C) 2004-2007 Red Hat, Inc. All rights reserved.
6 1.1 haad *
7 1.1 haad * This file is part of LVM2.
8 1.1 haad *
9 1.1 haad * This copyrighted material is made available to anyone wishing to use,
10 1.1 haad * modify, copy, or redistribute it subject to the terms and conditions
11 1.1 haad * of the GNU Lesser General Public License v.2.1.
12 1.1 haad *
13 1.1 haad * You should have received a copy of the GNU Lesser General Public License
14 1.1 haad * along with this program; if not, write to the Free Software Foundation,
15 1.1 haad * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 1.1 haad */
17 1.1 haad
18 1.1 haad #include "tools.h"
19 1.1 haad
20 1.1 haad int vgcreate(struct cmd_context *cmd, int argc, char **argv)
21 1.1 haad {
22 1.1 haad struct vgcreate_params vp_new;
23 1.1 haad struct vgcreate_params vp_def;
24 1.1 haad struct volume_group *vg;
25 1.1 haad const char *tag;
26 1.1 haad const char *clustered_message = "";
27 1.1 haad
28 1.1 haad if (!argc) {
29 1.1 haad log_error("Please provide volume group name and "
30 1.1 haad "physical volumes");
31 1.1 haad return EINVALID_CMD_LINE;
32 1.1 haad }
33 1.1 haad
34 1.1 haad if (argc == 1) {
35 1.1 haad log_error("Please enter physical volume name(s)");
36 1.1 haad return EINVALID_CMD_LINE;
37 1.1 haad }
38 1.1 haad
39 1.1 haad vp_def.vg_name = NULL;
40 1.1 haad vp_def.extent_size = DEFAULT_EXTENT_SIZE * 2;
41 1.1 haad vp_def.max_pv = 0;
42 1.1 haad vp_def.max_lv = 0;
43 1.1 haad vp_def.alloc = ALLOC_NORMAL;
44 1.1 haad vp_def.clustered = 0;
45 1.1 haad if (fill_vg_create_params(cmd, argv[0], &vp_new, &vp_def))
46 1.1 haad return EINVALID_CMD_LINE;
47 1.1 haad
48 1.1 haad if (validate_vg_create_params(cmd, &vp_new))
49 1.1 haad return EINVALID_CMD_LINE;
50 1.1 haad
51 1.1 haad /* Create the new VG */
52 1.1 haad if (!(vg = vg_create(cmd, vp_new.vg_name, vp_new.extent_size,
53 1.1 haad vp_new.max_pv, vp_new.max_lv, vp_new.alloc,
54 1.1 haad argc - 1, argv + 1)))
55 1.1 haad return ECMD_FAILED;
56 1.1 haad
57 1.1 haad if (vp_new.max_lv != vg->max_lv)
58 1.1 haad log_warn("WARNING: Setting maxlogicalvolumes to %d "
59 1.1 haad "(0 means unlimited)", vg->max_lv);
60 1.1 haad
61 1.1 haad if (vp_new.max_pv != vg->max_pv)
62 1.1 haad log_warn("WARNING: Setting maxphysicalvolumes to %d "
63 1.1 haad "(0 means unlimited)", vg->max_pv);
64 1.1 haad
65 1.1 haad if (arg_count(cmd, addtag_ARG)) {
66 1.1 haad if (!(tag = arg_str_value(cmd, addtag_ARG, NULL))) {
67 1.1 haad log_error("Failed to get tag");
68 1.1 haad return ECMD_FAILED;
69 1.1 haad }
70 1.1 haad
71 1.1 haad if (!(vg->fid->fmt->features & FMT_TAGS)) {
72 1.1 haad log_error("Volume group format does not support tags");
73 1.1 haad return ECMD_FAILED;
74 1.1 haad }
75 1.1 haad
76 1.1 haad if (!str_list_add(cmd->mem, &vg->tags, tag)) {
77 1.1 haad log_error("Failed to add tag %s to volume group %s",
78 1.1 haad tag, vp_new.vg_name);
79 1.1 haad return ECMD_FAILED;
80 1.1 haad }
81 1.1 haad }
82 1.1 haad
83 1.1 haad /* FIXME: move this inside vg_create? */
84 1.1 haad if (vp_new.clustered) {
85 1.1 haad vg->status |= CLUSTERED;
86 1.1 haad clustered_message = "Clustered ";
87 1.1 haad } else {
88 1.1 haad vg->status &= ~CLUSTERED;
89 1.1 haad if (locking_is_clustered())
90 1.1 haad clustered_message = "Non-clustered ";
91 1.1 haad }
92 1.1 haad
93 1.1 haad if (!lock_vol(cmd, VG_ORPHANS, LCK_VG_WRITE)) {
94 1.1 haad log_error("Can't get lock for orphan PVs");
95 1.1 haad return ECMD_FAILED;
96 1.1 haad }
97 1.1 haad
98 1.1 haad if (!lock_vol(cmd, vp_new.vg_name, LCK_VG_WRITE | LCK_NONBLOCK)) {
99 1.1 haad log_error("Can't get lock for %s", vp_new.vg_name);
100 1.1 haad unlock_vg(cmd, VG_ORPHANS);
101 1.1 haad return ECMD_FAILED;
102 1.1 haad }
103 1.1 haad
104 1.1 haad if (!archive(vg)) {
105 1.1 haad unlock_vg(cmd, vp_new.vg_name);
106 1.1 haad unlock_vg(cmd, VG_ORPHANS);
107 1.1 haad return ECMD_FAILED;
108 1.1 haad }
109 1.1 haad
110 1.1 haad /* Store VG on disk(s) */
111 1.1 haad if (!vg_write(vg) || !vg_commit(vg)) {
112 1.1 haad unlock_vg(cmd, vp_new.vg_name);
113 1.1 haad unlock_vg(cmd, VG_ORPHANS);
114 1.1 haad return ECMD_FAILED;
115 1.1 haad }
116 1.1 haad
117 1.1 haad unlock_vg(cmd, vp_new.vg_name);
118 1.1 haad unlock_vg(cmd, VG_ORPHANS);
119 1.1 haad
120 1.1 haad backup(vg);
121 1.1 haad
122 1.1 haad log_print("%s%colume group \"%s\" successfully created",
123 1.1 haad clustered_message, *clustered_message ? 'v' : 'V', vg->name);
124 1.1 haad
125 1.1 haad return ECMD_PROCESSED;
126 1.1 haad }
127