15a2072
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
15a2072
From: Mark Salter <msalter@redhat.com>
15a2072
Date: Mon, 17 Apr 2017 08:44:29 -0400
15a2072
Subject: [PATCH] arm64: make sure fdt has #address-cells and #size-cells
15a2072
 properties
15a2072
15a2072
Recent upstream changes to kexec-tools relies on #address-cells
15a2072
and #size-cells properties in the FDT. If grub2 needs to create
15a2072
a chosen node, it is likely because firmware did not provide one.
15a2072
In that case, set #address-cells and #size-cells properties to
15a2072
make sure they exist.
15a2072
---
15a2072
 grub-core/loader/arm64/linux.c | 16 +++++++++++++++-
15a2072
 1 file changed, 15 insertions(+), 1 deletion(-)
15a2072
15a2072
diff --git a/grub-core/loader/arm64/linux.c b/grub-core/loader/arm64/linux.c
dbfd2e6
index a1ac7a38867..93b5cd306eb 100644
15a2072
--- a/grub-core/loader/arm64/linux.c
15a2072
+++ b/grub-core/loader/arm64/linux.c
15a2072
@@ -80,7 +80,21 @@ finalize_params_linux (void)
15a2072
 
15a2072
   node = grub_fdt_find_subnode (fdt, 0, "chosen");
15a2072
   if (node < 0)
15a2072
-    node = grub_fdt_add_subnode (fdt, 0, "chosen");
15a2072
+    {
15a2072
+      /*
15a2072
+       * If we have to create a chosen node, Make sure we
15a2072
+       * have #address-cells and #size-cells properties.
15a2072
+       */
15a2072
+      retval = grub_fdt_set_prop32(fdt, 0, "#address-cells", 2);
15a2072
+      if (retval)
15a2072
+	goto failure;
15a2072
+
15a2072
+      retval = grub_fdt_set_prop32(fdt, 0, "#size-cells", 2);
15a2072
+      if (retval)
15a2072
+	goto failure;
15a2072
+
15a2072
+      node = grub_fdt_add_subnode (fdt, 0, "chosen");
15a2072
+    }
15a2072
 
15a2072
   if (node < 1)
15a2072
     goto failure;