2001-10-12 01:35:55 +04:00
/*
2008-01-30 17:00:02 +03:00
* Copyright ( C ) 2001 - 2004 Sistina Software , Inc . All rights reserved .
2009-09-14 23:44:15 +04:00
* Copyright ( C ) 2004 - 2009 Red Hat , Inc . All rights reserved .
2001-10-12 01:35:55 +04:00
*
2004-03-30 23:35:44 +04:00
* This file is part of LVM2 .
2001-10-12 01:35:55 +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
2007-08-21 00:55:30 +04:00
* of the GNU Lesser General Public License v .2 .1 .
2001-10-12 01:35:55 +04: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 ,
2016-01-21 13:49:46 +03:00
* Inc . , 51 Franklin Street , Fifth Floor , Boston , MA 02110 - 1301 USA
2001-10-12 01:35:55 +04:00
*/
# include "tools.h"
2002-11-18 17:04:08 +03:00
static int vgscan_single ( struct cmd_context * cmd , const char * vg_name ,
2009-07-01 21:00:50 +04:00
struct volume_group * vg ,
2014-11-27 17:02:13 +03:00
struct processing_handle * handle __attribute__ ( ( unused ) ) )
2002-11-18 17:04:08 +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 ( " Found %svolume group \" %s \" using metadata type %s " ,
vg_is_exported ( vg ) ? " exported " : " " , vg_name ,
vg - > fid - > fmt - > name ) ;
2002-11-18 17:04:08 +03:00
2005-05-17 17:44:02 +04:00
check_current_backup ( vg ) ;
2012-02-28 22:08:08 +04:00
2003-10-22 02:06:07 +04:00
return ECMD_PROCESSED ;
2002-11-18 17:04:08 +03:00
}
2001-10-12 01:35:55 +04:00
2016-04-06 23:31:15 +03:00
/*
* Two main vgscan cases related to lvmetad usage :
* 1. vgscan
* 2. vgscan - - cache
*
* 1. The ' vgscan ' command ( without - - cache ) may or may not attempt to
* repopulate the lvmetad cache , and may or may not use the lvmetad
* cache to display VG info :
*
* i . If lvmetad is being used and is in a normal state , then ' vgscan '
* will simply read and display VG info from the lvmetad cache .
*
* ii . If lvmetad is not being used , ' vgscan ' will read all devices to
* display the VG info .
*
* iii . If lvmetad is being used , but has been disabled ( because of
* duplicate devs or lvm1 metadata ) , or has a non - matching token
* ( because the device filter is different from the device filter last
* used to populate lvmetad ) , then ' vgscan ' will begin by rescanning
* devices to repopulate lvmetad . If lvmetad is enabled after the
* rescan , then ' vgscan ' will simply read and display VG info from the
* lvmetad cache ( like case i ) . If lvmetad is disabled after the
* rescan , then ' vgscan ' will read all devices to display VG info
* ( like case ii ) .
*
* 2. The ' vgscan - - cache ' command will always attempt to repopulate
* the lvmetad cache by rescanning all devs ( regardless of whether
* lvmetad was previously disabled or had an unmatching token . )
* lvmetad may be enabled or disabled after the rescan ( depending
* on whether duplicate devs or lvm1 metadata was found ) .
* If enabled , then it will simply read and display VG info from the
* lvmetad cache ( like case 1. i . ) . If disabled , then it will
* read all devices to display VG info ( like case 1. ii . )
*/
2002-02-11 23:50:53 +03:00
int vgscan ( struct cmd_context * cmd , int argc , char * * argv )
2001-10-12 01:35:55 +04:00
{
2016-04-06 23:31:15 +03:00
const char * reason = NULL ;
2012-03-27 15:04:46 +04:00
int maxret , ret ;
2003-11-14 17:03:48 +03:00
2001-10-12 01:35:55 +04:00
if ( argc ) {
log_error ( " Too many parameters on command line " ) ;
return EINVALID_CMD_LINE ;
}
2016-03-07 19:50:45 +03:00
if ( arg_is_set ( cmd , notifydbus_ARG ) ) {
if ( ! lvmnotify_is_supported ( ) ) {
log_error ( " Cannot notify dbus: lvm is not built with dbus support. " ) ;
return ECMD_FAILED ;
}
if ( ! find_config_tree_bool ( cmd , global_notify_dbus_CFG , NULL ) ) {
log_error ( " Cannot notify dbus: notify_dbus is disabled in lvm config. " ) ;
return ECMD_FAILED ;
}
set_pv_notify ( cmd ) ;
set_vg_notify ( cmd ) ;
set_lv_notify ( cmd ) ;
return ECMD_PROCESSED ;
}
2013-03-18 00:29:58 +04:00
if ( ! lock_vol ( cmd , VG_GLOBAL , LCK_VG_WRITE , NULL ) ) {
2007-08-23 19:02:26 +04:00
log_error ( " Unable to obtain global lock. " ) ;
return ECMD_FAILED ;
}
2012-08-13 21:44:10 +04:00
if ( cmd - > filter - > wipe )
cmd - > filter - > wipe ( cmd - > filter ) ;
2014-03-22 01:26:39 +04:00
lvmcache_destroy ( cmd , 1 , 0 ) ;
2012-03-27 15:04:46 +04:00
2016-01-29 01:40:26 +03:00
if ( ! lvmetad_used ( ) & & arg_is_set ( cmd , cache_long_ARG ) )
log_verbose ( " Ignoring vgscan --cache command because lvmetad is not in use. " ) ;
2015-02-26 00:41:15 +03:00
2016-04-06 23:31:15 +03:00
if ( lvmetad_used ( ) & & ( arg_is_set ( cmd , cache_long_ARG ) | | ! lvmetad_token_matches ( cmd ) | | lvmetad_is_disabled ( cmd , & reason ) ) ) {
2016-01-29 01:40:26 +03:00
if ( lvmetad_used ( ) & & ! lvmetad_pvscan_all_devs ( cmd , NULL , arg_is_set ( cmd , cache_long_ARG ) ) ) {
log_warn ( " WARNING: Not using lvmetad because cache update failed. " ) ;
2016-04-14 01:00:01 +03:00
lvmetad_make_unused ( cmd ) ;
2012-03-27 15:04:46 +04:00
}
2016-04-06 23:31:15 +03:00
if ( lvmetad_used ( ) & & lvmetad_is_disabled ( cmd , & reason ) ) {
log_warn ( " WARNING: Not using lvmetad because %s. " , reason ) ;
2016-04-14 01:00:01 +03:00
lvmetad_make_unused ( cmd ) ;
2016-04-06 23:31:15 +03:00
}
2012-03-27 15:04:46 +04:00
}
2001-10-24 21:53:50 +04:00
2016-01-29 01:40:26 +03:00
if ( ! lvmetad_used ( ) )
log_print_unless_silent ( " Reading all physical volumes. This may take a while... " ) ;
else
log_print_unless_silent ( " Reading volume groups from cache. " ) ;
2001-10-12 01:35:55 +04:00
2015-12-01 02:00:26 +03:00
maxret = process_each_vg ( cmd , argc , argv , NULL , 0 , NULL ,
2003-11-14 17:03:48 +03:00
& vgscan_single ) ;
if ( arg_count ( cmd , mknodes_ARG ) ) {
ret = vgmknodes ( cmd , argc , argv ) ;
if ( ret > maxret )
maxret = ret ;
}
2007-08-23 19:02:26 +04:00
unlock_vg ( cmd , VG_GLOBAL ) ;
2003-11-14 17:03:48 +03:00
return maxret ;
2001-10-12 01:35:55 +04:00
}