konradr / rpms / grub2

Forked from rpms/grub2 6 years ago
Clone
8c6b1ac
From d2fd442571640c4adb15d9aa726a5da9503b5b8a Mon Sep 17 00:00:00 2001
9d85b1d
From: Peter Jones <pjones@redhat.com>
9d85b1d
Date: Fri, 3 Oct 2014 11:08:03 -0400
8c6b1ac
Subject: [PATCH 495/506] Try $prefix if $fw_path doesn't work.
9d85b1d
9d85b1d
Related: rhbz#1148652
9d85b1d
9d85b1d
Signed-off-by: Peter Jones <pjones@redhat.com>
9d85b1d
---
9d85b1d
 grub-core/kern/ieee1275/init.c |  30 ++++++-----
9d85b1d
 grub-core/net/net.c            |   2 +-
9d85b1d
 grub-core/normal/main.c        | 118 ++++++++++++++++++++---------------------
9d85b1d
 3 files changed, 75 insertions(+), 75 deletions(-)
9d85b1d
9d85b1d
diff --git a/grub-core/kern/ieee1275/init.c b/grub-core/kern/ieee1275/init.c
9d85b1d
index 8191f8c..8ca4bf7 100644
9d85b1d
--- a/grub-core/kern/ieee1275/init.c
9d85b1d
+++ b/grub-core/kern/ieee1275/init.c
9d85b1d
@@ -131,23 +131,25 @@ grub_machine_get_bootlocation (char **device, char **path)
9d85b1d
       grub_free (canon);
9d85b1d
     }
9d85b1d
   else
9d85b1d
-    *device = grub_ieee1275_encode_devname (bootpath);
9d85b1d
-  grub_free (type);
9d85b1d
-
9d85b1d
-  filename = grub_ieee1275_get_filename (bootpath);
9d85b1d
-  if (filename)
9d85b1d
     {
9d85b1d
-      char *lastslash = grub_strrchr (filename, '\\');
9d85b1d
-
9d85b1d
-      /* Truncate at last directory.  */
9d85b1d
-      if (lastslash)
9d85b1d
+      filename = grub_ieee1275_get_filename (bootpath);
9d85b1d
+      if (filename)
9d85b1d
         {
9d85b1d
-	  *lastslash = '\0';
9d85b1d
-	  grub_translate_ieee1275_path (filename);
9d85b1d
-
9d85b1d
-	  *path = filename;
9d85b1d
-	}
9d85b1d
+          char *lastslash = grub_strrchr (filename, '\\');
9d85b1d
+
9d85b1d
+          /* Truncate at last directory.  */
9d85b1d
+          if (lastslash)
9d85b1d
+            {
9d85b1d
+              *lastslash = '\0';
9d85b1d
+              grub_translate_ieee1275_path (filename);
9d85b1d
+
9d85b1d
+              *path = filename;
9d85b1d
+            }
9d85b1d
+        }
9d85b1d
+      *device = grub_ieee1275_encode_devname (bootpath);
9d85b1d
     }
9d85b1d
+
9d85b1d
+  grub_free (type);
9d85b1d
   grub_free (bootpath);
9d85b1d
 }
9d85b1d
 
9d85b1d
diff --git a/grub-core/net/net.c b/grub-core/net/net.c
8c6b1ac
index cc68b0d..6c9ba4c 100644
9d85b1d
--- a/grub-core/net/net.c
9d85b1d
+++ b/grub-core/net/net.c
8c6b1ac
@@ -1819,7 +1819,7 @@ grub_net_search_configfile (char *config)
9d85b1d
   /* Remove the remaining minus sign at the end. */
9d85b1d
   config[config_len] = '\0';
9d85b1d
 
9d85b1d
-  return GRUB_ERR_NONE;
9d85b1d
+  return GRUB_ERR_FILE_NOT_FOUND;
9d85b1d
 }
9d85b1d
 
9d85b1d
 static struct grub_preboot *fini_hnd;
9d85b1d
diff --git a/grub-core/normal/main.c b/grub-core/normal/main.c
8c6b1ac
index 3ba1cdb..13d9eab 100644
9d85b1d
--- a/grub-core/normal/main.c
9d85b1d
+++ b/grub-core/normal/main.c
9d85b1d
@@ -331,74 +331,72 @@ grub_enter_normal_mode (const char *config)
9d85b1d
   grub_boot_time ("Exiting normal mode");
9d85b1d
 }
9d85b1d
 
9d85b1d
+static grub_err_t
9d85b1d
+grub_try_normal (const char *variable)
9d85b1d
+{
9d85b1d
+    char *config;
9d85b1d
+    const char *prefix;
9d85b1d
+    grub_err_t err = GRUB_ERR_FILE_NOT_FOUND;
9d85b1d
+
9d85b1d
+    prefix = grub_env_get (variable);
9d85b1d
+    if (!prefix)
9d85b1d
+      return GRUB_ERR_FILE_NOT_FOUND;
9d85b1d
+
9d85b1d
+    if (grub_strncmp (prefix + 1, "tftp", sizeof ("tftp") - 1) == 0)
9d85b1d
+      {
9d85b1d
+	grub_size_t config_len;
9d85b1d
+	config_len = grub_strlen (prefix) +
9d85b1d
+	  sizeof ("/grub.cfg-XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX");
9d85b1d
+	config = grub_malloc (config_len);
9d85b1d
+
9d85b1d
+	if (! config)
9d85b1d
+	  return GRUB_ERR_FILE_NOT_FOUND;
9d85b1d
+
9d85b1d
+	grub_snprintf (config, config_len, "%s/grub.cfg", prefix);
9d85b1d
+	err = grub_net_search_configfile (config);
9d85b1d
+      }
9d85b1d
+
9d85b1d
+    if (err != GRUB_ERR_NONE)
9d85b1d
+      {
9d85b1d
+	config = grub_xasprintf ("%s/grub.cfg", prefix);
9d85b1d
+	if (config)
9d85b1d
+	  {
9d85b1d
+	    grub_file_t file;
9d85b1d
+	    file = grub_file_open (config);
9d85b1d
+	    if (file)
9d85b1d
+	      {
9d85b1d
+		grub_file_close (file);
9d85b1d
+		err = GRUB_ERR_NONE;
9d85b1d
+	      }
9d85b1d
+	  }
9d85b1d
+      }
9d85b1d
+
9d85b1d
+    if (err == GRUB_ERR_NONE)
9d85b1d
+      grub_enter_normal_mode (config);
9d85b1d
+
9d85b1d
+    grub_errno = 0;
9d85b1d
+    grub_free (config);
9d85b1d
+    return err;
9d85b1d
+}
9d85b1d
+
9d85b1d
 /* Enter normal mode from rescue mode.  */
9d85b1d
 static grub_err_t
9d85b1d
 grub_cmd_normal (struct grub_command *cmd __attribute__ ((unused)),
9d85b1d
 		 int argc, char *argv[])
9d85b1d
 {
9d85b1d
-  if (argc == 0)
9d85b1d
+  if (argc)
9d85b1d
+    grub_enter_normal_mode (argv[0]);
9d85b1d
+  else
9d85b1d
     {
9d85b1d
-      /* Guess the config filename. It is necessary to make CONFIG static,
9d85b1d
-	 so that it won't get broken by longjmp.  */
9d85b1d
-      char *config;
9d85b1d
-      const char *prefix;
9d85b1d
-
9d85b1d
-      prefix = grub_env_get ("fw_path");
9d85b1d
-      if (! prefix)
9d85b1d
-	      prefix = grub_env_get ("prefix");
9d85b1d
-
9d85b1d
-      if (prefix)
9d85b1d
-	{
9d85b1d
-	  if (grub_strncmp (prefix + 1, "tftp", sizeof ("tftp") - 1) == 0)
9d85b1d
-	    {
9d85b1d
-	      grub_size_t config_len;
9d85b1d
-	      config_len = grub_strlen (prefix) +
9d85b1d
-		sizeof ("/grub.cfg-XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX");
9d85b1d
-	      config = grub_malloc (config_len);
9d85b1d
-
9d85b1d
-	      if (! config)
9d85b1d
-		goto quit;
9d85b1d
-
9d85b1d
-	      grub_snprintf (config, config_len, "%s/grub.cfg", prefix);
9d85b1d
-
9d85b1d
-	      grub_net_search_configfile (config);
9d85b1d
-
9d85b1d
-	      grub_enter_normal_mode (config);
9d85b1d
-	      grub_free (config);
9d85b1d
-	      config = NULL;
9d85b1d
-	    }
9d85b1d
-
9d85b1d
-	  if (!config)
9d85b1d
-	    {
9d85b1d
-	      config = grub_xasprintf ("%s/grub.cfg", prefix);
9d85b1d
-	      if (config)
9d85b1d
-		{
9d85b1d
-		  grub_file_t file;
9d85b1d
-
9d85b1d
-		  file = grub_file_open (config);
9d85b1d
-		  if (file)
9d85b1d
-		    {
9d85b1d
-		      grub_file_close (file);
9d85b1d
-		      grub_enter_normal_mode (config);
9d85b1d
-		    }
9d85b1d
-		  else
9d85b1d
-		    {
9d85b1d
-		      /*  Ignore all errors.  */
9d85b1d
-		      grub_errno = 0;
9d85b1d
-		    }
9d85b1d
-		  grub_free (config);
9d85b1d
-		}
9d85b1d
-	    }
9d85b1d
-	}
9d85b1d
-      else
9d85b1d
-	{
9d85b1d
-	  grub_enter_normal_mode (0);
9d85b1d
-	}
9d85b1d
+      /* Guess the config filename. */
9d85b1d
+      grub_err_t err;
9d85b1d
+      err = grub_try_normal ("fw_path");
9d85b1d
+      if (err == GRUB_ERR_FILE_NOT_FOUND)
9d85b1d
+        err = grub_try_normal ("prefix");
9d85b1d
+      if (err == GRUB_ERR_FILE_NOT_FOUND)
9d85b1d
+        grub_enter_normal_mode (0);
9d85b1d
     }
9d85b1d
-  else
9d85b1d
-    grub_enter_normal_mode (argv[0]);
9d85b1d
 
9d85b1d
-quit:
9d85b1d
   return 0;
9d85b1d
 }
9d85b1d
 
9d85b1d
-- 
8c6b1ac
2.4.3
9d85b1d