Blame SOURCES/lvm2-2_02_187-snapshot-correctly-check-device-id-of-merged-thin.patch

b83e05
 lib/activate/dev_manager.c | 11 ++++++++++-
b83e05
 1 file changed, 10 insertions(+), 1 deletion(-)
b83e05
b83e05
diff --git a/lib/activate/dev_manager.c b/lib/activate/dev_manager.c
b83e05
index 56608e3..a5e026c 100644
b83e05
--- a/lib/activate/dev_manager.c
b83e05
+++ b/lib/activate/dev_manager.c
b83e05
@@ -1592,6 +1592,9 @@ int dev_manager_thin_percent(struct dev_manager *dm,
b83e05
 	return 1;
b83e05
 }
b83e05
 
b83e05
+/*
b83e05
+ * Explore state of running DM table to obtain currently used deviceId
b83e05
+ */
b83e05
 int dev_manager_thin_device_id(struct dev_manager *dm,
b83e05
 			       const struct logical_volume *lv,
b83e05
 			       uint32_t *device_id)
b83e05
@@ -1601,10 +1604,16 @@ int dev_manager_thin_device_id(struct dev_manager *dm,
b83e05
 	struct dm_info info;
b83e05
 	uint64_t start, length;
b83e05
 	char *params, *target_type = NULL;
b83e05
+	const char *layer = lv_layer(lv);
b83e05
 	int r = 0;
b83e05
 
b83e05
+	if (lv_is_merging_origin(lv) && !lv_info(lv->vg->cmd, lv, 1, NULL, 0, 0))
b83e05
+		/* If the merge has already happened, that table
b83e05
+		 * can already be using correct LV without -real layer */
b83e05
+		layer = NULL;
b83e05
+
b83e05
 	/* Build dlid for the thin layer */
b83e05
-	if (!(dlid = build_dm_uuid(dm->mem, lv, lv_layer(lv))))
b83e05
+	if (!(dlid = build_dm_uuid(dm->mem, lv, layer)))
b83e05
 		return_0;
b83e05
 
b83e05
 	if (!(dmt = _setup_task_run(DM_DEVICE_TABLE, &info, NULL, dlid, 0, 0, 0, 0, 1, 0)))