mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-12 13:18:31 +03:00
c9aaf5fb24
Remove the checks for vg_read_error() in most of the tools callback functions and instead make the check in _process_one_vg() more general. In all but vgcfgbackup, we do not want to proceed if we get any error from vg_read(). In vgcfgbackup's case, we may proceed if the backup is to proceed with inconsistent VGs. This is a special case though, and we mark it with the READ_ALLOW_INCONSISTENT flag passed to process_each_vg (and subsequently to _process_one_vg). NOTE: More cleanup is needed in the vg_read_error() path cases. This patch is a start.
104 lines
2.5 KiB
C
104 lines
2.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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*/
|
|
|
|
#include "tools.h"
|
|
|
|
static char *_expand_filename(const char *template, const char *vg_name,
|
|
char **last_filename)
|
|
{
|
|
char *filename;
|
|
|
|
if (security_level())
|
|
return dm_strdup(template);
|
|
|
|
if (!(filename = dm_malloc(PATH_MAX))) {
|
|
log_error("Failed to allocate filename.");
|
|
return NULL;
|
|
}
|
|
|
|
if (snprintf(filename, PATH_MAX, template, vg_name) < 0) {
|
|
log_error("Error processing filename template %s",
|
|
template);
|
|
dm_free(filename);
|
|
return NULL;
|
|
}
|
|
if (*last_filename && !strncmp(*last_filename, filename, PATH_MAX)) {
|
|
log_error("VGs must be backed up into different files. "
|
|
"Use %%s in filename for VG name.");
|
|
dm_free(filename);
|
|
return NULL;
|
|
}
|
|
|
|
dm_free(*last_filename);
|
|
*last_filename = filename;
|
|
|
|
return filename;
|
|
}
|
|
|
|
static int vg_backup_single(struct cmd_context *cmd, const char *vg_name,
|
|
struct volume_group *vg,
|
|
void *handle)
|
|
{
|
|
char **last_filename = (char **)handle;
|
|
char *filename;
|
|
|
|
if (arg_count(cmd, file_ARG)) {
|
|
if (!(filename = _expand_filename(arg_value(cmd, file_ARG),
|
|
vg->name, last_filename))) {
|
|
stack;
|
|
return ECMD_FAILED;
|
|
}
|
|
|
|
if (!backup_to_file(filename, vg->cmd->cmd_line, vg)) {
|
|
stack;
|
|
return ECMD_FAILED;
|
|
}
|
|
} else {
|
|
if (vg_read_error(vg) == FAILED_INCONSISTENT) {
|
|
log_error("No backup taken: specify filename with -f "
|
|
"to backup an inconsistent VG");
|
|
stack;
|
|
return ECMD_FAILED;
|
|
}
|
|
|
|
/* just use the normal backup code */
|
|
backup_enable(cmd, 1); /* force a backup */
|
|
if (!backup(vg)) {
|
|
stack;
|
|
return ECMD_FAILED;
|
|
}
|
|
}
|
|
|
|
log_print("Volume group \"%s\" successfully backed up.", vg_name);
|
|
return ECMD_PROCESSED;
|
|
}
|
|
|
|
int vgcfgbackup(struct cmd_context *cmd, int argc, char **argv)
|
|
{
|
|
int ret;
|
|
char *last_filename = NULL;
|
|
|
|
init_pvmove(1);
|
|
|
|
ret = process_each_vg(cmd, argc, argv, READ_ALLOW_INCONSISTENT,
|
|
&last_filename, &vg_backup_single);
|
|
|
|
dm_free(last_filename);
|
|
|
|
init_pvmove(0);
|
|
|
|
return ret;
|
|
}
|