2001-10-01 19:29:39 +04:00
/*
2004-03-30 23:35:44 +04:00
* Copyright ( C ) 2001 - 2004 Sistina Software , Inc . All rights reserved .
2009-10-06 00:03:25 +04:00
* Copyright ( C ) 2004 - 2009 Red Hat , Inc . All rights reserved .
2001-11-07 11:50:07 +03:00
*
2004-03-30 23:35:44 +04:00
* This file is part of LVM2 .
2001-11-07 11:50:07 +03:00
*
2004-03-30 23:35:44 +04:00
* This copyrighted material is made available to anyone wishing to use ,
* modify , copy , or redistribute it subject to the terms and conditions
2007-08-21 00:55:30 +04:00
* of the GNU Lesser General Public License v .2 .1 .
2001-11-07 11:50:07 +03:00
*
2007-08-21 00:55:30 +04:00
* You should have received a copy of the GNU Lesser General Public License
2004-03-30 23:35:44 +04:00
* along with this program ; if not , write to the Free Software Foundation ,
* Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
2001-10-01 19:29:39 +04:00
*/
# include "tools.h"
2009-07-26 05:53:09 +04:00
# include "metadata-exported.h"
2001-10-01 19:29:39 +04:00
2008-07-21 23:26:33 +04:00
/*
2009-10-06 00:03:25 +04:00
* Intial sanity checking of recovery - related command - line arguments .
* These args are : - - restorefile , - - uuid , and - - physicalvolumesize
2008-07-21 23:27:22 +04:00
*
* Output arguments :
* pp : structure allocated by caller , fields written / validated here
2008-07-21 23:26:33 +04:00
*/
2009-11-01 22:51:54 +03:00
static int pvcreate_restore_params_validate ( struct cmd_context * cmd ,
2009-10-06 00:03:25 +04:00
int argc , char * * argv ,
struct pvcreate_params * pp )
2001-10-12 14:32:06 +04:00
{
2008-07-25 04:30:57 +04:00
const char * uuid = NULL ;
struct volume_group * vg ;
2010-03-16 18:48:27 +03:00
struct pv_list * existing_pvl ;
2008-07-25 04:30:57 +04:00
2002-11-18 17:04:08 +03:00
if ( arg_count ( cmd , restorefile_ARG ) & & ! arg_count ( cmd , uuidstr_ARG ) ) {
log_error ( " --uuid is required with --restorefile " ) ;
2008-07-21 23:26:33 +04:00
return 0 ;
2002-11-18 17:04:08 +03:00
}
2010-08-12 08:08:59 +04:00
if ( ! arg_count ( cmd , restorefile_ARG ) & & arg_count ( cmd , uuidstr_ARG ) ) {
if ( ! arg_count ( cmd , norestorefile_ARG ) & &
find_config_tree_bool ( cmd ,
" devices/require_restorefile_with_uuid " ,
DEFAULT_REQUIRE_RESTOREFILE_WITH_UUID ) ) {
log_error ( " --restorefile is required with --uuid " ) ;
return 0 ;
}
}
2002-02-12 00:00:35 +03:00
if ( arg_count ( cmd , uuidstr_ARG ) & & argc ! = 1 ) {
2002-01-16 21:10:08 +03:00
log_error ( " Can only set uuid on one volume at once " ) ;
2008-07-21 23:26:33 +04:00
return 0 ;
2002-01-16 21:10:08 +03:00
}
2008-07-25 04:30:57 +04:00
if ( arg_count ( cmd , uuidstr_ARG ) ) {
uuid = arg_str_value ( cmd , uuidstr_ARG , " " ) ;
if ( ! id_read_format ( & pp - > id , uuid ) )
return 0 ;
pp - > idp = & pp - > id ;
2012-02-23 17:11:07 +04:00
lvmcache_seed_infos_from_lvmetad ( cmd ) ; /* need to check for UUID dups */
2008-07-25 04:30:57 +04:00
}
if ( arg_count ( cmd , restorefile_ARG ) ) {
pp - > restorefile = arg_str_value ( cmd , restorefile_ARG , " " ) ;
/* The uuid won't already exist */
if ( ! ( vg = backup_read_vg ( cmd , NULL , pp - > restorefile ) ) ) {
log_error ( " Unable to read volume group from %s " ,
pp - > restorefile ) ;
return 0 ;
}
2010-03-16 18:48:27 +03:00
if ( ! ( existing_pvl = find_pv_in_vg_by_uuid ( vg , pp - > idp ) ) ) {
2008-07-25 04:30:57 +04:00
log_error ( " Can't find uuid %s in backup file %s " ,
uuid , pp - > restorefile ) ;
return 0 ;
}
2010-03-16 18:48:27 +03:00
pp - > pe_start = pv_pe_start ( existing_pvl - > pv ) ;
pp - > extent_size = pv_pe_size ( existing_pvl - > pv ) ;
pp - > extent_count = pv_pe_count ( existing_pvl - > pv ) ;
2011-08-11 00:25:29 +04:00
release_vg ( vg ) ;
2008-07-25 04:30:57 +04:00
}
2012-02-28 18:24:57 +04:00
if ( arg_sign_value ( cmd , physicalvolumesize_ARG , SIGN_NONE ) = = SIGN_MINUS ) {
2009-10-06 00:03:25 +04:00
log_error ( " Physical volume size may not be negative " ) ;
return 0 ;
}
pp - > size = arg_uint64_value ( cmd , physicalvolumesize_ARG , UINT64_C ( 0 ) ) ;
if ( arg_count ( cmd , restorefile_ARG ) | | arg_count ( cmd , uuidstr_ARG ) )
pp - > zero = 0 ;
return 1 ;
}
2008-07-21 23:26:33 +04:00
int pvcreate ( struct cmd_context * cmd , int argc , char * * argv )
{
2008-07-25 18:59:51 +04:00
int i ;
2008-07-21 23:26:33 +04:00
int ret = ECMD_PROCESSED ;
struct pvcreate_params pp ;
2011-03-11 17:56:56 +03:00
struct physical_volume * pv ;
2008-07-21 23:26:33 +04:00
2009-11-01 22:51:54 +03:00
pvcreate_params_set_defaults ( & pp ) ;
2009-10-06 00:03:25 +04:00
2009-11-01 22:51:54 +03:00
if ( ! pvcreate_restore_params_validate ( cmd , argc , argv , & pp ) ) {
2009-10-06 00:03:25 +04:00
return EINVALID_CMD_LINE ;
}
2009-11-01 22:51:54 +03:00
if ( ! pvcreate_params_validate ( cmd , argc , argv , & pp ) ) {
2008-07-21 23:26:33 +04:00
return EINVALID_CMD_LINE ;
}
2001-10-12 14:32:06 +04:00
for ( i = 0 ; i < argc ; i + + ) {
2009-07-26 05:54:20 +04:00
if ( ! lock_vol ( cmd , VG_ORPHANS , LCK_VG_WRITE ) ) {
log_error ( " Can't get lock for orphan PVs " ) ;
return ECMD_FAILED ;
}
2011-08-30 18:55:15 +04:00
dm_unescape_colons_and_at_signs ( argv [ i ] , NULL , NULL ) ;
2010-09-23 16:02:33 +04:00
2011-06-01 23:29:31 +04:00
if ( ! ( pv = pvcreate_single ( cmd , argv [ i ] , & pp , 1 ) ) ) {
2009-09-15 02:47:49 +04:00
stack ;
2008-07-25 18:59:51 +04:00
ret = ECMD_FAILED ;
2009-09-15 02:47:49 +04:00
}
2008-07-25 18:59:51 +04:00
2009-07-26 05:54:20 +04:00
unlock_vg ( cmd , VG_ORPHANS ) ;
2007-06-15 14:11:14 +04:00
if ( sigint_caught ( ) )
return ret ;
2001-10-12 14:32:06 +04:00
}
2001-10-01 19:29:39 +04:00
2003-10-22 02:06:07 +04:00
return ret ;
2001-10-01 19:29:39 +04:00
}