mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
metadata: Fix handling of orphan PV linking & re-linking.
This commit is contained in:
parent
651d5093ed
commit
ba6d6f0028
@ -269,6 +269,12 @@ int add_pv_to_vg(struct volume_group *vg, const char *pv_name,
|
|||||||
vg->extent_count += pv->pe_count;
|
vg->extent_count += pv->pe_count;
|
||||||
vg->free_count += pv->pe_count;
|
vg->free_count += pv->pe_count;
|
||||||
|
|
||||||
|
dm_list_iterate_items(pvl, &fid->fmt->orphan_vg->pvs)
|
||||||
|
if (pv == pvl->pv) { /* unlink from orphan */
|
||||||
|
dm_list_del(&pvl->list);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
if (pv->status & UNLABELLED_PV) {
|
if (pv->status & UNLABELLED_PV) {
|
||||||
if (!(pvc = dm_pool_zalloc(mem, sizeof(*pvc)))) {
|
if (!(pvc = dm_pool_zalloc(mem, sizeof(*pvc)))) {
|
||||||
log_error("pv_to_create allocation for '%s' failed", pv_name);
|
log_error("pv_to_create allocation for '%s' failed", pv_name);
|
||||||
@ -2810,8 +2816,10 @@ static struct volume_group *_vg_read_orphans(struct cmd_context *cmd,
|
|||||||
struct lvmcache_vginfo *vginfo;
|
struct lvmcache_vginfo *vginfo;
|
||||||
struct volume_group *vg = NULL;
|
struct volume_group *vg = NULL;
|
||||||
struct _vg_read_orphan_baton baton;
|
struct _vg_read_orphan_baton baton;
|
||||||
struct pv_list *pvl;
|
struct pv_list *pvl, *pvl_;
|
||||||
|
struct pv_list head;
|
||||||
|
|
||||||
|
dm_list_init(&head.list);
|
||||||
lvmcache_label_scan(cmd, 0);
|
lvmcache_label_scan(cmd, 0);
|
||||||
lvmcache_seed_infos_from_lvmetad(cmd);
|
lvmcache_seed_infos_from_lvmetad(cmd);
|
||||||
|
|
||||||
@ -2822,14 +2830,31 @@ static struct volume_group *_vg_read_orphans(struct cmd_context *cmd,
|
|||||||
return_NULL;
|
return_NULL;
|
||||||
|
|
||||||
vg = fmt->orphan_vg;
|
vg = fmt->orphan_vg;
|
||||||
dm_list_iterate_items(pvl, &vg->pvs)
|
restart:
|
||||||
pv_set_fid(pvl->pv, NULL);
|
dm_list_iterate_items(pvl, &vg->pvs) {
|
||||||
|
if (pvl->pv->status & UNLABELLED_PV ) {
|
||||||
|
dm_list_del(&pvl->list);
|
||||||
|
dm_list_add(&head.list, &pvl->list);
|
||||||
|
goto restart;
|
||||||
|
} else
|
||||||
|
pv_set_fid(pvl->pv, NULL);
|
||||||
|
}
|
||||||
dm_list_init(&vg->pvs);
|
dm_list_init(&vg->pvs);
|
||||||
vg->pv_count = 0;
|
vg->pv_count = 0;
|
||||||
|
vg->extent_count = 0;
|
||||||
|
vg->free_count = 0;
|
||||||
|
|
||||||
baton.warnings = warnings;
|
baton.warnings = warnings;
|
||||||
baton.vg = vg;
|
baton.vg = vg;
|
||||||
|
|
||||||
|
while (!dm_list_empty(&head.list)) {
|
||||||
|
pvl = (struct pv_list *) dm_list_first(&head.list);
|
||||||
|
dm_list_del(&pvl->list);
|
||||||
|
add_pvl_to_vgs(vg, pvl);
|
||||||
|
vg->extent_count += pvl->pv->pe_count;
|
||||||
|
vg->free_count += pvl->pv->pe_count;
|
||||||
|
}
|
||||||
|
|
||||||
if (!lvmcache_foreach_pv(vginfo, _vg_read_orphan_pv, &baton))
|
if (!lvmcache_foreach_pv(vginfo, _vg_read_orphan_pv, &baton))
|
||||||
return_NULL;
|
return_NULL;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user