2001-10-29 21:23:35 +03:00
/*
2008-01-30 17:00:02 +03:00
* Copyright ( C ) 2001 - 2004 Sistina Software , Inc . All rights reserved .
2007-08-21 00:55:30 +04:00
* Copyright ( C ) 2004 - 2006 Red Hat , Inc . All rights reserved .
2001-10-29 21:23:35 +03:00
*
2004-03-30 23:35:44 +04:00
* This file is part of LVM2 .
2001-10-29 21:23:35 +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-10-29 21:23:35 +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-29 21:23:35 +03:00
*/
# include "tools.h"
2014-07-21 05:55:46 +04:00
static int _lvscan_single_lvmetad ( struct cmd_context * cmd , struct logical_volume * lv )
{
struct pv_list * pvl ;
2014-08-04 19:36:12 +04:00
struct dm_list all_pvs ;
char pvid_s [ 64 ] __attribute__ ( ( aligned ( 8 ) ) ) ;
2014-07-21 05:55:46 +04:00
if ( ! lvmetad_used ( ) ) {
log_verbose ( " Ignoring lvscan --cache because lvmetad is not in use. " ) ;
return ECMD_PROCESSED ;
}
2014-08-04 19:36:12 +04:00
dm_list_init ( & all_pvs ) ;
2014-07-21 05:55:46 +04:00
2014-08-04 19:36:12 +04:00
if ( ! get_pv_list_for_lv ( lv - > vg - > vgmem , lv , & all_pvs ) )
2014-07-21 05:55:46 +04:00
return ECMD_FAILED ;
2014-08-04 19:36:12 +04:00
dm_list_iterate_items ( pvl , & all_pvs ) {
2014-08-04 19:02:26 +04:00
if ( ! pvl - > pv - > dev ) {
2014-08-19 16:26:06 +04: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 19:02:26 +04:00
continue ;
}
2014-07-21 05:55:46 +04:00
if ( ! lvmetad_pvscan_single ( cmd , pvl - > pv - > dev , NULL ) )
return ECMD_FAILED ;
2014-08-04 19:02:26 +04:00
}
2014-07-21 05:55:46 +04:00
return ECMD_PROCESSED ;
}
2002-11-18 17:04:08 +03:00
static int lvscan_single ( struct cmd_context * cmd , struct logical_volume * lv ,
2014-11-27 17:02:13 +03:00
struct processing_handle * handle __attribute__ ( ( unused ) ) )
2001-10-29 21:23:35 +03:00
{
2003-01-09 01:44:07 +03:00
struct lvinfo info ;
2005-12-08 20:49:34 +03:00
int inkernel , snap_active = 1 ;
2014-06-09 14:08:27 +04:00
dm_percent_t snap_percent ; /* fused, fsize; */
2001-10-29 21:23:35 +03:00
const char * active_str , * snapshot_str ;
2014-09-29 22:43:11 +04:00
if ( arg_count ( cmd , cache_long_ARG ) )
2014-07-21 05:55:46 +04:00
return _lvscan_single_lvmetad ( cmd , lv ) ;
2009-05-14 01:27:43 +04:00
if ( ! arg_count ( cmd , all_ARG ) & & ! lv_is_visible ( lv ) )
2005-10-17 20:41:38 +04:00
return ECMD_PROCESSED ;
2011-02-03 04:24:46 +03:00
inkernel = lv_info ( cmd , lv , 0 , & info , 0 , 0 ) & & info . exists ;
2014-04-28 13:58:26 +04:00
if ( lv_is_cow ( lv ) ) {
2005-12-08 20:49:34 +03:00
if ( inkernel & &
2010-11-30 14:53:31 +03:00
( snap_active = lv_snapshot_percent ( lv , & snap_percent ) ) )
2014-06-09 14:08:27 +04:00
if ( snap_percent = = DM_PERCENT_INVALID )
2005-12-08 20:49:34 +03:00
snap_active = 0 ;
}
2002-12-20 02:25:55 +03:00
/* FIXME Add -D arg to skip this! */
2005-12-08 20:49:34 +03:00
if ( inkernel & & snap_active )
2001-11-14 21:38:07 +03:00
active_str = " ACTIVE " ;
2002-03-11 22:02:28 +03:00
else
2001-11-14 21:38:07 +03:00
active_str = " inactive " ;
2001-10-29 21:23:35 +03:00
2002-02-20 22:04:55 +03:00
if ( lv_is_origin ( lv ) )
2001-11-14 21:38:07 +03:00
snapshot_str = " Original " ;
2002-02-20 22:04:55 +03:00
else if ( lv_is_cow ( lv ) )
2001-11-14 21:38:07 +03:00
snapshot_str = " Snapshot " ;
else
snapshot_str = " " ;
2001-10-29 21:23:35 +03: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 23:35:48 +04: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 21:23:35 +03:00
2003-10-22 02:06:07 +04:00
return ECMD_PROCESSED ;
2001-10-29 21:23:35 +03:00
}
2002-11-18 17:04:08 +03:00
int lvscan ( struct cmd_context * cmd , int argc , char * * argv )
{
2014-09-29 22:43:11 +04:00
if ( argc & & ! arg_count ( cmd , cache_long_ARG ) ) {
2002-11-18 17:04:08 +03:00
log_error ( " No additional command line arguments allowed " ) ;
return EINVALID_CMD_LINE ;
}
2009-07-01 21:00:50 +04:00
return process_each_lv ( cmd , argc , argv , 0 , NULL ,
2002-11-18 17:04:08 +03:00
& lvscan_single ) ;
}