]> sourceware.org Git - lvm2.git/commitdiff
More fields can cause segfaults with orphans.
authorAlasdair Kergon <agk@redhat.com>
Sat, 10 Jan 2009 17:09:40 +0000 (17:09 +0000)
committerAlasdair Kergon <agk@redhat.com>
Sat, 10 Jan 2009 17:09:40 +0000 (17:09 +0000)
Fix these by populating the dummy VG struct more completely.

WHATS_NEW
lib/report/report.c

index fc8605f7df6cdba7d7ec421205f3b9c69ae1f832..994114e48fdc709874555efba2f14b9bfbdd7fed 100644 (file)
--- a/WHATS_NEW
+++ b/WHATS_NEW
@@ -1,6 +1,6 @@
 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.
index 74739e07e0c4bc8c9fc4e23c064ae66de9144089..8439b2b095a2840f7ca7d0e15ad7fb14add03a59 100644 (file)
@@ -926,13 +926,7 @@ static int _vgmdasize_disp(struct dm_report *rh, struct dm_pool *mem,
        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);
 }
@@ -945,12 +939,6 @@ static int _vgmdafree_disp(struct dm_report *rh, struct dm_pool *mem,
        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;
@@ -958,7 +946,7 @@ static int _vgmdafree_disp(struct dm_report *rh, struct dm_pool *mem,
                if (mda_free < freespace)
                        freespace = mda_free;
        }
-calc_done:
+
        if (freespace == UINT64_MAX)
                freespace = UINT64_C(0);
 
@@ -1081,8 +1069,17 @@ static int _copypercent_disp(struct dm_report *rh __attribute((unused)), struct
 /* 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)
@@ -1182,6 +1179,10 @@ int report_object(void *handle, struct volume_group *vg,
 {
        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;
This page took 0.051911 seconds and 5 git commands to generate.