[lvm-devel] master - pvscan: fix PV online when device has a different size

David Teigland teigland at sourceware.org
Thu Jul 11 16:42:42 UTC 2019


Gitweb:        https://sourceware.org/git/?p=lvm2.git;a=commitdiff;h=b16abb3816408a296343a75658d4be0ef688390b
Commit:        b16abb3816408a296343a75658d4be0ef688390b
Parent:        f17353e3e604ad2d80bcd77ea0a6a93472e6b5bd
Author:        David Teigland <teigland at redhat.com>
AuthorDate:    Tue Jul 9 13:45:09 2019 -0500
Committer:     David Teigland <teigland at redhat.com>
CommitterDate: Tue Jul 9 13:45:09 2019 -0500

pvscan: fix PV online when device has a different size

Fix commit 7836e7aa1c17216ed368fda89cfc805a07efda81
"pvscan: ignore device with incorrect size"

which caused pvscan to not consider a PV online (for purposes
of event based activation) if the PV and device sizes differed.

This helped to avoid mistaking MD components for PVs, and is
replaced by triggering an md component check when PV and device
sizes differ (which happens in set_pv_device).
---
 tools/pvscan.c |   40 ++++++++++------------------------------
 1 files changed, 10 insertions(+), 30 deletions(-)

diff --git a/tools/pvscan.c b/tools/pvscan.c
index 12711cb..facc70c 100644
--- a/tools/pvscan.c
+++ b/tools/pvscan.c
@@ -621,6 +621,16 @@ static int _online_pvscan_one(struct cmd_context *cmd, struct device *dev,
 		set_pv_devices(baton.fid, baton.vg);
 	}
 
+	/* This check repeated because set_pv_devices can do new md check. */
+	if (dev->flags & DEV_IS_MD_COMPONENT) {
+		log_print("pvscan[%d] PV %s ignore MD component, ignore metadata.", getpid(), dev_name(dev));
+		if (baton.vg)
+			release_vg(baton.vg);
+		else
+			fmt->ops->destroy_instance(baton.fid);
+		return 1;
+	}
+
 	if (baton.vg && vg_is_shared(baton.vg)) {
 		log_print("pvscan[%d] PV %s ignore shared VG.", getpid(), dev_name(dev));
 		release_vg(baton.vg);
@@ -638,36 +648,6 @@ static int _online_pvscan_one(struct cmd_context *cmd, struct device *dev,
 		return 1;
 	}
 
-	/*
-	 * Do not consider a device online (for purposes of autoactivation)
-	 * if its size does not match the PV size recorded in the metadata.
-	 * It may mean that it's not the correct dev for the PV, e.g. it
-	 * could be an md component device that's not been filtered.
-	 */
-	if (baton.vg && cmd->check_pv_dev_sizes) {
-		struct pv_list *pvl;
-		uint64_t dev_size = 0;
-		uint64_t meta_pv_size = 0;
-
-		dm_list_iterate_items(pvl, &baton.vg->pvs) {
-			if (pvl->pv->dev != dev)
-				continue;
-
-			if (!dev_get_size(dev, &dev_size))
-				stack;
-			meta_pv_size = pv_size(pvl->pv);
-			break;
-		}
-
-		if (dev_size != meta_pv_size) {
-			log_print("pvscan[%d] PV %s ignore for size %llu not matching device %llu.",
-				  getpid(), dev_name(dev),
-				  (unsigned long long)meta_pv_size, (unsigned long long)dev_size);
-			release_vg(baton.vg);
-			return 1;
-		}
-	}
-
 	ret = _online_pv_found(cmd, dev, dev_args, baton.vg, found_vgnames);
 
 	/*




More information about the lvm-devel mailing list