Version 2.02.44 -
====================================
- Fix pvs segfault when run with orphan PV and vg_mda_size or vg_mda_free.
+ Fix pvs segfault when run with orphan PV and some VG fields.
Display a 'dev_size' of zero for missing devices in reports.
Add pv_mda_size to pvs and vg_mda_size to vgs.
Fix lvmdump /sys listing to include virtual devices directory.
const struct volume_group *vg = (const struct volume_group *) data;
uint64_t min_mda_size;
- /*
- * An orphan PV will have vg->fid == NULL
- */
- if (vg->fid == NULL)
- min_mda_size = UINT64_C(0);
- else
- min_mda_size = _find_min_mda_size(&vg->fid->metadata_areas);
+ min_mda_size = _find_min_mda_size(&vg->fid->metadata_areas);
return _size64_disp(rh, mem, field, &min_mda_size, private);
}
uint64_t freespace = UINT64_MAX, mda_free;
struct metadata_area *mda;
- /*
- * An orphan PV will have vg->fid == NULL
- */
- if (vg->fid == NULL)
- goto calc_done;
-
dm_list_iterate_items(mda, &vg->fid->metadata_areas) {
if (!mda->ops->mda_free_sectors)
continue;
if (mda_free < freespace)
freespace = mda_free;
}
-calc_done:
+
if (freespace == UINT64_MAX)
freespace = UINT64_C(0);
/* Report object types */
/* necessary for displaying something for PVs not belonging to VG */
+static struct format_instance _dummy_fid = {
+ .metadata_areas = { &(_dummy_fid.metadata_areas), &(_dummy_fid.metadata_areas) },
+};
+
static struct volume_group _dummy_vg = {
+ .fid = &_dummy_fid,
.name = (char *) "",
+ .system_id = (char *) "",
+ .pvs = { &(_dummy_vg.pvs), &(_dummy_vg.pvs) },
+ .lvs = { &(_dummy_vg.lvs), &(_dummy_vg.lvs) },
+ .tags = { &(_dummy_vg.tags), &(_dummy_vg.tags) },
};
static void *_obj_get_vg(void *obj)
{
struct lvm_report_object obj;
+ /* The two format fields might as well match. */
+ if (!vg && pv)
+ _dummy_fid.fmt = pv->fmt;
+
obj.vg = vg;
obj.lv = lv;
obj.pv = pv;