Home | History | Annotate | Line # | Download | only in tools
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