mirror of
git://sourceware.org/git/lvm2.git
synced 2024-12-30 17:18:21 +03:00
0534cd9cd4
When systemd is running pvscans, udev may not be entirely initialized, so the pvscan should not sleep and retry waiting for udev info.
406 lines
7.5 KiB
C
406 lines
7.5 KiB
C
/*
|
|
* 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#include "lib/misc/lib.h"
|
|
#include "lib/device/device.h"
|
|
#include "lib/misc/lvm-string.h"
|
|
#include "lib/config/defaults.h"
|
|
#include "lib/metadata/metadata-exported.h"
|
|
|
|
#include <stdarg.h>
|
|
|
|
static int _verbose_level = VERBOSE_BASE_LEVEL;
|
|
static int _silent = 0;
|
|
static int _test = 0;
|
|
static int _use_aio = 0;
|
|
static int _md_filtering = 0;
|
|
static int _internal_filtering = 0;
|
|
static int _fwraid_filtering = 0;
|
|
static int _pvmove = 0;
|
|
static int _obtain_device_list_from_udev = DEFAULT_OBTAIN_DEVICE_LIST_FROM_UDEV;
|
|
static enum dev_ext_e _external_device_info_source = DEV_EXT_NONE;
|
|
static int _debug_level = 0;
|
|
static int _debug_classes_logged = 0;
|
|
static int _security_level = SECURITY_LEVEL;
|
|
static char _log_command_info[40] = "";
|
|
static char _log_command_file[40] = "";
|
|
static char _cmd_name[30] = "none";
|
|
static int _mirror_in_sync = 0;
|
|
static int _dmeventd_monitor = DEFAULT_DMEVENTD_MONITOR;
|
|
/* When set, disables update of _dmeventd_monitor & _ignore_suspended_devices */
|
|
static int _disable_dmeventd_monitoring = 0;
|
|
static int _background_polling = DEFAULT_BACKGROUND_POLLING;
|
|
static int _ignore_suspended_devices = 0;
|
|
static int _ignore_lvm_mirrors = DEFAULT_IGNORE_LVM_MIRRORS;
|
|
static int _error_message_produced = 0;
|
|
static unsigned _is_static = 0;
|
|
static int _udev_checking = 1;
|
|
static int _udev_sleeping = 1;
|
|
static int _retry_deactivation = DEFAULT_RETRY_DEACTIVATION;
|
|
static int _activation_checks = 0;
|
|
static char _sysfs_dir_path[PATH_MAX] = "";
|
|
static uint64_t _pv_min_size = (DEFAULT_PV_MIN_SIZE_KB * 1024L >> SECTOR_SHIFT);
|
|
static const char *_unknown_device_name = DEFAULT_UNKNOWN_DEVICE_NAME;
|
|
static int _io_memory_size_kb = DEFAULT_IO_MEMORY_SIZE_KB;
|
|
|
|
void init_verbose(int level)
|
|
{
|
|
_verbose_level = level;
|
|
}
|
|
|
|
void init_silent(int silent)
|
|
{
|
|
_silent = silent;
|
|
}
|
|
|
|
void init_test(int level)
|
|
{
|
|
if (!_test && level)
|
|
log_warn("TEST MODE: Metadata will NOT be updated and volumes will not be (de)activated.");
|
|
_test = level;
|
|
}
|
|
|
|
void init_use_aio(int useaio)
|
|
{
|
|
_use_aio = useaio;
|
|
}
|
|
|
|
void init_md_filtering(int level)
|
|
{
|
|
_md_filtering = level;
|
|
}
|
|
|
|
void init_internal_filtering(int level)
|
|
{
|
|
_internal_filtering = level;
|
|
}
|
|
|
|
void init_fwraid_filtering(int level)
|
|
{
|
|
_fwraid_filtering = level;
|
|
}
|
|
|
|
void init_pvmove(int level)
|
|
{
|
|
_pvmove = level;
|
|
}
|
|
|
|
void init_obtain_device_list_from_udev(int device_list_from_udev)
|
|
{
|
|
_obtain_device_list_from_udev = device_list_from_udev;
|
|
}
|
|
|
|
void init_external_device_info_source(enum dev_ext_e src)
|
|
{
|
|
_external_device_info_source = src;
|
|
}
|
|
|
|
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)
|
|
{
|
|
if (!_disable_dmeventd_monitoring)
|
|
_dmeventd_monitor = reg;
|
|
}
|
|
|
|
void init_disable_dmeventd_monitoring(int reg)
|
|
{
|
|
_disable_dmeventd_monitoring = reg;
|
|
}
|
|
|
|
void init_background_polling(int polling)
|
|
{
|
|
_background_polling = polling;
|
|
}
|
|
|
|
void init_ignore_suspended_devices(int ignore)
|
|
{
|
|
if (!_disable_dmeventd_monitoring)
|
|
_ignore_suspended_devices = ignore;
|
|
}
|
|
|
|
void init_ignore_lvm_mirrors(int scan)
|
|
{
|
|
_ignore_lvm_mirrors = scan;
|
|
}
|
|
|
|
void init_log_command(int log_name, int log_pid)
|
|
{
|
|
memset(_log_command_info, 0, sizeof(_log_command_info));
|
|
memset(_log_command_file, 0, sizeof(_log_command_file));
|
|
|
|
/*
|
|
* Always include command name and pid in file and verbose output.
|
|
*/
|
|
|
|
(void) dm_snprintf(_log_command_file, sizeof(_log_command_file), "%s[%d]",
|
|
_cmd_name, getpid());
|
|
|
|
/*
|
|
* This is the prefix that can be configured for each line of stdout.
|
|
*/
|
|
|
|
if (!log_name && !log_pid)
|
|
return;
|
|
|
|
else if (log_name && !log_pid)
|
|
(void) dm_strncpy(_log_command_info, _cmd_name, sizeof(_log_command_info));
|
|
|
|
else if (!log_name && log_pid)
|
|
(void) dm_snprintf(_log_command_info, sizeof(_log_command_info), "%d", getpid());
|
|
|
|
else
|
|
(void) dm_snprintf(_log_command_info, sizeof(_log_command_info), "%s[%d]",
|
|
_cmd_name, getpid());
|
|
}
|
|
|
|
void init_is_static(unsigned value)
|
|
{
|
|
_is_static = value;
|
|
}
|
|
|
|
void init_udev_checking(int checking)
|
|
{
|
|
if ((_udev_checking = checking))
|
|
log_debug_activation("LVM udev checking enabled");
|
|
else
|
|
log_debug_activation("LVM udev checking disabled");
|
|
}
|
|
|
|
void init_udev_sleeping(int sleeping)
|
|
{
|
|
_udev_sleeping = sleeping;
|
|
}
|
|
|
|
void init_retry_deactivation(int retry)
|
|
{
|
|
_retry_deactivation = retry;
|
|
}
|
|
|
|
void init_activation_checks(int checks)
|
|
{
|
|
if ((_activation_checks = checks))
|
|
log_debug_activation("LVM activation checks enabled");
|
|
else
|
|
log_debug_activation("LVM activation checks disabled");
|
|
}
|
|
|
|
void init_pv_min_size(uint64_t sectors)
|
|
{
|
|
_pv_min_size = sectors;
|
|
}
|
|
|
|
void set_cmd_name(const char *cmd)
|
|
{
|
|
(void) dm_strncpy(_cmd_name, cmd, sizeof(_cmd_name));
|
|
}
|
|
|
|
const char *get_cmd_name(void)
|
|
{
|
|
return _cmd_name;
|
|
}
|
|
|
|
void set_sysfs_dir_path(const char *path)
|
|
{
|
|
(void) dm_strncpy(_sysfs_dir_path, path, sizeof(_sysfs_dir_path));
|
|
}
|
|
|
|
const char *log_command_info(void)
|
|
{
|
|
return _log_command_info;
|
|
}
|
|
|
|
const char *log_command_file(void)
|
|
{
|
|
return _log_command_file;
|
|
}
|
|
|
|
void init_error_message_produced(int value)
|
|
{
|
|
_error_message_produced = value;
|
|
}
|
|
|
|
int error_message_produced(void)
|
|
{
|
|
return _error_message_produced;
|
|
}
|
|
|
|
int test_mode(void)
|
|
{
|
|
return _test;
|
|
}
|
|
|
|
int use_aio(void)
|
|
{
|
|
return _use_aio;
|
|
}
|
|
|
|
int md_filtering(void)
|
|
{
|
|
return _md_filtering;
|
|
}
|
|
|
|
int internal_filtering(void)
|
|
{
|
|
return _internal_filtering;
|
|
}
|
|
|
|
int fwraid_filtering(void)
|
|
{
|
|
return _fwraid_filtering;
|
|
}
|
|
|
|
int pvmove_mode(void)
|
|
{
|
|
return _pvmove;
|
|
}
|
|
|
|
int obtain_device_list_from_udev(void)
|
|
{
|
|
return _obtain_device_list_from_udev;
|
|
}
|
|
|
|
enum dev_ext_e external_device_info_source(void)
|
|
{
|
|
return _external_device_info_source;
|
|
}
|
|
|
|
int background_polling(void)
|
|
{
|
|
return _background_polling;
|
|
}
|
|
|
|
int security_level(void)
|
|
{
|
|
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;
|
|
}
|
|
|
|
int ignore_lvm_mirrors(void)
|
|
{
|
|
return _ignore_lvm_mirrors;
|
|
}
|
|
|
|
void init_debug(int level)
|
|
{
|
|
_debug_level = level;
|
|
}
|
|
|
|
void init_debug_classes_logged(int classes)
|
|
{
|
|
_debug_classes_logged = classes;
|
|
}
|
|
|
|
int debug_class_is_logged(int class)
|
|
{
|
|
/* If no class given, log it */
|
|
if (!class)
|
|
return 1;
|
|
|
|
return (_debug_classes_logged & class) ? 1 : 0;
|
|
}
|
|
|
|
int verbose_level(void)
|
|
{
|
|
return _verbose_level;
|
|
}
|
|
|
|
int debug_level(void)
|
|
{
|
|
return _debug_level;
|
|
}
|
|
|
|
int silent_mode(void)
|
|
{
|
|
return _silent;
|
|
}
|
|
|
|
unsigned is_static(void)
|
|
{
|
|
return _is_static;
|
|
}
|
|
|
|
int udev_checking(void)
|
|
{
|
|
return _udev_checking;
|
|
}
|
|
|
|
int udev_sleeping(void)
|
|
{
|
|
return _udev_sleeping;
|
|
}
|
|
|
|
int retry_deactivation(void)
|
|
{
|
|
return _retry_deactivation;
|
|
}
|
|
|
|
int activation_checks(void)
|
|
{
|
|
return _activation_checks;
|
|
}
|
|
|
|
const char *sysfs_dir_path(void)
|
|
{
|
|
return _sysfs_dir_path;
|
|
}
|
|
|
|
uint64_t pv_min_size(void)
|
|
{
|
|
return _pv_min_size;
|
|
}
|
|
|
|
const char *unknown_device_name(void)
|
|
{
|
|
return _unknown_device_name;
|
|
}
|
|
|
|
void init_unknown_device_name(const char *name)
|
|
{
|
|
_unknown_device_name = name;
|
|
}
|
|
|
|
int io_memory_size(void)
|
|
{
|
|
return _io_memory_size_kb;
|
|
}
|
|
|
|
void init_io_memory_size(int val)
|
|
{
|
|
_io_memory_size_kb = val;
|
|
}
|