mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
Add lots of missing stack debug messages to tools.
Make readonly locking available as locking type 4. Fix readonly locking to permit writeable global locks (for vgscan). (2.02.49)
This commit is contained in:
parent
905240f91d
commit
651ff9b328
@ -1,5 +1,8 @@
|
|||||||
Version 2.02.52 -
|
Version 2.02.52 -
|
||||||
=================================
|
=================================
|
||||||
|
Add lots of missing stack debug messages to tools.
|
||||||
|
Make readonly locking available as locking type 4.
|
||||||
|
Fix readonly locking to permit writeable global locks (for vgscan). (2.02.49)
|
||||||
Add manpage entry for dmsetup's udevcomplete_all and udevcookies commands.
|
Add manpage entry for dmsetup's udevcomplete_all and udevcookies commands.
|
||||||
Add DM_UDEV_RULES_VSN udev enviroment variable.
|
Add DM_UDEV_RULES_VSN udev enviroment variable.
|
||||||
Check that udev is running and set internal state appropriately.
|
Check that udev is running and set internal state appropriately.
|
||||||
@ -97,6 +100,7 @@ Version 2.02.50 - 28th July 2009
|
|||||||
|
|
||||||
Version 2.02.49 - 15th July 2009
|
Version 2.02.49 - 15th July 2009
|
||||||
================================
|
================================
|
||||||
|
Add readonly locking type to replace implementation of --ignorelockingfailure.
|
||||||
Exclude VG_GLOBAL from vg_write_lock_held so scans open devs read-only again.
|
Exclude VG_GLOBAL from vg_write_lock_held so scans open devs read-only again.
|
||||||
Add unit test case for liblvm VG create/delete APIs.
|
Add unit test case for liblvm VG create/delete APIs.
|
||||||
Add liblvm APIs to implement creation and deletion of VGs.
|
Add liblvm APIs to implement creation and deletion of VGs.
|
||||||
|
@ -261,6 +261,13 @@ int init_locking(int type, struct cmd_context *cmd)
|
|||||||
return 1;
|
return 1;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
case 4:
|
||||||
|
log_verbose("Read-only locking selected. "
|
||||||
|
"Only read operations permitted.");
|
||||||
|
if (!init_readonly_locking(&_locking, cmd))
|
||||||
|
break;
|
||||||
|
return 1;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
log_error("Unknown locking type requested.");
|
log_error("Unknown locking type requested.");
|
||||||
return 0;
|
return 0;
|
||||||
@ -280,7 +287,6 @@ int init_locking(int type, struct cmd_context *cmd)
|
|||||||
if (!ignorelockingfailure())
|
if (!ignorelockingfailure())
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/* FIXME Ensure only read ops are permitted */
|
|
||||||
log_verbose("Locking disabled - only read operations permitted.");
|
log_verbose("Locking disabled - only read operations permitted.");
|
||||||
init_readonly_locking(&_locking, cmd);
|
init_readonly_locking(&_locking, cmd);
|
||||||
|
|
||||||
|
@ -71,10 +71,13 @@ static int _readonly_lock_resource(struct cmd_context *cmd,
|
|||||||
uint32_t flags)
|
uint32_t flags)
|
||||||
{
|
{
|
||||||
if ((flags & LCK_TYPE_MASK) == LCK_WRITE &&
|
if ((flags & LCK_TYPE_MASK) == LCK_WRITE &&
|
||||||
(flags & LCK_SCOPE_MASK) == LCK_VG) {
|
(flags & LCK_SCOPE_MASK) == LCK_VG &&
|
||||||
|
!(flags & LCK_CACHE) &&
|
||||||
|
strcmp(resource, VG_GLOBAL)) {
|
||||||
log_error("Write locks are prohibited with --ignorelockingfailure.");
|
log_error("Write locks are prohibited with --ignorelockingfailure.");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return _no_lock_resource(cmd, resource, flags);
|
return _no_lock_resource(cmd, resource, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -22,8 +22,10 @@ int dumpconfig(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
if (arg_count(cmd, file_ARG))
|
if (arg_count(cmd, file_ARG))
|
||||||
file = arg_str_value(cmd, file_ARG, "");
|
file = arg_str_value(cmd, file_ARG, "");
|
||||||
|
|
||||||
if (!write_config_file(cmd->cft, file, argc, argv))
|
if (!write_config_file(cmd->cft, file, argc, argv)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
|
@ -591,8 +591,10 @@ static int lvchange_single(struct cmd_context *cmd, struct logical_volume *lv,
|
|||||||
|
|
||||||
/* access permission change */
|
/* access permission change */
|
||||||
if (arg_count(cmd, permission_ARG)) {
|
if (arg_count(cmd, permission_ARG)) {
|
||||||
if (!archive(lv->vg))
|
if (!archive(lv->vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
archived = 1;
|
archived = 1;
|
||||||
doit += lvchange_permission(cmd, lv);
|
doit += lvchange_permission(cmd, lv);
|
||||||
docmds++;
|
docmds++;
|
||||||
@ -600,8 +602,10 @@ static int lvchange_single(struct cmd_context *cmd, struct logical_volume *lv,
|
|||||||
|
|
||||||
/* allocation policy change */
|
/* allocation policy change */
|
||||||
if (arg_count(cmd, contiguous_ARG) || arg_count(cmd, alloc_ARG)) {
|
if (arg_count(cmd, contiguous_ARG) || arg_count(cmd, alloc_ARG)) {
|
||||||
if (!archived && !archive(lv->vg))
|
if (!archived && !archive(lv->vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
archived = 1;
|
archived = 1;
|
||||||
doit += lvchange_alloc(cmd, lv);
|
doit += lvchange_alloc(cmd, lv);
|
||||||
docmds++;
|
docmds++;
|
||||||
@ -609,8 +613,10 @@ static int lvchange_single(struct cmd_context *cmd, struct logical_volume *lv,
|
|||||||
|
|
||||||
/* read ahead sector change */
|
/* read ahead sector change */
|
||||||
if (arg_count(cmd, readahead_ARG)) {
|
if (arg_count(cmd, readahead_ARG)) {
|
||||||
if (!archived && !archive(lv->vg))
|
if (!archived && !archive(lv->vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
archived = 1;
|
archived = 1;
|
||||||
doit += lvchange_readahead(cmd, lv);
|
doit += lvchange_readahead(cmd, lv);
|
||||||
docmds++;
|
docmds++;
|
||||||
@ -618,19 +624,25 @@ static int lvchange_single(struct cmd_context *cmd, struct logical_volume *lv,
|
|||||||
|
|
||||||
/* read ahead sector change */
|
/* read ahead sector change */
|
||||||
if (arg_count(cmd, persistent_ARG)) {
|
if (arg_count(cmd, persistent_ARG)) {
|
||||||
if (!archived && !archive(lv->vg))
|
if (!archived && !archive(lv->vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
archived = 1;
|
archived = 1;
|
||||||
doit += lvchange_persistent(cmd, lv);
|
doit += lvchange_persistent(cmd, lv);
|
||||||
docmds++;
|
docmds++;
|
||||||
if (sigint_caught())
|
if (sigint_caught()) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* add tag */
|
/* add tag */
|
||||||
if (arg_count(cmd, addtag_ARG)) {
|
if (arg_count(cmd, addtag_ARG)) {
|
||||||
if (!archived && !archive(lv->vg))
|
if (!archived && !archive(lv->vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
archived = 1;
|
archived = 1;
|
||||||
doit += lvchange_tag(cmd, lv, addtag_ARG);
|
doit += lvchange_tag(cmd, lv, addtag_ARG);
|
||||||
docmds++;
|
docmds++;
|
||||||
@ -638,8 +650,10 @@ static int lvchange_single(struct cmd_context *cmd, struct logical_volume *lv,
|
|||||||
|
|
||||||
/* del tag */
|
/* del tag */
|
||||||
if (arg_count(cmd, deltag_ARG)) {
|
if (arg_count(cmd, deltag_ARG)) {
|
||||||
if (!archived && !archive(lv->vg))
|
if (!archived && !archive(lv->vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
archived = 1;
|
archived = 1;
|
||||||
doit += lvchange_tag(cmd, lv, deltag_ARG);
|
doit += lvchange_tag(cmd, lv, deltag_ARG);
|
||||||
docmds++;
|
docmds++;
|
||||||
@ -649,28 +663,38 @@ static int lvchange_single(struct cmd_context *cmd, struct logical_volume *lv,
|
|||||||
log_print("Logical volume \"%s\" changed", lv->name);
|
log_print("Logical volume \"%s\" changed", lv->name);
|
||||||
|
|
||||||
if (arg_count(cmd, resync_ARG))
|
if (arg_count(cmd, resync_ARG))
|
||||||
if (!lvchange_resync(cmd, lv))
|
if (!lvchange_resync(cmd, lv)) {
|
||||||
return ECMD_FAILED;
|
stack;
|
||||||
|
|
||||||
/* availability change */
|
|
||||||
if (arg_count(cmd, available_ARG)) {
|
|
||||||
if (!lvchange_availability(cmd, lv))
|
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (arg_count(cmd, refresh_ARG))
|
/* availability change */
|
||||||
if (!lvchange_refresh(cmd, lv))
|
if (arg_count(cmd, available_ARG)) {
|
||||||
|
if (!lvchange_availability(cmd, lv)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (arg_count(cmd, refresh_ARG))
|
||||||
|
if (!lvchange_refresh(cmd, lv)) {
|
||||||
|
stack;
|
||||||
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!arg_count(cmd, available_ARG) &&
|
if (!arg_count(cmd, available_ARG) &&
|
||||||
!arg_count(cmd, refresh_ARG) &&
|
!arg_count(cmd, refresh_ARG) &&
|
||||||
arg_count(cmd, monitor_ARG)) {
|
arg_count(cmd, monitor_ARG)) {
|
||||||
if (!lvchange_monitoring(cmd, lv))
|
if (!lvchange_monitoring(cmd, lv)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (doit != docmds)
|
if (doit != docmds) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
|
@ -904,16 +904,24 @@ static int lvconvert_single(struct cmd_context *cmd, struct logical_volume *lv,
|
|||||||
log_error("Unable to convert mirrored LV \"%s\" into a snapshot.", lv->name);
|
log_error("Unable to convert mirrored LV \"%s\" into a snapshot.", lv->name);
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
if (!archive(lv->vg))
|
if (!archive(lv->vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
if (!lvconvert_snapshot(cmd, lv, lp))
|
}
|
||||||
|
if (!lvconvert_snapshot(cmd, lv, lp)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
} else if (arg_count(cmd, mirrors_ARG) || (lv->status & MIRRORED)) {
|
} else if (arg_count(cmd, mirrors_ARG) || (lv->status & MIRRORED)) {
|
||||||
if (!archive(lv->vg))
|
if (!archive(lv->vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
if (!_lvconvert_mirrors(cmd, lv, lp))
|
}
|
||||||
|
if (!_lvconvert_mirrors(cmd, lv, lp)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
|
@ -586,14 +586,19 @@ int lvcreate(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
vg = vg_read_for_update(cmd, lp.vg_name, NULL, 0);
|
vg = vg_read_for_update(cmd, lp.vg_name, NULL, 0);
|
||||||
if (vg_read_error(vg)) {
|
if (vg_read_error(vg)) {
|
||||||
vg_release(vg);
|
vg_release(vg);
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!_update_extents_params(vg, &lp, &lcp))
|
if (!_update_extents_params(vg, &lp, &lcp)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!lv_create_single(vg, &lp))
|
if (!lv_create_single(vg, &lp)) {
|
||||||
|
stack;
|
||||||
r = ECMD_FAILED;
|
r = ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
unlock_and_release_vg(cmd, vg, lp.vg_name);
|
unlock_and_release_vg(cmd, vg, lp.vg_name);
|
||||||
return r;
|
return r;
|
||||||
|
@ -963,8 +963,10 @@ int lvm_run_command(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
/* each command should start out with sigint flag cleared */
|
/* each command should start out with sigint flag cleared */
|
||||||
sigint_clear();
|
sigint_clear();
|
||||||
|
|
||||||
if (!(cmd->cmd_line = _copy_command_line(cmd, argc, argv)))
|
if (!(cmd->cmd_line = _copy_command_line(cmd, argc, argv))) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
log_debug("Parsing: %s", cmd->cmd_line);
|
log_debug("Parsing: %s", cmd->cmd_line);
|
||||||
|
|
||||||
|
@ -26,8 +26,10 @@ static int lvremove_single(struct cmd_context *cmd, struct logical_volume *lv,
|
|||||||
if (lv_is_cow(lv) && lv_is_virtual_origin(origin = origin_from_cow(lv)))
|
if (lv_is_cow(lv) && lv_is_virtual_origin(origin = origin_from_cow(lv)))
|
||||||
lv = origin;
|
lv = origin;
|
||||||
|
|
||||||
if (!lv_remove_with_dependencies(cmd, lv, arg_count(cmd, force_ARG)))
|
if (!lv_remove_with_dependencies(cmd, lv, arg_count(cmd, force_ARG))) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
|
@ -105,6 +105,7 @@ int lvrename(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
vg = vg_read_for_update(cmd, vg_name, NULL, 0);
|
vg = vg_read_for_update(cmd, vg_name, NULL, 0);
|
||||||
if (vg_read_error(vg)) {
|
if (vg_read_error(vg)) {
|
||||||
vg_release(vg);
|
vg_release(vg);
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -185,8 +185,10 @@ static int _poll_vg(struct cmd_context *cmd, const char *vgname,
|
|||||||
const char *name;
|
const char *name;
|
||||||
int finished;
|
int finished;
|
||||||
|
|
||||||
if (vg_read_error(vg))
|
if (vg_read_error(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
dm_list_iterate_items(lvl, &vg->lvs) {
|
dm_list_iterate_items(lvl, &vg->lvs) {
|
||||||
lv_mirr = lvl->lv;
|
lv_mirr = lvl->lv;
|
||||||
@ -253,8 +255,10 @@ int poll_daemon(struct cmd_context *cmd, const char *name, const char *uuid,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (name) {
|
if (name) {
|
||||||
if (!_wait_for_single_mirror(cmd, name, uuid, &parms))
|
if (!_wait_for_single_mirror(cmd, name, uuid, &parms)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
} else
|
} else
|
||||||
_poll_for_all_vgs(cmd, &parms);
|
_poll_for_all_vgs(cmd, &parms);
|
||||||
|
|
||||||
|
@ -274,6 +274,7 @@ int pvchange(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
} else {
|
} else {
|
||||||
log_verbose("Scanning for physical volume names");
|
log_verbose("Scanning for physical volume names");
|
||||||
if (!(pvslist = get_pvs(cmd))) {
|
if (!(pvslist = get_pvs(cmd))) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -195,8 +195,10 @@ int pvcreate(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!pvcreate_single(cmd, argv[i], &pp))
|
if (!pvcreate_single(cmd, argv[i], &pp)) {
|
||||||
|
stack;
|
||||||
ret = ECMD_FAILED;
|
ret = ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
unlock_vg(cmd, VG_ORPHANS);
|
unlock_vg(cmd, VG_ORPHANS);
|
||||||
if (sigint_caught())
|
if (sigint_caught())
|
||||||
|
@ -176,8 +176,10 @@ static int _pvresize_single(struct cmd_context *cmd,
|
|||||||
|
|
||||||
params->total++;
|
params->total++;
|
||||||
|
|
||||||
if (!_pv_resize_single(cmd, vg, pv, params->new_size))
|
if (!_pv_resize_single(cmd, vg, pv, params->new_size)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
params->done++;
|
params->done++;
|
||||||
|
|
||||||
|
@ -135,6 +135,7 @@ int pvscan(struct cmd_context *cmd, int argc __attribute((unused)),
|
|||||||
log_verbose("Walking through all physical volumes");
|
log_verbose("Walking through all physical volumes");
|
||||||
if (!(pvslist = get_pvs(cmd))) {
|
if (!(pvslist = get_pvs(cmd))) {
|
||||||
unlock_vg(cmd, VG_GLOBAL);
|
unlock_vg(cmd, VG_GLOBAL);
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,11 +20,15 @@ static int _vgs_single(struct cmd_context *cmd __attribute((unused)),
|
|||||||
const char *vg_name, struct volume_group *vg,
|
const char *vg_name, struct volume_group *vg,
|
||||||
void *handle)
|
void *handle)
|
||||||
{
|
{
|
||||||
if (vg_read_error(vg))
|
if (vg_read_error(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!report_object(handle, vg, NULL, NULL, NULL, NULL))
|
if (!report_object(handle, vg, NULL, NULL, NULL, NULL)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
check_current_backup(vg);
|
check_current_backup(vg);
|
||||||
|
|
||||||
@ -37,8 +41,10 @@ static int _lvs_single(struct cmd_context *cmd, struct logical_volume *lv,
|
|||||||
if (!arg_count(cmd, all_ARG) && !lv_is_visible(lv))
|
if (!arg_count(cmd, all_ARG) && !lv_is_visible(lv))
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
|
|
||||||
if (!report_object(handle, lv->vg, lv, NULL, NULL, NULL))
|
if (!report_object(handle, lv->vg, lv, NULL, NULL, NULL)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
@ -46,8 +52,10 @@ static int _lvs_single(struct cmd_context *cmd, struct logical_volume *lv,
|
|||||||
static int _segs_single(struct cmd_context *cmd __attribute((unused)),
|
static int _segs_single(struct cmd_context *cmd __attribute((unused)),
|
||||||
struct lv_segment *seg, void *handle)
|
struct lv_segment *seg, void *handle)
|
||||||
{
|
{
|
||||||
if (!report_object(handle, seg->lv->vg, seg->lv, NULL, seg, NULL))
|
if (!report_object(handle, seg->lv->vg, seg->lv, NULL, seg, NULL)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
@ -102,8 +110,10 @@ static int _pvsegs_sub_single(struct cmd_context *cmd,
|
|||||||
dm_list_init(&_free_logical_volume.snapshot_segs);
|
dm_list_init(&_free_logical_volume.snapshot_segs);
|
||||||
|
|
||||||
if (!report_object(handle, vg, seg ? seg->lv : &_free_logical_volume, pvseg->pv,
|
if (!report_object(handle, vg, seg ? seg->lv : &_free_logical_volume, pvseg->pv,
|
||||||
seg ? : &_free_lv_segment, pvseg))
|
seg ? : &_free_lv_segment, pvseg)) {
|
||||||
|
stack;
|
||||||
ret = ECMD_FAILED;
|
ret = ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -155,8 +165,10 @@ static int _pvs_single(struct cmd_context *cmd, struct volume_group *vg,
|
|||||||
pv = pvl->pv;
|
pv = pvl->pv;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!report_object(handle, vg, NULL, pv, NULL, NULL))
|
if (!report_object(handle, vg, NULL, pv, NULL, NULL)) {
|
||||||
|
stack;
|
||||||
ret = ECMD_FAILED;
|
ret = ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
out:
|
out:
|
||||||
if (vg_name)
|
if (vg_name)
|
||||||
@ -171,8 +183,10 @@ out:
|
|||||||
static int _label_single(struct cmd_context *cmd, struct volume_group *vg,
|
static int _label_single(struct cmd_context *cmd, struct volume_group *vg,
|
||||||
struct physical_volume *pv, void *handle)
|
struct physical_volume *pv, void *handle)
|
||||||
{
|
{
|
||||||
if (!report_object(handle, vg, NULL, pv, NULL, NULL))
|
if (!report_object(handle, vg, NULL, pv, NULL, NULL)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
@ -181,8 +195,10 @@ static int _pvs_in_vg(struct cmd_context *cmd, const char *vg_name,
|
|||||||
struct volume_group *vg,
|
struct volume_group *vg,
|
||||||
void *handle)
|
void *handle)
|
||||||
{
|
{
|
||||||
if (vg_read_error(vg))
|
if (vg_read_error(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return process_each_pv_in_vg(cmd, vg, NULL, handle, &_pvs_single);
|
return process_each_pv_in_vg(cmd, vg, NULL, handle, &_pvs_single);
|
||||||
}
|
}
|
||||||
@ -191,8 +207,10 @@ static int _pvsegs_in_vg(struct cmd_context *cmd, const char *vg_name,
|
|||||||
struct volume_group *vg,
|
struct volume_group *vg,
|
||||||
void *handle)
|
void *handle)
|
||||||
{
|
{
|
||||||
if (vg_read_error(vg))
|
if (vg_read_error(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return process_each_pv_in_vg(cmd, vg, NULL, handle, &_pvsegs_single);
|
return process_each_pv_in_vg(cmd, vg, NULL, handle, &_pvsegs_single);
|
||||||
}
|
}
|
||||||
|
@ -293,7 +293,8 @@ int process_each_lv(struct cmd_context *cmd, int argc, char **argv,
|
|||||||
if (ret_max < ECMD_FAILED) {
|
if (ret_max < ECMD_FAILED) {
|
||||||
log_error("Skipping volume group %s", vgname);
|
log_error("Skipping volume group %s", vgname);
|
||||||
ret_max = ECMD_FAILED;
|
ret_max = ECMD_FAILED;
|
||||||
}
|
} else
|
||||||
|
stack;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -431,9 +432,10 @@ static int _process_one_vg(struct cmd_context *cmd, const char *vg_name,
|
|||||||
log_verbose("Finding volume group \"%s\"", vg_name);
|
log_verbose("Finding volume group \"%s\"", vg_name);
|
||||||
|
|
||||||
vg = vg_read(cmd, vg_name, vgid, flags);
|
vg = vg_read(cmd, vg_name, vgid, flags);
|
||||||
if (vg_read_error(vg) == FAILED_ALLOCATION ||
|
/* Allow FAILED_INCONSISTENT through only for vgcfgrestore */
|
||||||
vg_read_error(vg) == FAILED_NOTFOUND) {
|
if (vg_read_error(vg) && (vg_read_error(vg) != FAILED_INCONSISTENT)) {
|
||||||
vg_release(vg);
|
vg_release(vg);
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -445,9 +447,8 @@ static int _process_one_vg(struct cmd_context *cmd, const char *vg_name,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ((ret = process_single(cmd, vg_name, vg,
|
if ((ret = process_single(cmd, vg_name, vg,
|
||||||
handle)) > ret_max) {
|
handle)) > ret_max)
|
||||||
ret_max = ret;
|
ret_max = ret;
|
||||||
}
|
|
||||||
|
|
||||||
out:
|
out:
|
||||||
unlock_and_release_vg(cmd, vg, vg_name);
|
unlock_and_release_vg(cmd, vg, vg_name);
|
||||||
@ -728,6 +729,7 @@ int process_each_pv(struct cmd_context *cmd, int argc, char **argv,
|
|||||||
if (vg_read_error(vg)) {
|
if (vg_read_error(vg)) {
|
||||||
ret_max = ECMD_FAILED;
|
ret_max = ECMD_FAILED;
|
||||||
vg_release(vg);
|
vg_release(vg);
|
||||||
|
stack;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -54,9 +54,6 @@ static int vg_backup_single(struct cmd_context *cmd, const char *vg_name,
|
|||||||
char **last_filename = (char **)handle;
|
char **last_filename = (char **)handle;
|
||||||
char *filename;
|
char *filename;
|
||||||
|
|
||||||
if (vg_read_error(vg) && (vg_read_error(vg) != FAILED_INCONSISTENT))
|
|
||||||
return ECMD_FAILED;
|
|
||||||
|
|
||||||
if (arg_count(cmd, file_ARG)) {
|
if (arg_count(cmd, file_ARG)) {
|
||||||
if (!(filename = _expand_filename(arg_value(cmd, file_ARG),
|
if (!(filename = _expand_filename(arg_value(cmd, file_ARG),
|
||||||
vg->name, last_filename))) {
|
vg->name, last_filename))) {
|
||||||
@ -64,8 +61,10 @@ static int vg_backup_single(struct cmd_context *cmd, const char *vg_name,
|
|||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!backup_to_file(filename, vg->cmd->cmd_line, vg))
|
if (!backup_to_file(filename, vg->cmd->cmd_line, vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (vg_read_error(vg) == FAILED_INCONSISTENT) {
|
if (vg_read_error(vg) == FAILED_INCONSISTENT) {
|
||||||
log_error("No backup taken: specify filename with -f "
|
log_error("No backup taken: specify filename with -f "
|
||||||
|
@ -38,8 +38,10 @@ int vgcfgrestore(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
if (!(arg_count(cmd,file_ARG) ?
|
if (!(arg_count(cmd,file_ARG) ?
|
||||||
archive_display_file(cmd,
|
archive_display_file(cmd,
|
||||||
arg_str_value(cmd, file_ARG, "")) :
|
arg_str_value(cmd, file_ARG, "")) :
|
||||||
archive_display(cmd, vg_name)))
|
archive_display(cmd, vg_name))) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -179,8 +179,10 @@ static int _vgchange_alloc(struct cmd_context *cmd, struct volume_group *vg)
|
|||||||
|
|
||||||
alloc = arg_uint_value(cmd, alloc_ARG, ALLOC_NORMAL);
|
alloc = arg_uint_value(cmd, alloc_ARG, ALLOC_NORMAL);
|
||||||
|
|
||||||
if (!archive(vg))
|
if (!archive(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
/* FIXME: make consistent with vg_set_alloc_policy() */
|
/* FIXME: make consistent with vg_set_alloc_policy() */
|
||||||
if (alloc == vg->alloc) {
|
if (alloc == vg->alloc) {
|
||||||
@ -188,11 +190,15 @@ static int _vgchange_alloc(struct cmd_context *cmd, struct volume_group *vg)
|
|||||||
get_alloc_string(vg->alloc));
|
get_alloc_string(vg->alloc));
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
if (!vg_set_alloc_policy(vg, alloc))
|
if (!vg_set_alloc_policy(vg, alloc)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!vg_write(vg) || !vg_commit(vg))
|
if (!vg_write(vg) || !vg_commit(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
backup(vg);
|
backup(vg);
|
||||||
|
|
||||||
@ -218,16 +224,20 @@ static int _vgchange_resizeable(struct cmd_context *cmd,
|
|||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!archive(vg))
|
if (!archive(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (resizeable)
|
if (resizeable)
|
||||||
vg->status |= RESIZEABLE_VG;
|
vg->status |= RESIZEABLE_VG;
|
||||||
else
|
else
|
||||||
vg->status &= ~RESIZEABLE_VG;
|
vg->status &= ~RESIZEABLE_VG;
|
||||||
|
|
||||||
if (!vg_write(vg) || !vg_commit(vg))
|
if (!vg_write(vg) || !vg_commit(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
backup(vg);
|
backup(vg);
|
||||||
|
|
||||||
@ -265,16 +275,20 @@ static int _vgchange_clustered(struct cmd_context *cmd,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!archive(vg))
|
if (!archive(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (clustered)
|
if (clustered)
|
||||||
vg->status |= CLUSTERED;
|
vg->status |= CLUSTERED;
|
||||||
else
|
else
|
||||||
vg->status &= ~CLUSTERED;
|
vg->status &= ~CLUSTERED;
|
||||||
|
|
||||||
if (!vg_write(vg) || !vg_commit(vg))
|
if (!vg_write(vg) || !vg_commit(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
backup(vg);
|
backup(vg);
|
||||||
|
|
||||||
@ -288,14 +302,20 @@ static int _vgchange_logicalvolume(struct cmd_context *cmd,
|
|||||||
{
|
{
|
||||||
uint32_t max_lv = arg_uint_value(cmd, logicalvolume_ARG, 0);
|
uint32_t max_lv = arg_uint_value(cmd, logicalvolume_ARG, 0);
|
||||||
|
|
||||||
if (!archive(vg))
|
if (!archive(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!vg_set_max_lv(vg, max_lv))
|
if (!vg_set_max_lv(vg, max_lv)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!vg_write(vg) || !vg_commit(vg))
|
if (!vg_write(vg) || !vg_commit(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
backup(vg);
|
backup(vg);
|
||||||
|
|
||||||
@ -314,14 +334,20 @@ static int _vgchange_physicalvolumes(struct cmd_context *cmd,
|
|||||||
return EINVALID_CMD_LINE;
|
return EINVALID_CMD_LINE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!archive(vg))
|
if (!archive(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!vg_set_max_pv(vg, max_pv))
|
if (!vg_set_max_pv(vg, max_pv)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!vg_write(vg) || !vg_commit(vg))
|
if (!vg_write(vg) || !vg_commit(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
backup(vg);
|
backup(vg);
|
||||||
|
|
||||||
@ -347,16 +373,20 @@ static int _vgchange_pesize(struct cmd_context *cmd, struct volume_group *vg)
|
|||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!archive(vg))
|
if (!archive(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!vg_set_extent_size(vg, extent_size)) {
|
if (!vg_set_extent_size(vg, extent_size)) {
|
||||||
stack;
|
stack;
|
||||||
return EINVALID_CMD_LINE;
|
return EINVALID_CMD_LINE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!vg_write(vg) || !vg_commit(vg))
|
if (!vg_write(vg) || !vg_commit(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
backup(vg);
|
backup(vg);
|
||||||
|
|
||||||
@ -380,8 +410,10 @@ static int _vgchange_tag(struct cmd_context *cmd, struct volume_group *vg,
|
|||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!archive(vg))
|
if (!archive(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if ((arg == addtag_ARG)) {
|
if ((arg == addtag_ARG)) {
|
||||||
if (!str_list_add(cmd->mem, &vg->tags, tag)) {
|
if (!str_list_add(cmd->mem, &vg->tags, tag)) {
|
||||||
@ -397,8 +429,10 @@ static int _vgchange_tag(struct cmd_context *cmd, struct volume_group *vg,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!vg_write(vg) || !vg_commit(vg))
|
if (!vg_write(vg) || !vg_commit(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
backup(vg);
|
backup(vg);
|
||||||
|
|
||||||
@ -417,8 +451,10 @@ static int _vgchange_uuid(struct cmd_context *cmd __attribute((unused)),
|
|||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!archive(vg))
|
if (!archive(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!id_create(&vg->id)) {
|
if (!id_create(&vg->id)) {
|
||||||
log_error("Failed to generate new random UUID for VG %s.",
|
log_error("Failed to generate new random UUID for VG %s.",
|
||||||
@ -430,8 +466,10 @@ static int _vgchange_uuid(struct cmd_context *cmd __attribute((unused)),
|
|||||||
memcpy(&lvl->lv->lvid, &vg->id, sizeof(vg->id));
|
memcpy(&lvl->lv->lvid, &vg->id, sizeof(vg->id));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!vg_write(vg) || !vg_commit(vg))
|
if (!vg_write(vg) || !vg_commit(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
backup(vg);
|
backup(vg);
|
||||||
|
|
||||||
@ -444,8 +482,10 @@ static int _vgchange_refresh(struct cmd_context *cmd, struct volume_group *vg)
|
|||||||
{
|
{
|
||||||
log_verbose("Refreshing volume group \"%s\"", vg->name);
|
log_verbose("Refreshing volume group \"%s\"", vg->name);
|
||||||
|
|
||||||
if (!vg_refresh_visible(cmd, vg))
|
if (!vg_refresh_visible(cmd, vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
@ -456,8 +496,10 @@ static int vgchange_single(struct cmd_context *cmd, const char *vg_name,
|
|||||||
{
|
{
|
||||||
int r = ECMD_FAILED;
|
int r = ECMD_FAILED;
|
||||||
|
|
||||||
if (vg_read_error(vg))
|
if (vg_read_error(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (vg_is_exported(vg)) {
|
if (vg_is_exported(vg)) {
|
||||||
log_error("Volume group \"%s\" is exported", vg_name);
|
log_error("Volume group \"%s\" is exported", vg_name);
|
||||||
|
12
tools/vgck.c
12
tools/vgck.c
@ -21,14 +21,20 @@ static int vgck_single(struct cmd_context *cmd __attribute((unused)),
|
|||||||
struct volume_group *vg,
|
struct volume_group *vg,
|
||||||
void *handle __attribute((unused)))
|
void *handle __attribute((unused)))
|
||||||
{
|
{
|
||||||
if (vg_read_error(vg))
|
if (vg_read_error(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!vg_check_status(vg, EXPORTED_VG))
|
if (!vg_check_status(vg, EXPORTED_VG)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!vg_validate(vg))
|
if (!vg_validate(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
|
@ -32,11 +32,15 @@ static int vgconvert_single(struct cmd_context *cmd, const char *vg_name,
|
|||||||
struct lvinfo info;
|
struct lvinfo info;
|
||||||
int active = 0;
|
int active = 0;
|
||||||
|
|
||||||
if (vg_read_error(vg))
|
if (vg_read_error(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!vg_check_status(vg, LVM_WRITE | EXPORTED_VG))
|
if (!vg_check_status(vg, LVM_WRITE | EXPORTED_VG)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (vg->fid->fmt == cmd->fmt) {
|
if (vg->fid->fmt == cmd->fmt) {
|
||||||
log_error("Volume group \"%s\" already uses format %s",
|
log_error("Volume group \"%s\" already uses format %s",
|
||||||
@ -111,8 +115,10 @@ static int vgconvert_single(struct cmd_context *cmd, const char *vg_name,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (active)
|
if (active) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
dm_list_iterate_items(pvl, &vg->pvs) {
|
dm_list_iterate_items(pvl, &vg->pvs) {
|
||||||
existing_pv = pvl->pv;
|
existing_pv = pvl->pv;
|
||||||
|
@ -102,14 +102,12 @@ int vgcreate(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
clustered_message = "Non-clustered ";
|
clustered_message = "Non-clustered ";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!archive(vg)) {
|
if (!archive(vg))
|
||||||
goto bad;
|
goto_bad;
|
||||||
}
|
|
||||||
|
|
||||||
/* Store VG on disk(s) */
|
/* Store VG on disk(s) */
|
||||||
if (!vg_write(vg) || !vg_commit(vg)) {
|
if (!vg_write(vg) || !vg_commit(vg))
|
||||||
goto bad;
|
goto_bad;
|
||||||
}
|
|
||||||
|
|
||||||
unlock_vg(cmd, VG_ORPHANS);
|
unlock_vg(cmd, VG_ORPHANS);
|
||||||
unlock_vg(cmd, vp_new.vg_name);
|
unlock_vg(cmd, vp_new.vg_name);
|
||||||
|
@ -20,8 +20,10 @@ static int vgdisplay_single(struct cmd_context *cmd, const char *vg_name,
|
|||||||
void *handle __attribute((unused)))
|
void *handle __attribute((unused)))
|
||||||
{
|
{
|
||||||
/* FIXME Do the active check here if activevolumegroups_ARG ? */
|
/* FIXME Do the active check here if activevolumegroups_ARG ? */
|
||||||
if (vg_read_error(vg))
|
if (vg_read_error(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
vg_check_status(vg, EXPORTED_VG);
|
vg_check_status(vg, EXPORTED_VG);
|
||||||
|
|
||||||
|
@ -24,16 +24,16 @@ static int vgexport_single(struct cmd_context *cmd __attribute((unused)),
|
|||||||
struct physical_volume *pv;
|
struct physical_volume *pv;
|
||||||
|
|
||||||
if (vg_read_error(vg))
|
if (vg_read_error(vg))
|
||||||
goto error;
|
goto_bad;
|
||||||
|
|
||||||
if (lvs_in_vg_activated(vg)) {
|
if (lvs_in_vg_activated(vg)) {
|
||||||
log_error("Volume group \"%s\" has active logical volumes",
|
log_error("Volume group \"%s\" has active logical volumes",
|
||||||
vg_name);
|
vg_name);
|
||||||
goto error;
|
goto bad;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!archive(vg))
|
if (!archive(vg))
|
||||||
goto error;
|
goto_bad;
|
||||||
|
|
||||||
vg->status |= EXPORTED_VG;
|
vg->status |= EXPORTED_VG;
|
||||||
|
|
||||||
@ -43,7 +43,7 @@ static int vgexport_single(struct cmd_context *cmd __attribute((unused)),
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!vg_write(vg) || !vg_commit(vg))
|
if (!vg_write(vg) || !vg_commit(vg))
|
||||||
goto error;
|
goto_bad;
|
||||||
|
|
||||||
backup(vg);
|
backup(vg);
|
||||||
|
|
||||||
@ -51,7 +51,7 @@ static int vgexport_single(struct cmd_context *cmd __attribute((unused)),
|
|||||||
|
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
|
|
||||||
error:
|
bad:
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,6 +40,7 @@ int vgextend(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
vg = vg_read_for_update(cmd, vg_name, NULL, 0);
|
vg = vg_read_for_update(cmd, vg_name, NULL, 0);
|
||||||
if (vg_read_error(vg)) {
|
if (vg_read_error(vg)) {
|
||||||
vg_release(vg);
|
vg_release(vg);
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -50,11 +51,11 @@ int vgextend(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!archive(vg))
|
if (!archive(vg))
|
||||||
goto error;
|
goto_bad;
|
||||||
|
|
||||||
/* extend vg */
|
/* extend vg */
|
||||||
if (!vg_extend(vg, argc, argv))
|
if (!vg_extend(vg, argc, argv))
|
||||||
goto error;
|
goto_bad;
|
||||||
|
|
||||||
/* ret > 0 */
|
/* ret > 0 */
|
||||||
log_verbose("Volume group \"%s\" will be extended by %d new "
|
log_verbose("Volume group \"%s\" will be extended by %d new "
|
||||||
@ -62,13 +63,13 @@ int vgextend(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
|
|
||||||
/* store vg on disk(s) */
|
/* store vg on disk(s) */
|
||||||
if (!vg_write(vg) || !vg_commit(vg))
|
if (!vg_write(vg) || !vg_commit(vg))
|
||||||
goto error;
|
goto_bad;
|
||||||
|
|
||||||
backup(vg);
|
backup(vg);
|
||||||
log_print("Volume group \"%s\" successfully extended", vg_name);
|
log_print("Volume group \"%s\" successfully extended", vg_name);
|
||||||
r = ECMD_PROCESSED;
|
r = ECMD_PROCESSED;
|
||||||
|
|
||||||
error:
|
bad:
|
||||||
unlock_vg(cmd, VG_ORPHANS);
|
unlock_vg(cmd, VG_ORPHANS);
|
||||||
unlock_and_release_vg(cmd, vg, vg_name);
|
unlock_and_release_vg(cmd, vg, vg_name);
|
||||||
return r;
|
return r;
|
||||||
|
@ -24,20 +24,20 @@ static int vgimport_single(struct cmd_context *cmd __attribute((unused)),
|
|||||||
struct physical_volume *pv;
|
struct physical_volume *pv;
|
||||||
|
|
||||||
if (vg_read_error(vg))
|
if (vg_read_error(vg))
|
||||||
goto error;
|
goto_bad;
|
||||||
|
|
||||||
if (!vg_is_exported(vg)) {
|
if (!vg_is_exported(vg)) {
|
||||||
log_error("Volume group \"%s\" is not exported", vg_name);
|
log_error("Volume group \"%s\" is not exported", vg_name);
|
||||||
goto error;
|
goto bad;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (vg_status(vg) & PARTIAL_VG) {
|
if (vg_status(vg) & PARTIAL_VG) {
|
||||||
log_error("Volume group \"%s\" is partially missing", vg_name);
|
log_error("Volume group \"%s\" is partially missing", vg_name);
|
||||||
goto error;
|
goto bad;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!archive(vg))
|
if (!archive(vg))
|
||||||
goto error;
|
goto_bad;
|
||||||
|
|
||||||
vg->status &= ~EXPORTED_VG;
|
vg->status &= ~EXPORTED_VG;
|
||||||
|
|
||||||
@ -47,7 +47,7 @@ static int vgimport_single(struct cmd_context *cmd __attribute((unused)),
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!vg_write(vg) || !vg_commit(vg))
|
if (!vg_write(vg) || !vg_commit(vg))
|
||||||
goto error;
|
goto_bad;
|
||||||
|
|
||||||
backup(vg);
|
backup(vg);
|
||||||
|
|
||||||
@ -55,7 +55,7 @@ static int vgimport_single(struct cmd_context *cmd __attribute((unused)),
|
|||||||
|
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
|
|
||||||
error:
|
bad:
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -46,20 +46,26 @@ static int _vgmerge_single(struct cmd_context *cmd, const char *vg_name_to,
|
|||||||
|
|
||||||
if (lock_vg_from_first) {
|
if (lock_vg_from_first) {
|
||||||
vg_from = _vgmerge_vg_read(cmd, vg_name_from);
|
vg_from = _vgmerge_vg_read(cmd, vg_name_from);
|
||||||
if (!vg_from)
|
if (!vg_from) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
vg_to = _vgmerge_vg_read(cmd, vg_name_to);
|
vg_to = _vgmerge_vg_read(cmd, vg_name_to);
|
||||||
if (!vg_to) {
|
if (!vg_to) {
|
||||||
|
stack;
|
||||||
unlock_and_release_vg(cmd, vg_from, vg_name_from);
|
unlock_and_release_vg(cmd, vg_from, vg_name_from);
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
vg_to = _vgmerge_vg_read(cmd, vg_name_to);
|
vg_to = _vgmerge_vg_read(cmd, vg_name_to);
|
||||||
if (!vg_to)
|
if (!vg_to) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
vg_from = _vgmerge_vg_read(cmd, vg_name_from);
|
vg_from = _vgmerge_vg_read(cmd, vg_name_from);
|
||||||
if (!vg_from) {
|
if (!vg_from) {
|
||||||
|
stack;
|
||||||
unlock_and_release_vg(cmd, vg_to, vg_name_to);
|
unlock_and_release_vg(cmd, vg_to, vg_name_to);
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
@ -19,19 +19,25 @@ static int _vgmknodes_single(struct cmd_context *cmd, struct logical_volume *lv,
|
|||||||
void *handle __attribute((unused)))
|
void *handle __attribute((unused)))
|
||||||
{
|
{
|
||||||
if (arg_count(cmd, refresh_ARG) && lv_is_visible(lv))
|
if (arg_count(cmd, refresh_ARG) && lv_is_visible(lv))
|
||||||
if (!lv_refresh(cmd, lv))
|
if (!lv_refresh(cmd, lv)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!lv_mknodes(cmd, lv))
|
if (!lv_mknodes(cmd, lv)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
|
|
||||||
int vgmknodes(struct cmd_context *cmd, int argc, char **argv)
|
int vgmknodes(struct cmd_context *cmd, int argc, char **argv)
|
||||||
{
|
{
|
||||||
if (!lv_mknodes(cmd, NULL))
|
if (!lv_mknodes(cmd, NULL)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return process_each_lv(cmd, argc, argv, LCK_VG_READ, NULL,
|
return process_each_lv(cmd, argc, argv, LCK_VG_READ, NULL,
|
||||||
&_vgmknodes_single);
|
&_vgmknodes_single);
|
||||||
|
@ -404,7 +404,7 @@ static int _vgreduce_single(struct cmd_context *cmd, struct volume_group *vg,
|
|||||||
pvl = find_pv_in_vg(vg, name);
|
pvl = find_pv_in_vg(vg, name);
|
||||||
|
|
||||||
if (!archive(vg))
|
if (!archive(vg))
|
||||||
goto bad;
|
goto_bad;
|
||||||
|
|
||||||
log_verbose("Removing \"%s\" from volume group \"%s\"", name, vg->name);
|
log_verbose("Removing \"%s\" from volume group \"%s\"", name, vg->name);
|
||||||
|
|
||||||
@ -512,12 +512,12 @@ int vgreduce(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
vg = vg_read_for_update(cmd, vg_name, NULL, READ_ALLOW_EXPORTED);
|
vg = vg_read_for_update(cmd, vg_name, NULL, READ_ALLOW_EXPORTED);
|
||||||
if (vg_read_error(vg) == FAILED_ALLOCATION ||
|
if (vg_read_error(vg) == FAILED_ALLOCATION ||
|
||||||
vg_read_error(vg) == FAILED_NOTFOUND)
|
vg_read_error(vg) == FAILED_NOTFOUND)
|
||||||
goto out;
|
goto_out;
|
||||||
|
|
||||||
/* FIXME We want to allow read-only VGs to be changed here? */
|
/* FIXME We want to allow read-only VGs to be changed here? */
|
||||||
if (vg_read_error(vg) && vg_read_error(vg) != FAILED_READ_ONLY
|
if (vg_read_error(vg) && vg_read_error(vg) != FAILED_READ_ONLY
|
||||||
&& !arg_count(cmd, removemissing_ARG))
|
&& !arg_count(cmd, removemissing_ARG))
|
||||||
goto out;
|
goto_out;
|
||||||
|
|
||||||
if (repairing) {
|
if (repairing) {
|
||||||
if (!vg_read_error(vg) && !vg_missing_pv_count(vg)) {
|
if (!vg_read_error(vg) && !vg_missing_pv_count(vg)) {
|
||||||
@ -536,14 +536,14 @@ int vgreduce(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
|
|
||||||
if (vg_read_error(vg) && vg_read_error(vg) != FAILED_READ_ONLY
|
if (vg_read_error(vg) && vg_read_error(vg) != FAILED_READ_ONLY
|
||||||
&& vg_read_error(vg) != FAILED_INCONSISTENT)
|
&& vg_read_error(vg) != FAILED_INCONSISTENT)
|
||||||
goto out;
|
goto_out;
|
||||||
|
|
||||||
if (!archive(vg))
|
if (!archive(vg))
|
||||||
goto out;
|
goto_out;
|
||||||
|
|
||||||
if (arg_count(cmd, force_ARG)) {
|
if (arg_count(cmd, force_ARG)) {
|
||||||
if (!_make_vg_consistent(cmd, vg))
|
if (!_make_vg_consistent(cmd, vg))
|
||||||
goto out;
|
goto_out;
|
||||||
} else
|
} else
|
||||||
fixed = _consolidate_vg(cmd, vg);
|
fixed = _consolidate_vg(cmd, vg);
|
||||||
|
|
||||||
@ -563,7 +563,7 @@ int vgreduce(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (!vg_check_status(vg, EXPORTED_VG | LVM_WRITE | RESIZEABLE_VG))
|
if (!vg_check_status(vg, EXPORTED_VG | LVM_WRITE | RESIZEABLE_VG))
|
||||||
goto out;
|
goto_out;
|
||||||
|
|
||||||
/* FIXME: Pass private struct through to all these functions */
|
/* FIXME: Pass private struct through to all these functions */
|
||||||
/* and update in batch here? */
|
/* and update in batch here? */
|
||||||
|
@ -22,11 +22,15 @@ static int vgremove_single(struct cmd_context *cmd, const char *vg_name,
|
|||||||
unsigned lv_count;
|
unsigned lv_count;
|
||||||
force_t force;
|
force_t force;
|
||||||
|
|
||||||
if (vg_read_error(vg))
|
if (vg_read_error(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
if (!vg_check_status(vg, EXPORTED_VG))
|
if (!vg_check_status(vg, EXPORTED_VG)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
lv_count = vg_visible_lvs(vg);
|
lv_count = vg_visible_lvs(vg);
|
||||||
|
|
||||||
@ -40,15 +44,21 @@ static int vgremove_single(struct cmd_context *cmd, const char *vg_name,
|
|||||||
log_print("Volume group \"%s\" not removed", vg_name);
|
log_print("Volume group \"%s\" not removed", vg_name);
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
if (!remove_lvs_in_vg(cmd, vg, force))
|
if (!remove_lvs_in_vg(cmd, vg, force)) {
|
||||||
|
stack;
|
||||||
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!vg_remove_check(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!vg_remove_check(vg))
|
if (!vg_remove(vg)) {
|
||||||
return ECMD_FAILED;
|
stack;
|
||||||
|
|
||||||
if (!vg_remove(vg))
|
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
|
@ -206,8 +206,10 @@ int vgrename(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
return EINVALID_CMD_LINE;
|
return EINVALID_CMD_LINE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!vg_rename_path(cmd, argv[0], argv[1]))
|
if (!vg_rename_path(cmd, argv[0], argv[1])) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
return ECMD_PROCESSED;
|
return ECMD_PROCESSED;
|
||||||
}
|
}
|
||||||
|
@ -19,8 +19,10 @@ static int vgscan_single(struct cmd_context *cmd, const char *vg_name,
|
|||||||
struct volume_group *vg,
|
struct volume_group *vg,
|
||||||
void *handle __attribute((unused)))
|
void *handle __attribute((unused)))
|
||||||
{
|
{
|
||||||
if (vg_read_error(vg))
|
if (vg_read_error(vg)) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
log_print("Found %svolume group \"%s\" using metadata type %s",
|
log_print("Found %svolume group \"%s\" using metadata type %s",
|
||||||
vg_is_exported(vg) ? "exported " : "", vg_name,
|
vg_is_exported(vg) ? "exported " : "", vg_name,
|
||||||
|
@ -319,8 +319,10 @@ int vgsplit(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
|
|
||||||
if (lock_vg_from_first) {
|
if (lock_vg_from_first) {
|
||||||
vg_from = _vgsplit_from(cmd, vg_name_from);
|
vg_from = _vgsplit_from(cmd, vg_name_from);
|
||||||
if (!vg_from)
|
if (!vg_from) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
/*
|
/*
|
||||||
* Set metadata format of original VG.
|
* Set metadata format of original VG.
|
||||||
* NOTE: We must set the format before calling vg_create()
|
* NOTE: We must set the format before calling vg_create()
|
||||||
@ -331,15 +333,19 @@ int vgsplit(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
vg_to = _vgsplit_to(cmd, vg_name_to, &existing_vg);
|
vg_to = _vgsplit_to(cmd, vg_name_to, &existing_vg);
|
||||||
if (!vg_to) {
|
if (!vg_to) {
|
||||||
unlock_and_release_vg(cmd, vg_from, vg_name_from);
|
unlock_and_release_vg(cmd, vg_from, vg_name_from);
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
vg_to = _vgsplit_to(cmd, vg_name_to, &existing_vg);
|
vg_to = _vgsplit_to(cmd, vg_name_to, &existing_vg);
|
||||||
if (!vg_to)
|
if (!vg_to) {
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
|
}
|
||||||
vg_from = _vgsplit_from(cmd, vg_name_from);
|
vg_from = _vgsplit_from(cmd, vg_name_from);
|
||||||
if (!vg_from) {
|
if (!vg_from) {
|
||||||
unlock_and_release_vg(cmd, vg_to, vg_name_to);
|
unlock_and_release_vg(cmd, vg_to, vg_name_to);
|
||||||
|
stack;
|
||||||
return ECMD_FAILED;
|
return ECMD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -355,7 +361,7 @@ int vgsplit(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
if (new_vg_option_specified(cmd)) {
|
if (new_vg_option_specified(cmd)) {
|
||||||
log_error("Volume group \"%s\" exists, but new VG "
|
log_error("Volume group \"%s\" exists, but new VG "
|
||||||
"option specified", vg_name_to);
|
"option specified", vg_name_to);
|
||||||
goto_bad;
|
goto bad;
|
||||||
}
|
}
|
||||||
if (!vgs_are_compatible(cmd, vg_from,vg_to))
|
if (!vgs_are_compatible(cmd, vg_from,vg_to))
|
||||||
goto_bad;
|
goto_bad;
|
||||||
@ -369,12 +375,12 @@ int vgsplit(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
|
|
||||||
if (fill_vg_create_params(cmd, vg_name_to, &vp_new, &vp_def)) {
|
if (fill_vg_create_params(cmd, vg_name_to, &vp_new, &vp_def)) {
|
||||||
r = EINVALID_CMD_LINE;
|
r = EINVALID_CMD_LINE;
|
||||||
goto bad;
|
goto_bad;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (validate_vg_create_params(cmd, &vp_new)) {
|
if (validate_vg_create_params(cmd, &vp_new)) {
|
||||||
r = EINVALID_CMD_LINE;
|
r = EINVALID_CMD_LINE;
|
||||||
goto bad;
|
goto_bad;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!vg_set_extent_size(vg_to, vp_new.extent_size) ||
|
if (!vg_set_extent_size(vg_to, vp_new.extent_size) ||
|
||||||
@ -416,7 +422,7 @@ int vgsplit(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
/* Split metadata areas and check if both vgs have at least one area */
|
/* Split metadata areas and check if both vgs have at least one area */
|
||||||
if (!(vg_split_mdas(cmd, vg_from, vg_to)) && vg_from->pv_count) {
|
if (!(vg_split_mdas(cmd, vg_from, vg_to)) && vg_from->pv_count) {
|
||||||
log_error("Cannot split: Nowhere to store metadata for new Volume Group");
|
log_error("Cannot split: Nowhere to store metadata for new Volume Group");
|
||||||
goto_bad;
|
goto bad;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Set proper name for all PVs in new VG */
|
/* Set proper name for all PVs in new VG */
|
||||||
@ -465,7 +471,7 @@ int vgsplit(struct cmd_context *cmd, int argc, char **argv)
|
|||||||
if (vg_read_error(vg_to)) {
|
if (vg_read_error(vg_to)) {
|
||||||
log_error("Volume group \"%s\" became inconsistent: "
|
log_error("Volume group \"%s\" became inconsistent: "
|
||||||
"please fix manually", vg_name_to);
|
"please fix manually", vg_name_to);
|
||||||
goto_bad;
|
goto bad;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user