1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-03 05:18:29 +03:00

Revert "systemid: Add ACCESS_NEEDS_SYSTEM_ID VG flag."

This reverts commit bfbb5d269a.

This will be done differently.
This commit is contained in:
David Teigland 2015-03-04 11:11:10 -06:00
parent 06b408ecce
commit c6a57dc4f3
7 changed files with 11 additions and 28 deletions

View File

@ -501,8 +501,6 @@ static int _format1_vg_setup(struct format_instance *fid, struct volume_group *v
!generate_lvm1_system_id(vg->cmd, vg->lvm1_system_id, "")) !generate_lvm1_system_id(vg->cmd, vg->lvm1_system_id, ""))
return_0; return_0;
vg->status &= ~ACCESS_NEEDS_SYSTEM_ID;
return 1; return 1;
} }

View File

@ -69,10 +69,8 @@ int import_pv(const struct format_type *fmt, struct dm_pool *mem,
memcpy(&pv->vgid, vgd->vg_uuid, sizeof(vg->id)); memcpy(&pv->vgid, vgd->vg_uuid, sizeof(vg->id));
/* Store system_id from first PV if PV belongs to a VG */ /* Store system_id from first PV if PV belongs to a VG */
if (vg && !*vg->lvm1_system_id) { if (vg && !*vg->lvm1_system_id)
strncpy(vg->lvm1_system_id, (char *)pvd->system_id, NAME_LEN); strncpy(vg->lvm1_system_id, (char *)pvd->system_id, NAME_LEN);
vg->status &= ~ACCESS_NEEDS_SYSTEM_ID;
}
if (vg && if (vg &&
strncmp(vg->lvm1_system_id, (char *)pvd->system_id, sizeof(pvd->system_id))) strncmp(vg->lvm1_system_id, (char *)pvd->system_id, sizeof(pvd->system_id)))

View File

@ -36,7 +36,6 @@ static const struct flag _vg_flags[] = {
{LVM_WRITE, "WRITE", STATUS_FLAG}, {LVM_WRITE, "WRITE", STATUS_FLAG},
{CLUSTERED, "CLUSTERED", STATUS_FLAG}, {CLUSTERED, "CLUSTERED", STATUS_FLAG},
{SHARED, "SHARED", STATUS_FLAG}, {SHARED, "SHARED", STATUS_FLAG},
{ACCESS_NEEDS_SYSTEM_ID, "ACCESS_NEEDS_SYSTEM_ID", STATUS_FLAG},
{PARTIAL_VG, NULL, 0}, {PARTIAL_VG, NULL, 0},
{PRECOMMITTED, NULL, 0}, {PRECOMMITTED, NULL, 0},
{ARCHIVED_VG, NULL, 0}, {ARCHIVED_VG, NULL, 0},

View File

@ -733,10 +733,11 @@ static struct volume_group *_read_vg(struct format_instance *fid,
{ {
const struct dm_config_node *vgn; const struct dm_config_node *vgn;
const struct dm_config_value *cv; const struct dm_config_value *cv;
const char *str, *system_id, *format_str; const char *str, *format_str;
struct volume_group *vg; struct volume_group *vg;
struct dm_hash_table *pv_hash = NULL, *lv_hash = NULL; struct dm_hash_table *pv_hash = NULL, *lv_hash = NULL;
unsigned scan_done_once = use_cached_pvs; unsigned scan_done_once = use_cached_pvs;
char *system_id;
/* skip any top-level values */ /* skip any top-level values */
for (vgn = cft->root; (vgn && vgn->v); vgn = vgn->sib) for (vgn = cft->root; (vgn && vgn->v); vgn = vgn->sib)
@ -750,6 +751,9 @@ static struct volume_group *_read_vg(struct format_instance *fid,
if (!(vg = alloc_vg("read_vg", fid->fmt->cmd, vgn->key))) if (!(vg = alloc_vg("read_vg", fid->fmt->cmd, vgn->key)))
return_NULL; return_NULL;
if (!(system_id = dm_pool_zalloc(vg->vgmem, NAME_LEN + 1)))
goto_bad;
vg->system_id = system_id;
/* /*
* The pv hash memorises the pv section names -> pv * The pv hash memorises the pv section names -> pv
@ -778,6 +782,9 @@ static struct volume_group *_read_vg(struct format_instance *fid,
goto bad; goto bad;
} }
if (dm_config_get_str(vgn, "system_id", &str))
strncpy(system_id, str, NAME_LEN);
if (!_read_id(&vg->id, vgn, "id")) { if (!_read_id(&vg->id, vgn, "id")) {
log_error("Couldn't read uuid for volume group %s.", vg->name); log_error("Couldn't read uuid for volume group %s.", vg->name);
goto bad; goto bad;
@ -795,17 +802,6 @@ static struct volume_group *_read_vg(struct format_instance *fid,
goto bad; goto bad;
} }
if (dm_config_get_str(vgn, "system_id", &system_id)) {
if (!(vg->status & ACCESS_NEEDS_SYSTEM_ID)) {
if (!(vg->lvm1_system_id = dm_pool_zalloc(vg->vgmem, NAME_LEN + 1)))
goto_bad;
strncpy(vg->lvm1_system_id, system_id, NAME_LEN);
} else if (!(vg->system_id = dm_pool_strdup(vg->vgmem, system_id))) {
log_error("Failed to allocate memory for system_id in vg_set_system_id.");
goto bad;
}
}
if (!_read_int32(vgn, "extent_size", &vg->extent_size)) { if (!_read_int32(vgn, "extent_size", &vg->extent_size)) {
log_error("Couldn't read extent size for volume group %s.", log_error("Couldn't read extent size for volume group %s.",
vg->name); vg->name);

View File

@ -60,7 +60,6 @@
#define LVM_WRITE UINT64_C(0x0000000000000200) /* LV, VG */ #define LVM_WRITE UINT64_C(0x0000000000000200) /* LV, VG */
#define CLUSTERED UINT64_C(0x0000000000000400) /* VG */ #define CLUSTERED UINT64_C(0x0000000000000400) /* VG */
#define ACCESS_NEEDS_SYSTEM_ID UINT64_C(0x0020000000000000) /* VG */
//#define SHARED UINT64_C(0x0000000000000800) /* VG */ //#define SHARED UINT64_C(0x0000000000000800) /* VG */
/* FIXME Remove when metadata restructuring is completed */ /* FIXME Remove when metadata restructuring is completed */
@ -123,7 +122,7 @@
#define PV_ALLOCATION_PROHIBITED UINT64_C(0x0010000000000000) /* PV - internal use only - allocation prohibited #define PV_ALLOCATION_PROHIBITED UINT64_C(0x0010000000000000) /* PV - internal use only - allocation prohibited
e.g. to prohibit allocation of a RAID image e.g. to prohibit allocation of a RAID image
on a PV already holing an image of the RAID set */ on a PV already holing an image of the RAID set */
/* Next unused flag: UINT64_C(0x0040000000000000) */ /* Next unused flag: UINT64_C(0x0020000000000000) */
/* Format features flags */ /* Format features flags */
#define FMT_SEGMENTS 0x00000001U /* Arbitrary segment params? */ #define FMT_SEGMENTS 0x00000001U /* Arbitrary segment params? */

View File

@ -615,7 +615,6 @@ int vg_set_system_id(struct volume_group *vg, const char *system_id)
{ {
if (!system_id || !*system_id) { if (!system_id || !*system_id) {
vg->system_id = NULL; vg->system_id = NULL;
vg->status &= ~ACCESS_NEEDS_SYSTEM_ID;
return 1; return 1;
} }
@ -633,8 +632,6 @@ int vg_set_system_id(struct volume_group *vg, const char *system_id)
if (vg->lvm1_system_id) if (vg->lvm1_system_id)
*vg->lvm1_system_id = '\0'; *vg->lvm1_system_id = '\0';
vg->status |= ACCESS_NEEDS_SYSTEM_ID;
return 1; return 1;
} }

View File

@ -575,14 +575,10 @@ static int _vgchange_system_id(struct cmd_context *cmd, struct volume_group *vg)
vg->name, vg->system_id, system_id); vg->name, vg->system_id, system_id);
vg->system_id = system_id; vg->system_id = system_id;
if (vg->lvm1_system_id) if (vg->lvm1_system_id)
*vg->lvm1_system_id = '\0'; *vg->lvm1_system_id = '\0';
if (vg->system_id && *vg->system_id)
vg->status |= ACCESS_NEEDS_SYSTEM_ID;
else
vg->status &= ~ACCESS_NEEDS_SYSTEM_ID;
return 1; return 1;
} }