Blame SOURCES/avoid_register.patch

8ccba5
diff --git a/lib/activate/activate.c.avoid_register b/lib/activate/activate.c
8ccba5
index 1d71ea8..86882f7 100644
8ccba5
--- a/lib/activate/activate.c.avoid_register
8ccba5
+++ b/lib/activate/activate.c
8ccba5
@@ -964,11 +964,13 @@ activate_subset(struct lib_context *lc, struct raid_set *rs, enum dm_what what)
8ccba5
 {
8ccba5
 	int ret = 0;
8ccba5
 	char *table = NULL;
8ccba5
+	struct dmraid_format *fmt = get_format(rs);
8ccba5
 
8ccba5
 	if (T_GROUP(rs))
8ccba5
 		return 1;
8ccba5
 
8ccba5
-	if (what == DM_REGISTER)
8ccba5
+	if (what == DM_REGISTER &&
8ccba5
+	    fmt->metadata_handler)
8ccba5
 		return register_devices(lc, rs);
8ccba5
 
8ccba5
 	/* Call type handler */
8ccba5
@@ -1053,8 +1055,10 @@ deactivate_superset(struct lib_context *lc, struct raid_set *rs,
8ccba5
 		    enum dm_what what)
8ccba5
 {
8ccba5
 	int ret = 1, status;
8ccba5
+	struct dmraid_format *fmt = get_format(rs);
8ccba5
 
8ccba5
-	if (what == DM_REGISTER)
8ccba5
+	if (what == DM_REGISTER &&
8ccba5
+	    fmt->metadata_handler)
8ccba5
 		return unregister_devices(lc, rs);
8ccba5
 
8ccba5
 	status = dm_status(lc, rs);