mrc0mmand / rpms / lvm2

Forked from rpms/lvm2 2 years ago
Clone

Blame SOURCES/lvm2-2_03_13-lvremove-fix-removing-thin-pool-with-writecache-on-d.patch

f6e141
 lib/metadata/lv_manip.c                | 19 +++++++++
f6e141
 lib/metadata/metadata-exported.h       |  2 +
f6e141
 lib/metadata/thin_manip.c              | 12 ++++++
f6e141
 test/shell/lvremove-thindata-caches.sh | 71 ++++++++++++++++++++++++++++++++++
f6e141
 4 files changed, 104 insertions(+)
f6e141
 create mode 100644 test/shell/lvremove-thindata-caches.sh
f6e141
f6e141
diff --git a/lib/metadata/lv_manip.c b/lib/metadata/lv_manip.c
f6e141
index 508f78c..37dd361 100644
f6e141
--- a/lib/metadata/lv_manip.c
f6e141
+++ b/lib/metadata/lv_manip.c
f6e141
@@ -6692,6 +6692,25 @@ int lv_remove_single(struct cmd_context *cmd, struct logical_volume *lv,
f6e141
 			return_0;
f6e141
 	}
f6e141
 
f6e141
+	/* if thin pool data lv is writecache, then detach and remove the writecache */
f6e141
+	if (lv_is_thin_pool(lv)) {
f6e141
+		struct logical_volume *data_lv = data_lv_from_thin_pool(lv);
f6e141
+
f6e141
+		if (data_lv && lv_is_writecache(data_lv)) {
f6e141
+			struct logical_volume *cachevol_lv = first_seg(data_lv)->writecache;
f6e141
+
f6e141
+			if (!lv_detach_writecache_cachevol(data_lv, 1)) {
f6e141
+				log_error("Failed to detach writecache from %s", display_lvname(data_lv));
f6e141
+				return 0;
f6e141
+			}
f6e141
+
f6e141
+			if (!lv_remove_single(cmd, cachevol_lv, force, 1)) {
f6e141
+				log_error("Failed to remove cachevol %s.", display_lvname(cachevol_lv));
f6e141
+				return 0;
f6e141
+			}
f6e141
+		}
f6e141
+	}
f6e141
+
f6e141
 	if (lv_is_writecache(lv)) {
f6e141
 		struct logical_volume *cachevol_lv = first_seg(lv)->writecache;
f6e141
 
f6e141
diff --git a/lib/metadata/metadata-exported.h b/lib/metadata/metadata-exported.h
f6e141
index c611635..54bc0d0 100644
f6e141
--- a/lib/metadata/metadata-exported.h
f6e141
+++ b/lib/metadata/metadata-exported.h
f6e141
@@ -927,6 +927,8 @@ int handle_pool_metadata_spare(struct volume_group *vg, uint32_t extents,
f6e141
 int vg_set_pool_metadata_spare(struct logical_volume *lv);
f6e141
 int vg_remove_pool_metadata_spare(struct volume_group *vg);
f6e141
 
f6e141
+struct logical_volume *data_lv_from_thin_pool(struct logical_volume *pool_lv);
f6e141
+
f6e141
 int attach_thin_external_origin(struct lv_segment *seg,
f6e141
 				struct logical_volume *external_lv);
f6e141
 int detach_thin_external_origin(struct lv_segment *seg);
f6e141
diff --git a/lib/metadata/thin_manip.c b/lib/metadata/thin_manip.c
f6e141
index 451c382..6ce88bd 100644
f6e141
--- a/lib/metadata/thin_manip.c
f6e141
+++ b/lib/metadata/thin_manip.c
f6e141
@@ -21,6 +21,18 @@
f6e141
 #include "lib/config/defaults.h"
f6e141
 #include "lib/display/display.h"
f6e141
 
f6e141
+struct logical_volume *data_lv_from_thin_pool(struct logical_volume *pool_lv)
f6e141
+{
f6e141
+	struct lv_segment *seg_thinpool = first_seg(pool_lv);
f6e141
+
f6e141
+	if (!seg_thinpool || !seg_is_thin_pool(seg_thinpool)) {
f6e141
+		log_error(INTERNAL_ERROR "data_lv_from_thin_pool arg not thin pool %s", pool_lv->name);
f6e141
+		return NULL;
f6e141
+	}
f6e141
+
f6e141
+	return seg_thinpool->areas[0].u.lv.lv;
f6e141
+}
f6e141
+
f6e141
 /* TODO: drop unused no_update */
f6e141
 int attach_pool_message(struct lv_segment *pool_seg, dm_thin_message_t type,
f6e141
 			struct logical_volume *lv, uint32_t delete_id,
f6e141
diff --git a/test/shell/lvremove-thindata-caches.sh b/test/shell/lvremove-thindata-caches.sh
f6e141
new file mode 100644
f6e141
index 0000000..ba099c3
f6e141
--- /dev/null
f6e141
+++ b/test/shell/lvremove-thindata-caches.sh
f6e141
@@ -0,0 +1,71 @@
f6e141
+#!/usr/bin/env bash
f6e141
+
f6e141
+# Copyright (C) 2017-2020 Red Hat, Inc. All rights reserved.
f6e141
+#
f6e141
+# This copyrighted material is made available to anyone wishing to use,
f6e141
+# modify, copy, or redistribute it subject to the terms and conditions
f6e141
+# of the GNU General Public License v.2.
f6e141
+#
f6e141
+# You should have received a copy of the GNU General Public License
f6e141
+# along with this program; if not, write to the Free Software Foundation,
f6e141
+# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
f6e141
+
f6e141
+SKIP_WITH_LVMPOLLD=1
f6e141
+
f6e141
+. lib/inittest
f6e141
+
f6e141
+aux have_cache 1 10 0 || skip
f6e141
+aux have_writecache 1 0 0 || skip
f6e141
+which mkfs.xfs || skip
f6e141
+
f6e141
+aux prepare_devs 6 70 # want 64M of usable space from each dev
f6e141
+
f6e141
+vgcreate $SHARED $vg "$dev1" "$dev2" "$dev3" "$dev4" "$dev5" "$dev6"
f6e141
+
f6e141
+# lv1 is thinpool LV: 128M
f6e141
+# lv2 is fast LV:      64M
f6e141
+# lv3 is thin LV:       1G
f6e141
+
f6e141
+#
f6e141
+# Test lvremove of a thinpool that uses cache|writecache on data
f6e141
+#
f6e141
+
f6e141
+# attach writecache to thinpool data
f6e141
+lvcreate --type thin-pool -n $lv1 -L128M --poolmetadataspare n $vg "$dev1" "$dev2"
f6e141
+lvcreate --type thin -n $lv3 -V1G --thinpool $lv1 $vg
f6e141
+lvcreate -n $lv2 -L64M -an $vg "$dev3"
f6e141
+lvconvert -y --type writecache --cachevol $lv2 $vg/$lv1
f6e141
+lvchange -ay $vg/$lv1
f6e141
+lvs -a $vg
f6e141
+mkfs.xfs -f -s size=4096 "$DM_DEV_DIR/$vg/$lv3"
f6e141
+lvremove -y $vg/$lv1
f6e141
+
f6e141
+# attach cache/writeback (cachevol) to thinpool data
f6e141
+lvcreate --type thin-pool -n $lv1 -L128M --poolmetadataspare n $vg "$dev1" "$dev2"
f6e141
+lvcreate --type thin -n $lv3 -V1G --thinpool $lv1 $vg
f6e141
+lvcreate -n $lv2 -L64M -an $vg "$dev3"
f6e141
+lvconvert -y --type cache --cachevol $lv2 --cachemode writeback $vg/$lv1
f6e141
+lvchange -ay $vg/$lv1
f6e141
+mkfs.xfs -f -s size=4096 "$DM_DEV_DIR/$vg/$lv3"
f6e141
+lvremove -y $vg/$lv1
f6e141
+
f6e141
+# attach cache/writethrough (cachevol) to thinpool data
f6e141
+lvcreate --type thin-pool -n $lv1 -L128M --poolmetadataspare n $vg "$dev1" "$dev2"
f6e141
+lvcreate --type thin -n $lv3 -V1G --thinpool $lv1 $vg
f6e141
+lvcreate -n $lv2 -L64M -an $vg "$dev3"
f6e141
+lvconvert -y --type cache --cachevol $lv2 --cachemode writethrough $vg/$lv1
f6e141
+lvchange -ay $vg/$lv1
f6e141
+mkfs.xfs -f -s size=4096 "$DM_DEV_DIR/$vg/$lv3"
f6e141
+lvremove -y $vg/$lv1
f6e141
+
f6e141
+# attach cache (cachepool) to thinpool data
f6e141
+lvcreate --type thin-pool -n $lv1 -L128M --poolmetadataspare n $vg "$dev1" "$dev2"
f6e141
+lvcreate --type thin -n $lv3 -V1G --thinpool $lv1 $vg
f6e141
+lvcreate -y --type cache-pool -n $lv2 -L64M --poolmetadataspare n $vg "$dev3" "$dev6"
f6e141
+lvconvert -y --type cache --cachepool $lv2 --poolmetadataspare n $vg/$lv1
f6e141
+lvchange -ay $vg/$lv1
f6e141
+mkfs.xfs -f -s size=4096 "$DM_DEV_DIR/$vg/$lv3"
f6e141
+lvremove -y $vg/$lv1
f6e141
+
f6e141
+vgremove -f $vg
f6e141
+