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"
2017-10-18 17:57:46 +03:00
static int _vgscan_single ( struct cmd_context * cmd , const char * vg_name ,
struct volume_group * vg ,
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
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
{
2012-03-27 15:04:46 +04:00
int maxret , ret ;
2003-11-14 17:03:48 +03:00
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 ;
}
2018-07-10 21:39:29 +03:00
if ( arg_is_set ( cmd , cache_long_ARG ) ) {
2023-07-15 11:57:37 +03:00
log_warn ( " WARNING: Ignoring vgscan --cache command because lvmetad is no longer used. " ) ;
2018-07-10 21:39:29 +03:00
return ECMD_PROCESSED ;
2012-03-27 15:04:46 +04:00
}
2001-10-24 21:53:50 +04:00
2017-10-18 17:57:46 +03:00
maxret = process_each_vg ( cmd , argc , argv , NULL , NULL , 0 , 0 , NULL , & _vgscan_single ) ;
2003-11-14 17:03:48 +03:00
2016-06-22 00:24:52 +03:00
if ( arg_is_set ( cmd , mknodes_ARG ) ) {
2003-11-14 17:03:48 +03:00
ret = vgmknodes ( cmd , argc , argv ) ;
if ( ret > maxret )
maxret = ret ;
}
return maxret ;
2001-10-12 01:35:55 +04:00
}