powerpc/pseries/scm: Use a specific endian format for storing uuid from the device...
authorAneesh Kumar K.V <aneesh.kumar@linux.ibm.com>
Fri, 7 Jun 2019 06:47:05 +0000 (12:17 +0530)
committerMichael Ellerman <mpe@ellerman.id.au>
Thu, 4 Jul 2019 14:42:10 +0000 (00:42 +1000)
We used uuid_parse to convert uuid string from device tree to two u64
components. We want to make sure we look at the uuid read from device
tree in an endian-neutral fashion. For now, I am picking little-endian
to be format so that we don't end up doing an additional conversion.

The reason to store in a specific endian format is to enable reading
the namespace created with a little-endian kernel config on a
big-endian kernel. We do store the device tree uuid string as a 64-bit
little-endian cookie in the label area. When booting the kernel we
also compare this cookie against what is read from the device tree.
For this, to work we have to store and compare these values in a CPU
endian config independent fashion.

Signed-off-by: Aneesh Kumar K.V <aneesh.kumar@linux.ibm.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
arch/powerpc/platforms/pseries/papr_scm.c

index 80fbab118ef137e279a2393bb66ee04c9cf39326..c8ec670ee924e9d32615a1bf50b8bf0fe4c041fe 100644 (file)
@@ -373,8 +373,15 @@ static int papr_scm_probe(struct platform_device *pdev)
 
        /* We just need to ensure that set cookies are unique across */
        uuid_parse(uuid_str, (uuid_t *) uuid);
-       p->nd_set.cookie1 = uuid[0];
-       p->nd_set.cookie2 = uuid[1];
+       /*
+        * cookie1 and cookie2 are not really little endian
+        * we store a little endian representation of the
+        * uuid str so that we can compare this with the label
+        * area cookie irrespective of the endian config with which
+        * the kernel is built.
+        */
+       p->nd_set.cookie1 = cpu_to_le64(uuid[0]);
+       p->nd_set.cookie2 = cpu_to_le64(uuid[1]);
 
        /* might be zero */
        p->metadata_size = metadata_size;