Blame SOURCES/ddf1_lsi_persistent_name.patch
|
|
8ccba5 |
diff --git a/lib/format/ddf/ddf1.c.lsi_name b/lib/format/ddf/ddf1.c
|
|
|
8ccba5 |
index 05b550b..c8e484b 100644
|
|
|
8ccba5 |
--- a/lib/format/ddf/ddf1.c
|
|
|
8ccba5 |
+++ b/lib/format/ddf/ddf1.c
|
|
|
8ccba5 |
@@ -696,6 +696,16 @@ name(struct lib_context *lc, struct ddf1 *ddf1, struct raid_dev *rd)
|
|
|
8ccba5 |
sprintf(b, "%02x%02x%02x%02x",
|
|
|
8ccba5 |
vd->guid[i], vd->guid[i + 1],
|
|
|
8ccba5 |
vd->guid[i + 2], vd->guid[i + 3]);
|
|
|
8ccba5 |
+
|
|
|
8ccba5 |
+ /*
|
|
|
8ccba5 |
+ * Because the LSI bios changes the timestamp in the
|
|
|
8ccba5 |
+ * metadata on every boot, we have to neutralize it
|
|
|
8ccba5 |
+ * in order to allow for persistent names.
|
|
|
8ccba5 |
+ *
|
|
|
8ccba5 |
+ * Using a dummy string "47114711" for that.
|
|
|
8ccba5 |
+ */
|
|
|
8ccba5 |
+ if (!strncmp((char *) vd->guid, "LSI", 3))
|
|
|
8ccba5 |
+ strncpy(buf + prefix + 32, "47114711", 8);
|
|
|
8ccba5 |
}
|
|
|
8ccba5 |
|
|
|
8ccba5 |
out:
|