2001-10-09 21:20:02 +04:00
/*
2004-03-30 23:35:44 +04:00
* Copyright ( C ) 2001 - 2004 Sistina Software , Inc . All rights reserved .
* Copyright ( C ) 2004 Red Hat , Inc . All rights reserved .
2001-10-09 21:20:02 +04:00
*
2004-03-30 23:35:44 +04:00
* This file is part of LVM2 .
2001-10-09 21:20:02 +04: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
* of the GNU General Public License v .2 .
2001-10-09 21:20:02 +04:00
*
* You should have received a copy of the GNU 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-09 21:20:02 +04:00
*/
# include "tools.h"
2002-11-18 17:04:08 +03:00
static int vgremove_single ( struct cmd_context * cmd , const char * vg_name ,
struct volume_group * vg , int consistent ,
void * handle )
2001-10-09 21:20:02 +04:00
{
struct physical_volume * pv ;
2003-10-16 00:02:46 +04:00
struct pv_list * pvl ;
2003-10-22 02:06:07 +04:00
int ret = ECMD_PROCESSED ;
2001-10-09 21:20:02 +04:00
2004-11-18 22:45:53 +03:00
if ( ! vg | | ! consistent | | ( vg - > status & PARTIAL_VG ) ) {
log_error ( " Volume group \" %s \" not found or inconsistent. " ,
vg_name ) ;
log_error ( " Consider vgreduce --removemissing if metadata "
" is inconsistent. " ) ;
2001-10-12 01:35:55 +04:00
return ECMD_FAILED ;
}
2001-10-09 21:20:02 +04:00
2002-02-12 00:00:35 +03:00
if ( vg - > status & EXPORTED_VG ) {
log_error ( " Volume group \" %s \" is exported " , vg - > name ) ;
return ECMD_FAILED ;
}
2002-01-29 20:23:33 +03:00
2001-10-09 21:20:02 +04:00
if ( vg - > lv_count ) {
2002-01-30 18:04:48 +03:00
log_error ( " Volume group \" %s \" still contains %d "
2002-02-12 00:00:35 +03:00
" logical volume(s) " , vg_name , vg - > lv_count ) ;
2001-10-09 21:20:02 +04:00
return ECMD_FAILED ;
}
2002-01-09 16:17:14 +03:00
if ( ! archive ( vg ) )
return ECMD_FAILED ;
2002-04-24 22:20:51 +04:00
if ( ! vg_remove ( vg ) ) {
log_error ( " vg_remove %s failed " , vg_name ) ;
return ECMD_FAILED ;
2001-10-09 21:20:02 +04:00
}
/* init physical volumes */
2003-10-16 00:02:46 +04:00
list_iterate_items ( pvl , & vg - > pvs ) {
pv = pvl - > pv ;
2002-01-30 18:04:48 +03:00
log_verbose ( " Removing physical volume \" %s \" from "
2002-02-12 00:00:35 +03:00
" volume group \" %s \" " , dev_name ( pv - > dev ) , vg_name ) ;
2002-12-20 02:25:55 +03:00
pv - > vg_name = ORPHAN ;
2005-05-03 21:28:23 +04:00
pv - > status = ALLOCATABLE_PV ;
if ( ! dev_get_size ( pv - > dev , & pv - > size ) ) {
log_error ( " %s: Couldn't get size. " , dev_name ( pv - > dev ) ) ;
ret = ECMD_FAILED ;
continue ;
}
2002-11-18 17:04:08 +03:00
/* FIXME Write to same sector label was read from */
2003-03-24 21:08:53 +03:00
if ( ! pv_write ( cmd , pv , NULL , INT64_C ( - 1 ) ) ) {
2002-01-30 18:04:48 +03:00
log_error ( " Failed to remove physical volume \" %s \" "
" from volume group \" %s \" " ,
dev_name ( pv - > dev ) , vg_name ) ;
2001-10-12 01:35:55 +04:00
ret = ECMD_FAILED ;
}
2001-10-09 21:20:02 +04:00
}
2005-05-17 17:46:38 +04:00
backup_remove ( cmd , vg_name ) ;
2002-01-01 00:27:39 +03:00
2003-11-06 20:16:22 +03:00
if ( ret = = ECMD_PROCESSED )
2002-01-30 18:04:48 +03:00
log_print ( " Volume group \" %s \" successfully removed " , vg_name ) ;
2001-10-12 01:35:55 +04:00
else
2002-01-30 18:04:48 +03:00
log_error ( " Volume group \" %s \" not properly removed " , vg_name ) ;
2001-10-09 21:20:02 +04:00
2001-10-12 01:35:55 +04:00
return ret ;
2001-10-09 21:20:02 +04:00
}
2002-11-18 17:04:08 +03:00
int vgremove ( struct cmd_context * cmd , int argc , char * * argv )
{
int ret ;
if ( ! lock_vol ( cmd , " " , LCK_VG_WRITE ) ) {
log_error ( " Can't get lock for orphan PVs " ) ;
return ECMD_FAILED ;
}
ret = process_each_vg ( cmd , argc , argv ,
2004-09-27 14:32:36 +04:00
LCK_VG_WRITE | LCK_NONBLOCK , 1 ,
2004-09-24 16:48:43 +04:00
NULL , & vgremove_single ) ;
2002-11-18 17:04:08 +03:00
unlock_vg ( cmd , " " ) ;
return ret ;
}