2001-09-25 12:49:28 +00:00
/*
2004-03-30 19:35:44 +00:00
* Copyright ( C ) 2001 - 2004 Sistina Software , Inc . All rights reserved .
2007-08-20 20:55:30 +00:00
* Copyright ( C ) 2004 - 2007 Red Hat , Inc . All rights reserved .
2001-09-25 12:49:28 +00:00
*
2004-03-30 19:35:44 +00:00
* This file is part of LVM2 .
2001-09-25 12:49:28 +00:00
*
2004-03-30 19:35:44 +00: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-20 20:55:30 +00:00
* of the GNU Lesser General Public License v .2 .1 .
2001-09-25 12:49:28 +00:00
*
2007-08-20 20:55:30 +00:00
* You should have received a copy of the GNU Lesser General Public License
2004-03-30 19:35:44 +00: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-09-25 12:49:28 +00:00
*/
# include "tools.h"
2006-05-09 21:23:51 +00:00
static int _pvdisplay_single ( struct cmd_context * cmd ,
2007-11-14 18:41:05 +00:00
struct volume_group * vg ,
2002-12-19 23:25:55 +00:00
struct physical_volume * pv , void * handle )
2001-09-25 12:49:28 +00:00
{
2007-06-05 18:23:17 +00:00
struct pv_list * pvl ;
2006-10-16 16:29:40 +00:00
int ret = ECMD_PROCESSED ;
2002-02-11 21:00:35 +00:00
uint64_t size ;
2009-04-10 10:01:38 +00:00
struct volume_group * old_vg = vg ;
2001-09-25 12:49:28 +00:00
2007-10-12 14:29:32 +00:00
const char * pv_name = pv_dev_name ( pv ) ;
2007-11-02 20:40:05 +00:00
const char * vg_name = NULL ;
2001-09-25 12:49:28 +00:00
2008-01-16 18:15:26 +00:00
if ( ! is_orphan ( pv ) & & ! vg ) {
2007-11-02 20:40:05 +00:00
vg_name = pv_vg_name ( pv ) ;
2009-07-01 16:59:37 +00:00
vg = vg_read ( cmd , vg_name , ( char * ) & pv - > vgid , 0 ) ;
if ( vg_read_error ( vg ) ) {
2009-11-24 17:07:09 +00:00
log_error ( " Skipping volume group %s " , vg_name ) ;
2010-12-08 20:50:48 +00:00
free_vg ( vg ) ;
2007-11-15 21:30:52 +00:00
/* FIXME If CLUSTERED should return ECMD_PROCESSED here */
2009-11-24 17:07:09 +00:00
return ECMD_FAILED ;
}
2007-11-14 18:41:05 +00:00
/*
* Replace possibly incomplete PV structure with new one
2009-01-26 19:01:32 +00:00
* allocated in vg_read_internal ( ) path .
2007-11-14 18:41:05 +00:00
*/
2007-06-05 18:23:17 +00:00
if ( ! ( pvl = find_pv_in_vg ( vg , pv_name ) ) ) {
log_error ( " Unable to find \" %s \" in volume group \" %s \" " ,
pv_name , vg - > name ) ;
2008-01-30 14:00:02 +00:00
ret = ECMD_FAILED ;
goto out ;
2007-05-31 20:10:25 +00:00
}
2007-06-05 18:23:17 +00:00
pv = pvl - > pv ;
2007-05-31 20:10:25 +00:00
}
2006-10-16 16:29:40 +00:00
2007-11-02 14:54:40 +00:00
if ( is_orphan ( pv ) )
2007-06-15 22:16:55 +00:00
size = pv_size ( pv ) ;
2001-10-25 14:04:18 +00:00
else
2008-01-30 14:00:02 +00:00
size = ( pv_pe_count ( pv ) - pv_pe_alloc_count ( pv ) ) *
2007-06-15 22:16:55 +00:00
pv_pe_size ( pv ) ;
2001-09-25 12:49:28 +00:00
2002-02-11 21:00:35 +00:00
if ( arg_count ( cmd , short_ARG ) ) {
2002-12-12 20:55:49 +00:00
log_print ( " Device \" %s \" has a capacity of %s " , pv_name ,
2006-05-09 21:23:51 +00:00
display_size ( cmd , size ) ) ;
2006-10-16 16:29:40 +00:00
goto out ;
2001-09-25 12:49:28 +00:00
}
2007-06-15 22:16:55 +00:00
if ( pv_status ( pv ) & EXPORTED_VG )
2002-02-11 21:00:35 +00:00
log_print ( " Physical volume \" %s \" of volume group \" %s \" "
2007-06-15 22:16:55 +00:00
" is exported " , pv_name , pv_vg_name ( pv ) ) ;
2001-09-25 12:49:28 +00:00
2007-11-02 14:54:40 +00:00
if ( is_orphan ( pv ) )
2002-02-11 21:00:35 +00:00
log_print ( " \" %s \" is a new physical volume of \" %s \" " ,
2006-05-09 21:23:51 +00:00
pv_name , display_size ( cmd , size ) ) ;
2001-09-25 12:49:28 +00:00
2002-02-11 21:00:35 +00:00
if ( arg_count ( cmd , colon_ARG ) ) {
2001-10-18 16:55:19 +00:00
pvdisplay_colons ( pv ) ;
2006-10-16 16:29:40 +00:00
goto out ;
2001-09-25 12:49:28 +00:00
}
2002-12-12 20:55:49 +00:00
pvdisplay_full ( cmd , pv , handle ) ;
2001-09-25 12:49:28 +00:00
2007-05-30 20:43:09 +00:00
if ( arg_count ( cmd , maps_ARG ) )
pvdisplay_segments ( pv ) ;
2006-10-16 16:29:40 +00:00
out :
2008-01-30 14:00:02 +00:00
if ( vg_name )
unlock_vg ( cmd , vg_name ) ;
2009-04-10 10:01:38 +00:00
if ( ! old_vg )
2010-12-08 20:50:48 +00:00
free_vg ( vg ) ;
2001-09-25 12:49:28 +00:00
2006-10-16 16:29:40 +00:00
return ret ;
2002-11-18 14:04:08 +00:00
}
int pvdisplay ( struct cmd_context * cmd , int argc , char * * argv )
{
2002-12-12 20:55:49 +00:00
if ( arg_count ( cmd , columns_ARG ) ) {
if ( arg_count ( cmd , colon_ARG ) | | arg_count ( cmd , maps_ARG ) | |
arg_count ( cmd , short_ARG ) ) {
log_error ( " Incompatible options selected " ) ;
return EINVALID_CMD_LINE ;
}
return pvs ( cmd , argc , argv ) ;
} else if ( arg_count ( cmd , aligned_ARG ) | |
2005-03-21 14:47:36 +00:00
arg_count ( cmd , all_ARG ) | |
2002-12-12 20:55:49 +00:00
arg_count ( cmd , noheadings_ARG ) | |
arg_count ( cmd , options_ARG ) | |
arg_count ( cmd , separator_ARG ) | |
arg_count ( cmd , sort_ARG ) | | arg_count ( cmd , unbuffered_ARG ) ) {
log_error ( " Incompatible options selected " ) ;
return EINVALID_CMD_LINE ;
}
2002-11-18 14:04:08 +00:00
if ( arg_count ( cmd , colon_ARG ) & & arg_count ( cmd , maps_ARG ) ) {
log_error ( " Option -v not allowed with option -c " ) ;
return EINVALID_CMD_LINE ;
}
2009-07-15 05:50:22 +00:00
return process_each_pv ( cmd , argc , argv , NULL , 0 , 0 , NULL ,
2007-11-14 18:41:05 +00:00
_pvdisplay_single ) ;
2001-09-25 12:49:28 +00:00
}