011fe81
From 1c9518bb506f8f4fa6b388571c76797705e7b566 Mon Sep 17 00:00:00 2001
8c7f759
From: Peter Jones <pjones@redhat.com>
8c7f759
Date: Tue, 14 Jan 2014 13:12:23 -0500
58fe9aa
Subject: [PATCH 123/152] Make 10_linux work with our changes for linux16 and
8c7f759
 linuxefi on aarch64
8c7f759
8c7f759
Signed-off-by: Peter Jones <pjones@redhat.com>
8c7f759
---
8c7f759
 util/grub.d/10_linux.in | 31 ++++++++++++++++++++++++++++---
8c7f759
 1 file changed, 28 insertions(+), 3 deletions(-)
8c7f759
8c7f759
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
8c7f759
index c943a1e..2b8c561 100644
8c7f759
--- a/util/grub.d/10_linux.in
8c7f759
+++ b/util/grub.d/10_linux.in
8c7f759
@@ -75,8 +75,18 @@ linux_entry ()
8c7f759
   args="$4"
8c7f759
 
8c7f759
   sixteenbit=""
8c7f759
+  linuxefi="linux"
8c7f759
+  initrdefi="initrd"
8c7f759
   case "$machine" in
8c7f759
-    i?86|x86_64) sixteenbit="16" ;;
8c7f759
+    i?86|x86_64)
8c7f759
+	sixteenbit="16"
8c7f759
+	linuxefi="linuxefi"
8c7f759
+	initrdefi="initrdefi"
8c7f759
+	;;
8c7f759
+    aarch64)
8c7f759
+	linuxefi="linux"
8c7f759
+	initrdefi="initrd"
8c7f759
+	;;
8c7f759
   esac
8c7f759
 
8c7f759
   if [ -z "$boot_device_id" ]; then
8c7f759
@@ -133,7 +143,7 @@ linux_entry ()
8c7f759
   fi
8c7f759
   if [ -d /sys/firmware/efi ]; then
8c7f759
     sed "s/^/$submenu_indentation/" << EOF
8c7f759
-	linuxefi ${rel_dirname}/${basename} root=${linux_root_device_thisversion} ro ${args}
8c7f759
+	${linuxefi} ${rel_dirname}/${basename} root=${linux_root_device_thisversion} ro ${args}
8c7f759
 EOF
8c7f759
   else
8c7f759
     sed "s/^/$submenu_indentation/" << EOF
8c7f759
@@ -143,7 +153,7 @@ EOF
8c7f759
   if test -n "${initrd}" ; then
8c7f759
     if [ -d /sys/firmware/efi ]; then
8c7f759
       sed "s/^/$submenu_indentation/" << EOF
8c7f759
-	initrdefi ${rel_dirname}/${initrd}
8c7f759
+	${initrdefi} ${rel_dirname}/${initrd}
8c7f759
 EOF
8c7f759
     else
8c7f759
       sed "s/^/$submenu_indentation/" << EOF
8c7f759
@@ -151,6 +161,13 @@ EOF
8c7f759
 EOF
8c7f759
     fi
8c7f759
   fi
8c7f759
+  if test -n "${fdt}" ; then
8c7f759
+    message="$(gettext_printf "Loading fdt ...")"
8c7f759
+    sed "s/^/$submenu_indentation/" << EOF
8c7f759
+	echo	'$(echo "$message" | grub_quote)'
8c7f759
+	devicetree	${rel_dirname}/${fdt}
8c7f759
+EOF
8c7f759
+  fi
8c7f759
   sed "s/^/$submenu_indentation/" << EOF
8c7f759
 }
8c7f759
 EOF
8c7f759
@@ -211,6 +228,14 @@ while [ "x$list" != "x" ] ; do
8c7f759
     fi
8c7f759
   done
8c7f759
 
8c7f759
+  fdt=
8c7f759
+  for i in "dtb-${version}" "dtb-${alt_version}"; do
8c7f759
+    if test -e "${dirname}/${i}/foundation-v8.dtb" ; then
8c7f759
+      fdt="${i}/foundation-v8.dtb"
8c7f759
+      break
8c7f759
+    fi
8c7f759
+  done
8c7f759
+
8c7f759
   config=
8c7f759
   for i in "${dirname}/config-${version}" "${dirname}/config-${alt_version}" "/etc/kernels/kernel-config-${version}" ; do
8c7f759
     if test -e "${i}" ; then
8c7f759
-- 
37b39b7
1.9.3
8c7f759