summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlasdair G Kergon <agk@redhat.com>2015-03-09 18:56:24 +0000
committerAlasdair G Kergon <agk@redhat.com>2015-03-09 18:56:24 +0000
commita8545462349c560cf66362cb3d25b44b7b0e819b (patch)
tree84c3dec9fd7b757c7e4784b3e30949474308e744
parentfaccdeda83ee8c04546a2224fa2dee82a55413fe (diff)
downloadlvm2-a8545462349c560cf66362cb3d25b44b7b0e819b.tar.gz
metadata: Detect internal use of LVM_WRITE_LOCKED.
Generate internal error if LVM_WRITE_LOCKED ever appears in struct volume_group: it's only used in external metadata.
-rw-r--r--lib/metadata/metadata.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/lib/metadata/metadata.c b/lib/metadata/metadata.c
index ab23d257c..21066fb37 100644
--- a/lib/metadata/metadata.c
+++ b/lib/metadata/metadata.c
@@ -2495,6 +2495,12 @@ int vg_validate(struct volume_group *vg)
r = 0;
}
+ if (vg->status & LVM_WRITE_LOCKED) {
+ log_error(INTERNAL_ERROR "VG %s has external flag LVM_WRITE_LOCKED set internally.",
+ vg->name);
+ r = 0;
+ }
+
/* FIXME Also check there's no data/metadata overlap */
if (!(vhash.pvid = dm_hash_create(vg->pv_count))) {
log_error("Failed to allocate pvid hash.");
@@ -2568,6 +2574,12 @@ int vg_validate(struct volume_group *vg)
dm_list_iterate_items(lvl, &vg->lvs) {
lv_count++;
+ if (lvl->lv->status & LVM_WRITE_LOCKED) {
+ log_error(INTERNAL_ERROR "LV %s has external flag LVM_WRITE_LOCKED set internally.",
+ vg->name);
+ r = 0;
+ }
+
dev_name_len = strlen(lvl->lv->name) + vg_name_len + 3;
if (dev_name_len >= NAME_LEN) {
log_error(INTERNAL_ERROR "LV name \"%s/%s\" length %"