2008-10-30 17:39:00 +00:00
/*
* Copyright ( C ) 2001 - 2004 Sistina Software , Inc . All rights reserved .
* Copyright ( C ) 2004 - 2007 Red Hat , Inc . All rights reserved .
*
* This file is part of LVM2 .
*
* This copyrighted material is made available to anyone wishing to use ,
* modify , copy , or redistribute it subject to the terms and conditions
* of the GNU Lesser General Public License v .2 .1 .
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program ; if not , write to the Free Software Foundation ,
* Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*/
# include "lib.h"
# include "device.h"
# include "memlock.h"
# include "lvm-string.h"
# include "defaults.h"
2011-02-18 14:11:22 +00:00
# include "metadata-exported.h"
2008-10-30 17:39:00 +00:00
# include <stdarg.h>
static int _verbose_level = VERBOSE_BASE_LEVEL ;
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
static int _silent = 0 ;
2008-10-30 17:39:00 +00:00
static int _test = 0 ;
static int _md_filtering = 0 ;
static int _pvmove = 0 ;
static int _full_scan_done = 0 ; /* Restrict to one full scan during each cmd */
2011-04-22 12:05:32 +00:00
static int _obtain_device_list_from_udev = DEFAULT_OBTAIN_DEVICE_LIST_FROM_UDEV ;
2008-10-30 17:39:00 +00:00
static int _trust_cache = 0 ; /* Don't scan when incomplete VGs encountered */
static int _debug_level = 0 ;
static int _log_cmd_name = 0 ;
static int _ignorelockingfailure = 0 ;
static int _security_level = SECURITY_LEVEL ;
static char _cmd_name [ 30 ] = " " ;
static int _mirror_in_sync = 0 ;
static int _dmeventd_monitor = DEFAULT_DMEVENTD_MONITOR ;
2010-01-05 20:56:51 +00:00
static int _background_polling = DEFAULT_BACKGROUND_POLLING ;
2008-10-30 17:39:00 +00:00
static int _ignore_suspended_devices = 0 ;
static int _error_message_produced = 0 ;
2008-12-18 05:27:17 +00:00
static unsigned _is_static = 0 ;
2010-01-11 15:40:03 +00:00
static int _udev_checking = 1 ;
2011-09-22 17:39:56 +00:00
static int _retry_deactivation = DEFAULT_RETRY_DEACTIVATION ;
2011-07-01 14:09:19 +00:00
static int _activation_checks = 0 ;
2010-08-11 12:14:23 +00:00
static char _sysfs_dir_path [ PATH_MAX ] = " " ;
2010-10-13 15:40:38 +00:00
static int _dev_disable_after_error_count = DEFAULT_DISABLE_AFTER_ERROR_COUNT ;
2011-02-18 14:11:22 +00:00
static uint64_t _pv_min_size = ( DEFAULT_PV_MIN_SIZE_KB * 1024L > > SECTOR_SHIFT ) ;
2011-08-11 17:46:13 +00:00
static int _detect_internal_vg_cache_corruption =
DEFAULT_DETECT_INTERNAL_VG_CACHE_CORRUPTION ;
2008-10-30 17:39:00 +00:00
void init_verbose ( int level )
{
_verbose_level = level ;
}
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
void init_silent ( int silent )
{
_silent = silent ;
}
2008-10-30 17:39:00 +00:00
void init_test ( int level )
{
if ( ! _test & & level )
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_warn ( " TEST MODE: Metadata will NOT be updated and volumes will not be (de)activated. " ) ;
2008-10-30 17:39:00 +00:00
_test = level ;
}
void init_md_filtering ( int level )
{
_md_filtering = level ;
}
void init_pvmove ( int level )
{
_pvmove = level ;
}
void init_full_scan_done ( int level )
{
_full_scan_done = level ;
}
2011-04-22 12:05:32 +00:00
void init_obtain_device_list_from_udev ( int device_list_from_udev )
{
_obtain_device_list_from_udev = device_list_from_udev ;
}
2008-10-30 17:39:00 +00:00
void init_trust_cache ( int trustcache )
{
_trust_cache = trustcache ;
}
void init_ignorelockingfailure ( int level )
{
_ignorelockingfailure = level ;
}
void init_security_level ( int level )
{
_security_level = level ;
}
void init_mirror_in_sync ( int in_sync )
{
_mirror_in_sync = in_sync ;
}
void init_dmeventd_monitor ( int reg )
{
_dmeventd_monitor = reg ;
}
2010-01-05 20:56:51 +00:00
void init_background_polling ( int polling )
{
_background_polling = polling ;
}
2008-10-30 17:39:00 +00:00
void init_ignore_suspended_devices ( int ignore )
{
_ignore_suspended_devices = ignore ;
}
void init_cmd_name ( int status )
{
_log_cmd_name = status ;
}
2008-12-18 05:27:17 +00:00
void init_is_static ( unsigned value )
{
_is_static = value ;
}
2010-01-11 15:40:03 +00:00
void init_udev_checking ( int checking )
{
if ( ( _udev_checking = checking ) )
log_debug ( " LVM udev checking enabled " ) ;
else
log_debug ( " LVM udev checking disabled " ) ;
}
2011-09-22 17:39:56 +00:00
void init_retry_deactivation ( int retry )
{
_retry_deactivation = retry ;
}
2011-07-01 14:09:19 +00:00
void init_activation_checks ( int checks )
{
if ( ( _activation_checks = checks ) )
log_debug ( " LVM activation checks enabled " ) ;
else
log_debug ( " LVM activation checks disabled " ) ;
}
2010-10-13 15:40:38 +00:00
void init_dev_disable_after_error_count ( int value )
{
_dev_disable_after_error_count = value ;
}
2011-02-18 14:11:22 +00:00
void init_pv_min_size ( uint64_t sectors )
{
_pv_min_size = sectors ;
}
2011-08-11 17:46:13 +00:00
void init_detect_internal_vg_cache_corruption ( int detect )
{
_detect_internal_vg_cache_corruption = detect ;
}
2008-10-30 17:39:00 +00:00
void set_cmd_name ( const char * cmd )
{
2012-02-08 11:05:04 +00:00
strncpy ( _cmd_name , cmd , sizeof ( _cmd_name ) - 1 ) ;
2008-10-30 17:39:00 +00:00
_cmd_name [ sizeof ( _cmd_name ) - 1 ] = ' \0 ' ;
}
2010-08-11 12:14:23 +00:00
void set_sysfs_dir_path ( const char * path )
{
2012-02-08 11:05:04 +00:00
strncpy ( _sysfs_dir_path , path , sizeof ( _sysfs_dir_path ) - 1 ) ;
2010-08-11 12:14:23 +00:00
_sysfs_dir_path [ sizeof ( _sysfs_dir_path ) - 1 ] = ' \0 ' ;
}
2011-03-29 20:30:05 +00:00
const char * log_command_name ( void )
2008-10-30 17:39:00 +00:00
{
if ( ! _log_cmd_name )
return " " ;
return _cmd_name ;
}
void init_error_message_produced ( int value )
{
_error_message_produced = value ;
}
int error_message_produced ( void )
{
return _error_message_produced ;
}
2011-03-29 20:30:05 +00:00
int test_mode ( void )
2008-10-30 17:39:00 +00:00
{
return _test ;
}
2011-03-29 20:30:05 +00:00
int md_filtering ( void )
2008-10-30 17:39:00 +00:00
{
return _md_filtering ;
}
2011-03-29 20:30:05 +00:00
int pvmove_mode ( void )
2008-10-30 17:39:00 +00:00
{
return _pvmove ;
}
2011-03-29 20:30:05 +00:00
int full_scan_done ( void )
2008-10-30 17:39:00 +00:00
{
return _full_scan_done ;
}
2011-09-01 13:30:11 +00:00
int obtain_device_list_from_udev ( void )
2011-04-22 12:05:32 +00:00
{
return _obtain_device_list_from_udev ;
}
2011-03-29 20:30:05 +00:00
int trust_cache ( void )
2008-10-30 17:39:00 +00:00
{
return _trust_cache ;
}
2011-03-29 20:30:05 +00:00
int background_polling ( void )
2010-01-05 20:56:51 +00:00
{
return _background_polling ;
}
2011-03-29 20:30:05 +00:00
int ignorelockingfailure ( void )
2008-10-30 17:39:00 +00:00
{
return _ignorelockingfailure ;
}
2011-03-29 20:30:05 +00:00
int security_level ( void )
2008-10-30 17:39:00 +00:00
{
return _security_level ;
}
int mirror_in_sync ( void )
{
return _mirror_in_sync ;
}
int dmeventd_monitor_mode ( void )
{
return _dmeventd_monitor ;
}
int ignore_suspended_devices ( void )
{
return _ignore_suspended_devices ;
}
void init_debug ( int level )
{
_debug_level = level ;
}
2011-03-29 20:30:05 +00:00
int verbose_level ( void )
2008-10-30 17:39:00 +00:00
{
return _verbose_level ;
}
2011-03-29 20:30:05 +00:00
int debug_level ( void )
2008-10-30 17:39:00 +00:00
{
return _debug_level ;
}
2008-12-18 05:27:17 +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
int silent_mode ( void )
{
return _silent ;
}
2008-12-18 05:27:17 +00:00
unsigned is_static ( void )
{
return _is_static ;
}
2010-01-11 15:40:03 +00:00
int udev_checking ( void )
{
return _udev_checking ;
}
2010-08-11 12:14:23 +00:00
2011-09-22 17:39:56 +00:00
int retry_deactivation ( void )
{
return _retry_deactivation ;
}
2011-07-01 14:09:19 +00:00
int activation_checks ( void )
{
return _activation_checks ;
}
2011-03-29 20:30:05 +00:00
const char * sysfs_dir_path ( void )
2010-08-11 12:14:23 +00:00
{
return _sysfs_dir_path ;
}
2010-10-13 15:40:38 +00:00
int dev_disable_after_error_count ( void )
{
return _dev_disable_after_error_count ;
}
2011-02-18 14:11:22 +00:00
uint64_t pv_min_size ( void )
{
return _pv_min_size ;
}
2011-08-11 17:46:13 +00:00
int detect_internal_vg_cache_corruption ( void )
{
return _detect_internal_vg_cache_corruption ;
}