2001-10-29 18:23:35 +00:00
/*
2008-01-30 14:00:02 +00:00
* Copyright ( C ) 2001 - 2004 Sistina Software , Inc . All rights reserved .
2007-08-20 20:55:30 +00:00
* Copyright ( C ) 2004 - 2006 Red Hat , Inc . All rights reserved .
2001-10-29 18:23:35 +00:00
*
2004-03-30 19:35:44 +00:00
* This file is part of LVM2 .
2001-10-29 18:23:35 +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-10-29 18:23:35 +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 ,
2016-01-21 11:49:46 +01:00
* Inc . , 51 Franklin Street , Fifth Floor , Boston , MA 02110 - 1301 USA
2001-10-29 18:23:35 +00:00
*/
# include "tools.h"
2014-07-21 03:55:46 +02:00
static int _lvscan_single_lvmetad ( struct cmd_context * cmd , struct logical_volume * lv )
{
struct pv_list * pvl ;
2014-08-04 17:36:12 +02:00
struct dm_list all_pvs ;
char pvid_s [ 64 ] __attribute__ ( ( aligned ( 8 ) ) ) ;
2014-07-21 03:55:46 +02:00
if ( ! lvmetad_used ( ) ) {
log_verbose ( " Ignoring lvscan --cache because lvmetad is not in use. " ) ;
return ECMD_PROCESSED ;
}
2014-08-04 17:36:12 +02:00
dm_list_init ( & all_pvs ) ;
2014-07-21 03:55:46 +02:00
2014-08-04 17:36:12 +02:00
if ( ! get_pv_list_for_lv ( lv - > vg - > vgmem , lv , & all_pvs ) )
2014-07-21 03:55:46 +02:00
return ECMD_FAILED ;
2014-08-04 17:36:12 +02:00
dm_list_iterate_items ( pvl , & all_pvs ) {
2014-08-04 17:02:26 +02:00
if ( ! pvl - > pv - > dev ) {
2014-08-19 14:26:06 +02:00
if ( ! id_write_format ( & pvl - > pv - > id , pvid_s , sizeof ( pvid_s ) ) )
stack ;
else
log_warn ( " WARNING: Device for PV %s already missing, skipping. " ,
pvid_s ) ;
2014-08-04 17:02:26 +02:00
continue ;
}
2015-03-10 13:56:25 -05:00
if ( ! lvmetad_pvscan_single ( cmd , pvl - > pv - > dev , NULL , 0 ) )
2014-07-21 03:55:46 +02:00
return ECMD_FAILED ;
2014-08-04 17:02:26 +02:00
}
2014-07-21 03:55:46 +02:00
return ECMD_PROCESSED ;
}
2002-11-18 14:04:08 +00:00
static int lvscan_single ( struct cmd_context * cmd , struct logical_volume * lv ,
2014-11-27 15:02:13 +01:00
struct processing_handle * handle __attribute__ ( ( unused ) ) )
2001-10-29 18:23:35 +00:00
{
2003-01-08 22:44:07 +00:00
struct lvinfo info ;
2005-12-08 17:49:34 +00:00
int inkernel , snap_active = 1 ;
2014-06-09 12:08:27 +02:00
dm_percent_t snap_percent ; /* fused, fsize; */
2001-10-29 18:23:35 +00:00
const char * active_str , * snapshot_str ;
2014-09-29 20:43:11 +02:00
if ( arg_count ( cmd , cache_long_ARG ) )
2014-07-21 03:55:46 +02:00
return _lvscan_single_lvmetad ( cmd , lv ) ;
2009-05-13 21:27:43 +00:00
if ( ! arg_count ( cmd , all_ARG ) & & ! lv_is_visible ( lv ) )
2005-10-17 16:41:38 +00:00
return ECMD_PROCESSED ;
2011-02-03 01:24:46 +00:00
inkernel = lv_info ( cmd , lv , 0 , & info , 0 , 0 ) & & info . exists ;
2014-04-28 11:58:26 +02:00
if ( lv_is_cow ( lv ) ) {
2005-12-08 17:49:34 +00:00
if ( inkernel & &
2010-11-30 11:53:31 +00:00
( snap_active = lv_snapshot_percent ( lv , & snap_percent ) ) )
2014-06-09 12:08:27 +02:00
if ( snap_percent = = DM_PERCENT_INVALID )
2005-12-08 17:49:34 +00:00
snap_active = 0 ;
}
2002-12-19 23:25:55 +00:00
/* FIXME Add -D arg to skip this! */
2005-12-08 17:49:34 +00:00
if ( inkernel & & snap_active )
2001-11-14 18:38:07 +00:00
active_str = " ACTIVE " ;
2002-03-11 19:02:28 +00:00
else
2001-11-14 18:38:07 +00:00
active_str = " inactive " ;
2001-10-29 18:23:35 +00:00
2002-02-20 19:04:55 +00:00
if ( lv_is_origin ( lv ) )
2001-11-14 18:38:07 +00:00
snapshot_str = " Original " ;
2002-02-20 19:04:55 +00:00
else if ( lv_is_cow ( lv ) )
2001-11-14 18:38:07 +00:00
snapshot_str = " Snapshot " ;
else
snapshot_str = " " ;
2001-10-29 18:23:35 +00:00
config: add silent mode
Accept -q as the short form of --quiet.
Suppress non-essential standard output if -q is given twice.
Treat log/silent in lvm.conf as equivalent to -qq.
Review all log_print messages and change some to
log_print_unless_silent.
When silent, the following commands still produce output:
dumpconfig, lvdisplay, lvmdiskscan, lvs, pvck, pvdisplay,
pvs, version, vgcfgrestore -l, vgdisplay, vgs.
[Needs checking.]
Non-essential messages are shifted from log level 4 to log level 5
for syslog and lvm2_log_fn purposes.
2012-08-25 20:35:48 +01:00
log_print_unless_silent ( " %s%s '%s%s/%s' [%s] %s " , active_str , snapshot_str ,
cmd - > dev_dir , lv - > vg - > name , lv - > name ,
display_size ( cmd , lv - > size ) ,
get_alloc_string ( lv - > alloc ) ) ;
2001-10-29 18:23:35 +00:00
2003-10-21 22:06:07 +00:00
return ECMD_PROCESSED ;
2001-10-29 18:23:35 +00:00
}
2002-11-18 14:04:08 +00:00
int lvscan ( struct cmd_context * cmd , int argc , char * * argv )
{
2014-09-29 20:43:11 +02:00
if ( argc & & ! arg_count ( cmd , cache_long_ARG ) ) {
2002-11-18 14:04:08 +00:00
log_error ( " No additional command line arguments allowed " ) ;
return EINVALID_CMD_LINE ;
}
2009-07-01 17:00:50 +00:00
return process_each_lv ( cmd , argc , argv , 0 , NULL ,
2002-11-18 14:04:08 +00:00
& lvscan_single ) ;
}