ad4aff0
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
ad4aff0
From: Peter Jones <pjones@redhat.com>
ad4aff0
Date: Tue, 14 Jan 2014 13:12:23 -0500
ad4aff0
Subject: [PATCH] Add devicetree loading
ad4aff0
ad4aff0
Signed-off-by: Peter Jones <pjones@redhat.com>
ad4aff0
ad4aff0
Switch to use APM Mustang device tree, for hardware testing.
ad4aff0
ad4aff0
Signed-off-by: David A. Marlin <d.marlin@redhat.com>
ad4aff0
ad4aff0
Use the default device tree from the grub default file
ad4aff0
ad4aff0
instead of hardcoding a value.
ad4aff0
ad4aff0
Signed-off-by: David A. Marlin <dmarlin@redhat.com>
ad4aff0
---
ad4aff0
 util/grub-mkconfig.in   |  3 ++-
ad4aff0
 util/grub.d/10_linux.in | 15 +++++++++++++++
ad4aff0
 2 files changed, 17 insertions(+), 1 deletion(-)
ad4aff0
ad4aff0
diff --git a/util/grub-mkconfig.in b/util/grub-mkconfig.in
ad4aff0
index b0a8626dd1c..f68d4925ee6 100644
ad4aff0
--- a/util/grub-mkconfig.in
ad4aff0
+++ b/util/grub-mkconfig.in
ad4aff0
@@ -254,7 +254,8 @@ export GRUB_DEFAULT \
ad4aff0
   GRUB_ENABLE_CRYPTODISK \
ad4aff0
   GRUB_BADRAM \
ad4aff0
   GRUB_OS_PROBER_SKIP_LIST \
ad4aff0
-  GRUB_DISABLE_SUBMENU
ad4aff0
+  GRUB_DISABLE_SUBMENU \
ad4aff0
+  GRUB_DEFAULT_DTB
ad4aff0
 
ad4aff0
 if test "x${grub_cfg}" != "x"; then
ad4aff0
   rm -f "${grub_cfg}.new"
ad4aff0
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
ad4aff0
index 87a7da34982..233754ff296 100644
ad4aff0
--- a/util/grub.d/10_linux.in
ad4aff0
+++ b/util/grub.d/10_linux.in
ad4aff0
@@ -153,6 +153,13 @@ EOF
ad4aff0
     sed "s/^/$submenu_indentation/" << EOF
ad4aff0
 	echo	'$(echo "$message" | grub_quote)'
ad4aff0
 	initrd	$(echo $initrd_path)
ad4aff0
+EOF
ad4aff0
+  fi
ad4aff0
+  if test -n "${fdt}" ; then
ad4aff0
+    message="$(gettext_printf "Loading fdt ...")"
ad4aff0
+    sed "s/^/$submenu_indentation/" << EOF
ad4aff0
+	echo	'$(echo "$message" | grub_quote)'
ad4aff0
+	devicetree	${rel_dirname}/${fdt}
ad4aff0
 EOF
ad4aff0
   fi
ad4aff0
   sed "s/^/$submenu_indentation/" << EOF
ad4aff0
@@ -236,6 +243,14 @@ while [ "x$list" != "x" ] ; do
ad4aff0
     gettext_printf "Found initrd image: %s\n" "$(echo $initrd_display)" >&2
ad4aff0
   fi
ad4aff0
 
ad4aff0
+  fdt=
ad4aff0
+  for i in "dtb-${version}" "dtb-${alt_version}"; do
ad4aff0
+    if test -f "${dirname}/${i}/${GRUB_DEFAULT_DTB}" ; then
ad4aff0
+      fdt="${i}/${GRUB_DEFAULT_DTB}"
ad4aff0
+      break
ad4aff0
+    fi
ad4aff0
+  done
ad4aff0
+
ad4aff0
   config=
ad4aff0
   for i in "${dirname}/config-${version}" "${dirname}/config-${alt_version}" "/etc/kernels/kernel-config-${version}" ; do
ad4aff0
     if test -e "${i}" ; then