From db494d7d344f323c7255d6ceb9cd5180e4b6f23b Mon Sep 17 00:00:00 2001 From: Peter Rajnoha Date: Thu, 11 Feb 2016 15:00:43 +0100 Subject: [PATCH] report: always display 0 for pv_free field if we don't have any mda and PV is marked as used at the same time --- lib/report/report.c | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/lib/report/report.c b/lib/report/report.c index 3f2bd0cd2..c964bd82e 100644 --- a/lib/report/report.c +++ b/lib/report/report.c @@ -2363,6 +2363,7 @@ static int _pvused_disp(struct dm_report *rh, struct dm_pool *mem, { const struct physical_volume *pv = (const struct physical_volume *) data; + uint64_t used = pv_used(pv); return _size64_disp(rh, mem, field, &used, private); @@ -2374,8 +2375,21 @@ static int _pvfree_disp(struct dm_report *rh, struct dm_pool *mem, { const struct physical_volume *pv = (const struct physical_volume *) data; + struct lvmcache_info *info; + uint32_t ext_flags; uint64_t freespace = pv_free(pv); + if (is_orphan(pv)) { + if (!(info = lvmcache_info_from_pvid((const char *) &pv->id, 0))) { + log_error("Failed to find cached info for PV %s.", pv_dev_name(pv)); + return 0; + } + + ext_flags = lvmcache_ext_flags(info); + if (ext_flags & PV_EXT_USED) + freespace = 0; + } + return _size64_disp(rh, mem, field, &freespace, private); }