2002-11-18 14:01:16 +00:00
/*
* Copyright ( C ) 2001 Sistina Software ( UK ) Limited .
*
* This file is released under the LGPL .
*
*/
# include "lib.h"
# include "toolcontext.h"
# include "pool.h"
# include "metadata.h"
# include "defaults.h"
# include "lvm-string.h"
# include "activate.h"
# include "filter.h"
# include "filter-composite.h"
# include "filter-persistent.h"
# include "filter-regex.h"
2004-02-13 14:46:04 +00:00
# include "filter-sysfs.h"
2002-11-18 14:01:16 +00:00
# include "label.h"
# include "lvm-file.h"
# include "format-text.h"
2002-12-12 20:55:49 +00:00
# include "display.h"
2003-07-04 22:34:56 +00:00
# include "memlock.h"
2004-03-08 18:13:22 +00:00
# include "str_list.h"
2002-11-18 14:01:16 +00:00
2003-03-24 18:08:53 +00:00
# ifdef HAVE_LIBDL
# include "sharedlib.h"
# endif
2002-11-18 14:01:16 +00:00
# ifdef LVM1_INTERNAL
# include "format1.h"
# endif
# include <locale.h>
# include <sys/stat.h>
2004-03-08 17:25:59 +00:00
# include <sys/utsname.h>
2002-11-18 14:01:16 +00:00
# include <syslog.h>
# include <time.h>
2003-07-04 22:34:56 +00:00
# ifdef linux
# include <malloc.h>
# endif
2002-11-18 14:01:16 +00:00
static FILE * _log ;
static int _get_env_vars ( struct cmd_context * cmd )
{
const char * e ;
/* Set to "" to avoid using any system directory */
if ( ( e = getenv ( " LVM_SYSTEM_DIR " ) ) ) {
if ( lvm_snprintf ( cmd - > sys_dir , sizeof ( cmd - > sys_dir ) ,
" %s " , e ) < 0 ) {
log_error ( " LVM_SYSTEM_DIR environment variable "
" is too long. " ) ;
return 0 ;
}
}
return 1 ;
}
static void _init_logging ( struct cmd_context * cmd )
{
2003-07-04 22:34:56 +00:00
int append = 1 ;
2002-11-18 14:01:16 +00:00
time_t t ;
const char * log_file ;
/* Syslog */
cmd - > default_settings . syslog =
2004-03-08 18:28:45 +00:00
find_config_int ( cmd - > cft - > root , " log/syslog " , DEFAULT_SYSLOG ) ;
2002-11-18 14:01:16 +00:00
if ( cmd - > default_settings . syslog ! = 1 )
fin_syslog ( ) ;
if ( cmd - > default_settings . syslog > 1 )
init_syslog ( cmd - > default_settings . syslog ) ;
/* Debug level for log file output */
cmd - > default_settings . debug =
2004-03-08 18:28:45 +00:00
find_config_int ( cmd - > cft - > root , " log/level " , DEFAULT_LOGLEVEL ) ;
2002-11-18 14:01:16 +00:00
init_debug ( cmd - > default_settings . debug ) ;
/* Verbose level for tty output */
cmd - > default_settings . verbose =
2004-03-08 18:28:45 +00:00
find_config_int ( cmd - > cft - > root , " log/verbose " , DEFAULT_VERBOSE ) ;
2004-03-26 11:45:01 +00:00
init_verbose ( cmd - > default_settings . verbose + VERBOSE_BASE_LEVEL ) ;
2002-11-18 14:01:16 +00:00
/* Log message formatting */
2004-03-08 18:28:45 +00:00
init_indent ( find_config_int ( cmd - > cft - > root , " log/indent " ,
2002-11-18 14:01:16 +00:00
DEFAULT_INDENT ) ) ;
2004-03-08 18:28:45 +00:00
cmd - > default_settings . msg_prefix = find_config_str ( cmd - > cft - > root ,
" log/prefix " ,
2002-11-18 14:01:16 +00:00
DEFAULT_MSG_PREFIX ) ;
init_msg_prefix ( cmd - > default_settings . msg_prefix ) ;
2004-03-08 18:28:45 +00:00
cmd - > default_settings . cmd_name = find_config_int ( cmd - > cft - > root ,
2002-11-18 14:01:16 +00:00
" log/command_names " ,
2004-03-08 18:28:45 +00:00
DEFAULT_CMD_NAME ) ;
2002-11-18 14:01:16 +00:00
init_cmd_name ( cmd - > default_settings . cmd_name ) ;
/* Test mode */
cmd - > default_settings . test =
2004-03-08 18:28:45 +00:00
find_config_int ( cmd - > cft - > root , " global/test " , 0 ) ;
2002-11-18 14:01:16 +00:00
/* Settings for logging to file */
2004-03-08 18:28:45 +00:00
if ( find_config_int ( cmd - > cft - > root , " log/overwrite " ,
2002-11-18 14:01:16 +00:00
DEFAULT_OVERWRITE ) )
2003-07-04 22:34:56 +00:00
append = 0 ;
2002-11-18 14:01:16 +00:00
2004-03-08 18:28:45 +00:00
log_file = find_config_str ( cmd - > cft - > root , " log/file " , 0 ) ;
2004-03-08 18:13:22 +00:00
if ( log_file ) {
release_log_memory ( ) ;
fin_log ( ) ;
2003-07-04 22:34:56 +00:00
init_log_file ( log_file , append ) ;
2004-03-08 18:13:22 +00:00
}
2003-07-04 22:34:56 +00:00
2004-03-08 18:28:45 +00:00
log_file = find_config_str ( cmd - > cft - > root , " log/activate_file " , 0 ) ;
2003-07-04 22:34:56 +00:00
if ( log_file )
init_log_direct ( log_file , append ) ;
2004-03-08 18:28:45 +00:00
init_log_while_suspended ( find_config_int ( cmd - > cft - > root ,
" log/activation " , 0 ) ) ;
2002-11-18 14:01:16 +00:00
t = time ( NULL ) ;
log_verbose ( " Logging initialised at %s " , ctime ( & t ) ) ;
/* Tell device-mapper about our logging */
2003-01-08 22:44:07 +00:00
# ifdef DEVMAPPER_SUPPORT
2002-11-18 14:01:16 +00:00
dm_log_init ( print_log ) ;
2003-01-08 22:44:07 +00:00
# endif
2002-11-18 14:01:16 +00:00
}
static int _process_config ( struct cmd_context * cmd )
{
mode_t old_umask ;
/* umask */
2004-03-08 18:28:45 +00:00
cmd - > default_settings . umask = find_config_int ( cmd - > cft - > root ,
" global/umask " ,
2002-11-18 14:01:16 +00:00
DEFAULT_UMASK ) ;
if ( ( old_umask = umask ( ( mode_t ) cmd - > default_settings . umask ) ) ! =
( mode_t ) cmd - > default_settings . umask )
log_verbose ( " Set umask to %04o " , cmd - > default_settings . umask ) ;
/* dev dir */
if ( lvm_snprintf ( cmd - > dev_dir , sizeof ( cmd - > dev_dir ) , " %s/ " ,
2004-03-08 18:28:45 +00:00
find_config_str ( cmd - > cft - > root , " devices/dir " ,
DEFAULT_DEV_DIR ) ) < 0 ) {
2002-11-18 14:01:16 +00:00
log_error ( " Device directory given in config file too long " ) ;
return 0 ;
}
2003-01-08 22:44:07 +00:00
# ifdef DEVMAPPER_SUPPORT
2002-11-18 14:01:16 +00:00
dm_set_dev_dir ( cmd - > dev_dir ) ;
2003-01-08 22:44:07 +00:00
# endif
2002-11-18 14:01:16 +00:00
/* proc dir */
if ( lvm_snprintf ( cmd - > proc_dir , sizeof ( cmd - > proc_dir ) , " %s " ,
2004-03-08 18:28:45 +00:00
find_config_str ( cmd - > cft - > root , " global/proc " ,
DEFAULT_PROC_DIR ) ) < 0 ) {
2002-11-18 14:01:16 +00:00
log_error ( " Device directory given in config file too long " ) ;
return 0 ;
}
/* activation? */
2004-03-08 18:28:45 +00:00
cmd - > default_settings . activation = find_config_int ( cmd - > cft - > root ,
2002-11-18 14:01:16 +00:00
" global/activation " ,
DEFAULT_ACTIVATION ) ;
set_activation ( cmd - > default_settings . activation ) ;
2004-03-08 18:28:45 +00:00
cmd - > default_settings . suffix = find_config_int ( cmd - > cft - > root ,
2002-12-12 20:55:49 +00:00
" global/suffix " ,
2004-03-08 18:28:45 +00:00
DEFAULT_SUFFIX ) ;
2002-12-12 20:55:49 +00:00
if ( ! ( cmd - > default_settings . unit_factor =
2004-03-08 18:28:45 +00:00
units_to_bytes ( find_config_str ( cmd - > cft - > root ,
2002-12-12 20:55:49 +00:00
" global/units " ,
DEFAULT_UNITS ) ,
& cmd - > default_settings . unit_type ) ) ) {
log_error ( " Invalid units specification " ) ;
return 0 ;
}
2002-11-18 14:01:16 +00:00
return 1 ;
}
/* Find and read config file */
static int _init_config ( struct cmd_context * cmd )
{
struct stat info ;
char config_file [ PATH_MAX ] = " " ;
2004-03-08 18:28:45 +00:00
if ( ! ( cmd - > cft = create_config_tree ( ) ) ) {
2002-11-18 14:01:16 +00:00
stack ;
return 0 ;
}
/* No config file if LVM_SYSTEM_DIR is empty */
if ( ! * cmd - > sys_dir )
return 1 ;
if ( lvm_snprintf ( config_file , sizeof ( config_file ) ,
" %s/lvm.conf " , cmd - > sys_dir ) < 0 ) {
log_error ( " LVM_SYSTEM_DIR was too long " ) ;
2004-03-08 18:28:45 +00:00
destroy_config_tree ( cmd - > cft ) ;
2002-11-18 14:01:16 +00:00
return 0 ;
}
/* Is there a config file? */
if ( stat ( config_file , & info ) = = - 1 ) {
if ( errno = = ENOENT )
return 1 ;
log_sys_error ( " stat " , config_file ) ;
2004-03-08 18:28:45 +00:00
destroy_config_tree ( cmd - > cft ) ;
2002-11-18 14:01:16 +00:00
return 0 ;
}
2004-03-08 18:28:45 +00:00
if ( ! read_config_file ( cmd - > cft , config_file ) ) {
2002-11-18 14:01:16 +00:00
log_error ( " Failed to load config file %s " , config_file ) ;
2004-03-08 18:28:45 +00:00
destroy_config_tree ( cmd - > cft ) ;
2002-11-18 14:01:16 +00:00
return 0 ;
}
return 1 ;
}
static int _init_dev_cache ( struct cmd_context * cmd )
{
struct config_node * cn ;
struct config_value * cv ;
if ( ! dev_cache_init ( ) ) {
stack ;
return 0 ;
}
2004-03-08 18:28:45 +00:00
if ( ! ( cn = find_config_node ( cmd - > cft - > root , " devices/scan " ) ) ) {
2002-11-18 14:01:16 +00:00
if ( ! dev_cache_add_dir ( " /dev " ) ) {
log_error ( " Failed to add /dev to internal "
" device cache " ) ;
return 0 ;
}
log_verbose ( " device/scan not in config file: "
" Defaulting to /dev " ) ;
return 1 ;
}
for ( cv = cn - > v ; cv ; cv = cv - > next ) {
if ( cv - > type ! = CFG_STRING ) {
log_error ( " Invalid string in config file: "
" devices/scan " ) ;
return 0 ;
}
if ( ! dev_cache_add_dir ( cv - > v . str ) ) {
log_error ( " Failed to add %s to internal device cache " ,
cv - > v . str ) ;
return 0 ;
}
}
return 1 ;
}
2004-02-13 14:46:04 +00:00
# define MAX_FILTERS 3
2002-11-18 14:01:16 +00:00
static struct dev_filter * _init_filter_components ( struct cmd_context * cmd )
{
2004-02-13 14:46:04 +00:00
unsigned nr_filt = 0 ;
2002-11-18 14:01:16 +00:00
struct config_node * cn ;
2004-02-13 14:46:04 +00:00
struct dev_filter * filters [ MAX_FILTERS ] ;
2002-11-18 14:01:16 +00:00
2004-02-13 14:46:04 +00:00
memset ( filters , 0 , sizeof ( filters ) ) ;
2002-12-03 16:20:38 +00:00
2004-02-13 14:46:04 +00:00
/* sysfs filter */
2004-03-08 18:28:45 +00:00
if ( find_config_bool ( cmd - > cft - > root , " devices/sysfs_scan " ,
2004-02-13 14:46:04 +00:00
DEFAULT_SYSFS_SCAN ) ) {
if ( ( filters [ nr_filt ] = sysfs_filter_create ( cmd - > proc_dir ) ) )
nr_filt + + ;
}
2002-11-18 14:01:16 +00:00
2004-02-13 14:46:04 +00:00
/* regex filter */
2004-03-08 18:28:45 +00:00
if ( ! ( cn = find_config_node ( cmd - > cft - > root , " devices/filter " ) ) )
2002-11-18 14:01:16 +00:00
log_debug ( " devices/filter not found in config file: no regex "
" filter installed " ) ;
2004-02-13 14:46:04 +00:00
else if ( ! ( filters [ nr_filt + + ] = regex_filter_create ( cn - > v ) ) ) {
2002-11-18 14:01:16 +00:00
log_error ( " Failed to create regex device filter " ) ;
2003-04-15 13:22:43 +00:00
return NULL ;
2002-11-18 14:01:16 +00:00
}
2004-02-13 14:46:04 +00:00
/* device type filter */
2004-03-08 18:28:45 +00:00
cn = find_config_node ( cmd - > cft - > root , " devices/types " ) ;
2004-02-13 14:46:04 +00:00
if ( ! ( filters [ nr_filt + + ] = lvm_type_filter_create ( cmd - > proc_dir , cn ) ) ) {
log_error ( " Failed to create lvm type filter " ) ;
2003-04-15 13:22:43 +00:00
return NULL ;
2002-11-18 14:01:16 +00:00
}
2004-02-13 14:46:04 +00:00
/* only build a composite filter if we really need it */
return ( nr_filt = = 1 ) ?
filters [ 0 ] : composite_filter_create ( nr_filt , filters ) ;
2002-11-18 14:01:16 +00:00
}
static int _init_filters ( struct cmd_context * cmd )
{
2003-07-04 22:34:56 +00:00
const char * dev_cache ;
2002-11-18 14:01:16 +00:00
struct dev_filter * f3 , * f4 ;
struct stat st ;
char cache_file [ PATH_MAX ] ;
cmd - > dump_filter = 0 ;
if ( ! ( f3 = _init_filter_components ( cmd ) ) )
return 0 ;
if ( lvm_snprintf ( cache_file , sizeof ( cache_file ) ,
" %s/.cache " , cmd - > sys_dir ) < 0 ) {
log_error ( " Persistent cache filename too long ('%s/.cache'). " ,
cmd - > sys_dir ) ;
return 0 ;
}
2003-07-04 22:34:56 +00:00
dev_cache =
2004-03-08 18:28:45 +00:00
find_config_str ( cmd - > cft - > root , " devices/cache " , cache_file ) ;
2003-07-04 22:34:56 +00:00
if ( ! ( f4 = persistent_filter_create ( f3 , dev_cache ) ) ) {
2002-11-18 14:01:16 +00:00
log_error ( " Failed to create persistent device filter " ) ;
return 0 ;
}
/* Should we ever dump persistent filter state? */
2004-03-08 18:28:45 +00:00
if ( find_config_int ( cmd - > cft - > root , " devices/write_cache_state " , 1 ) )
2002-11-18 14:01:16 +00:00
cmd - > dump_filter = 1 ;
if ( ! * cmd - > sys_dir )
cmd - > dump_filter = 0 ;
2003-07-04 22:34:56 +00:00
if ( ! stat ( dev_cache , & st ) & &
2004-03-08 18:28:45 +00:00
( st . st_mtime > config_file_timestamp ( cmd - > cft ) ) & &
2003-01-06 21:09:04 +00:00
! persistent_filter_load ( f4 ) )
2002-11-18 14:01:16 +00:00
log_verbose ( " Failed to load existing device cache from %s " ,
2003-07-04 22:34:56 +00:00
dev_cache ) ;
2002-11-18 14:01:16 +00:00
cmd - > filter = f4 ;
return 1 ;
}
static int _init_formats ( struct cmd_context * cmd )
{
const char * format ;
struct format_type * fmt ;
struct list * fmth ;
2003-03-24 18:08:53 +00:00
# ifdef HAVE_LIBDL
struct config_node * cn ;
# endif
2002-11-18 14:01:16 +00:00
label_init ( ) ;
# ifdef LVM1_INTERNAL
if ( ! ( fmt = init_lvm1_format ( cmd ) ) )
return 0 ;
fmt - > library = NULL ;
list_add ( & cmd - > formats , & fmt - > list ) ;
# endif
2003-03-24 18:08:53 +00:00
# ifdef HAVE_LIBDL
2002-11-18 14:01:16 +00:00
/* Load any formats in shared libs */
2004-03-08 18:28:45 +00:00
if ( ( cn = find_config_node ( cmd - > cft - > root , " global/format_libraries " ) ) ) {
2003-03-24 18:08:53 +00:00
struct config_value * cv ;
struct format_type * ( * init_format_fn ) ( struct cmd_context * ) ;
void * lib ;
2002-11-18 14:01:16 +00:00
for ( cv = cn - > v ; cv ; cv = cv - > next ) {
if ( cv - > type ! = CFG_STRING ) {
log_error ( " Invalid string in config file: "
" global/format_libraries " ) ;
return 0 ;
}
2004-03-08 18:28:45 +00:00
if ( ! ( lib = load_shared_library ( cmd - > cft , cv - > v . str ,
2002-11-18 14:01:16 +00:00
" format " ) ) ) {
stack ;
return 0 ;
}
if ( ! ( init_format_fn = dlsym ( lib , " init_format " ) ) ) {
log_error ( " Shared library %s does not contain "
" format functions " , cv - > v . str ) ;
dlclose ( lib ) ;
return 0 ;
}
if ( ! ( fmt = init_format_fn ( cmd ) ) )
return 0 ;
fmt - > library = lib ;
list_add ( & cmd - > formats , & fmt - > list ) ;
}
}
2003-03-24 18:08:53 +00:00
# endif
2002-11-18 14:01:16 +00:00
if ( ! ( fmt = create_text_format ( cmd ) ) )
return 0 ;
fmt - > library = NULL ;
list_add ( & cmd - > formats , & fmt - > list ) ;
cmd - > fmt_backup = fmt ;
2004-03-08 18:28:45 +00:00
format = find_config_str ( cmd - > cft - > root , " global/format " ,
2002-11-18 14:01:16 +00:00
DEFAULT_FORMAT ) ;
list_iterate ( fmth , & cmd - > formats ) {
fmt = list_item ( fmth , struct format_type ) ;
if ( ! strcasecmp ( fmt - > name , format ) | |
( fmt - > alias & & ! strcasecmp ( fmt - > alias , format ) ) ) {
cmd - > default_settings . fmt = fmt ;
return 1 ;
}
}
log_error ( " _init_formats: Default format (%s) not found " , format ) ;
return 0 ;
}
2004-03-08 17:25:59 +00:00
static int _init_hostname ( struct cmd_context * cmd )
{
struct utsname uts ;
if ( uname ( & uts ) ) {
log_sys_error ( " uname " , " _init_hostname " ) ;
return 0 ;
}
if ( ! ( cmd - > hostname = pool_strdup ( cmd - > libmem , uts . nodename ) ) ) {
log_error ( " _init_hostname: pool_strdup failed " ) ;
return 0 ;
}
return 1 ;
}
2004-03-08 18:13:22 +00:00
static int _set_tag ( struct cmd_context * cmd , const char * tag )
{
log_very_verbose ( " Setting host tag: %s " , pool_strdup ( cmd - > libmem , tag ) ) ;
if ( ! str_list_add ( cmd - > libmem , & cmd - > tags , tag ) ) {
log_error ( " _init_tags: str_list_add %s failed " , tag ) ;
return 0 ;
}
return 1 ;
}
static int _check_host_filters ( struct cmd_context * cmd , struct config_node * hn ,
int * passes )
{
struct config_node * cn ;
struct config_value * cv ;
* passes = 1 ;
for ( cn = hn ; cn ; cn = cn - > sib ) {
if ( ! cn - > v )
continue ;
if ( ! strcmp ( cn - > key , " host_list " ) ) {
* passes = 0 ;
if ( cn - > v - > type = = CFG_EMPTY_ARRAY )
continue ;
for ( cv = cn - > v ; cv ; cv = cv - > next ) {
if ( cv - > type ! = CFG_STRING ) {
log_error ( " Invalid hostname string "
" for tag %s " , cn - > key ) ;
return 0 ;
}
if ( ! strcmp ( cv - > v . str , cmd - > hostname ) ) {
* passes = 1 ;
return 1 ;
}
}
}
if ( ! strcmp ( cn - > key , " host_filter " ) ) {
log_error ( " host_filter not supported yet " ) ;
return 0 ;
}
}
return 1 ;
}
static int _init_tags ( struct cmd_context * cmd )
{
struct config_node * tn , * cn ;
const char * tag ;
int passes ;
list_init ( & cmd - > tags ) ;
2004-03-08 18:28:45 +00:00
if ( ! ( tn = find_config_node ( cmd - > cft - > root , " tags " ) ) | |
2004-03-08 18:13:22 +00:00
! tn - > child ) {
log_very_verbose ( " No tags defined in config file " ) ;
return 1 ;
}
2004-03-08 18:28:45 +00:00
if ( find_config_int ( cmd - > cft - > root , " tags/hosttags " ,
2004-03-08 18:13:22 +00:00
DEFAULT_HOSTTAGS ) ) {
/* FIXME Strip out invalid chars: only A-Za-z0-9_+.- */
if ( ! _set_tag ( cmd , cmd - > hostname ) ) {
stack ;
return 0 ;
}
}
for ( cn = tn - > child ; cn ; cn = cn - > sib ) {
if ( cn - > v )
continue ;
tag = cn - > key ;
if ( * tag = = ' @ ' )
tag + + ;
if ( ! validate_name ( tag ) ) {
log_error ( " Invalid tag in config file: %s " , cn - > key ) ;
return 0 ;
}
if ( cn - > child ) {
passes = 0 ;
if ( ! _check_host_filters ( cmd , cn - > child , & passes ) ) {
stack ;
return 0 ;
}
if ( ! passes )
continue ;
}
if ( ! _set_tag ( cmd , tag ) ) {
stack ;
return 0 ;
}
}
return 1 ;
}
2002-11-18 14:01:16 +00:00
/* Entry point */
struct cmd_context * create_toolcontext ( struct arg * the_args )
{
struct cmd_context * cmd ;
2003-07-04 22:34:56 +00:00
# ifdef M_MMAP_MAX
mallopt ( M_MMAP_MAX , 0 ) ;
# endif
2002-11-18 14:01:16 +00:00
if ( ! setlocale ( LC_ALL , " " ) )
log_error ( " setlocale failed " ) ;
2004-02-13 22:56:45 +00:00
# ifdef INTL_PACKAGE
bindtextdomain ( INTL_PACKAGE , LOCALEDIR ) ;
# endif
2002-11-18 14:01:16 +00:00
init_syslog ( DEFAULT_LOG_FACILITY ) ;
if ( ! ( cmd = dbg_malloc ( sizeof ( * cmd ) ) ) ) {
log_error ( " Failed to allocate command context " ) ;
return NULL ;
}
memset ( cmd , 0 , sizeof ( * cmd ) ) ;
cmd - > args = the_args ;
list_init ( & cmd - > formats ) ;
strcpy ( cmd - > sys_dir , DEFAULT_SYS_DIR ) ;
if ( ! _get_env_vars ( cmd ) )
goto error ;
/* Create system directory if it doesn't already exist */
if ( * cmd - > sys_dir & & ! create_dir ( cmd - > sys_dir ) )
goto error ;
if ( ! _init_config ( cmd ) )
goto error ;
_init_logging ( cmd ) ;
2004-03-08 17:25:59 +00:00
if ( ! ( cmd - > libmem = pool_create ( 4 * 1024 ) ) ) {
log_error ( " Library memory pool creation failed " ) ;
return 0 ;
}
2002-11-18 14:01:16 +00:00
if ( ! _process_config ( cmd ) )
goto error ;
if ( ! _init_dev_cache ( cmd ) )
goto error ;
if ( ! _init_filters ( cmd ) )
goto error ;
if ( ! ( cmd - > mem = pool_create ( 4 * 1024 ) ) ) {
log_error ( " Command memory pool creation failed " ) ;
return 0 ;
}
2003-07-04 22:34:56 +00:00
memlock_init ( cmd ) ;
2002-11-18 14:01:16 +00:00
if ( ! _init_formats ( cmd ) )
goto error ;
2004-03-08 17:25:59 +00:00
if ( ! _init_hostname ( cmd ) )
goto error ;
2004-03-08 18:13:22 +00:00
if ( ! _init_tags ( cmd ) )
goto error ;
2002-11-18 14:01:16 +00:00
cmd - > current_settings = cmd - > default_settings ;
return cmd ;
error :
dbg_free ( cmd ) ;
return NULL ;
}
2004-03-08 18:13:22 +00:00
int refresh_toolcontext ( struct cmd_context * cmd )
{
_init_logging ( cmd ) ;
_init_tags ( cmd ) ;
/* FIXME Reset filters and dev_cache */
return 1 ;
}
2002-12-19 23:25:55 +00:00
static void _destroy_formats ( struct list * formats )
2002-11-18 14:01:16 +00:00
{
struct list * fmtl , * tmp ;
struct format_type * fmt ;
void * lib ;
list_iterate_safe ( fmtl , tmp , formats ) {
fmt = list_item ( fmtl , struct format_type ) ;
list_del ( & fmt - > list ) ;
lib = fmt - > library ;
fmt - > ops - > destroy ( fmt ) ;
2003-03-24 18:08:53 +00:00
# ifdef HAVE_LIBDL
2002-11-18 14:01:16 +00:00
if ( lib )
dlclose ( lib ) ;
2003-03-24 18:08:53 +00:00
# endif
2002-11-18 14:01:16 +00:00
}
}
void destroy_toolcontext ( struct cmd_context * cmd )
{
if ( cmd - > dump_filter )
persistent_filter_dump ( cmd - > filter ) ;
2003-07-04 22:34:56 +00:00
activation_exit ( ) ;
lvmcache_destroy ( ) ;
2002-11-18 14:01:16 +00:00
label_exit ( ) ;
2002-12-19 23:25:55 +00:00
_destroy_formats ( & cmd - > formats ) ;
2002-11-18 14:01:16 +00:00
cmd - > filter - > destroy ( cmd - > filter ) ;
pool_destroy ( cmd - > mem ) ;
dev_cache_exit ( ) ;
2004-03-08 18:28:45 +00:00
destroy_config_tree ( cmd - > cft ) ;
2004-03-08 17:25:59 +00:00
pool_destroy ( cmd - > libmem ) ;
2002-11-18 14:01:16 +00:00
dbg_free ( cmd ) ;
2003-07-04 22:34:56 +00:00
release_log_memory ( ) ;
2002-11-18 14:01:16 +00:00
dump_memory ( ) ;
fin_log ( ) ;
fin_syslog ( ) ;
if ( _log )
fclose ( _log ) ;
}