]> git.proxmox.com Git - grub2.git/commitdiff
Port yaboot logic for various powerpc machine types
authorColin Watson <cjwatson@debian.org>
Tue, 28 Jan 2014 14:40:02 +0000 (14:40 +0000)
committerColin Watson <cjwatson@debian.org>
Mon, 19 Sep 2016 11:15:51 +0000 (12:15 +0100)
Some powerpc machines require not updating the NVRAM.  This can be handled
by existing grub-install command-line options, but it's friendlier to detect
this automatically.

On chrp_ibm machines, use the nvram utility rather than nvsetenv.  (This
is possibly suitable for other machines too, but that needs to be
verified.)

Forwarded: no
Last-Update: 2014-10-15

Patch-Name: install_powerpc_machtypes.patch

grub-core/osdep/basic/platform.c
grub-core/osdep/linux/platform.c
grub-core/osdep/unix/platform.c
grub-core/osdep/windows/platform.c
include/grub/util/install.h
util/grub-install.c

index 4b5502aeb73e2b763fcc097ee144e6959bf33430..2ab907976356a7cd0a98a61557ca9195e3dfc42a 100644 (file)
@@ -24,3 +24,8 @@ grub_install_get_default_x86_platform (void)
   return "i386-pc";
 }
 
+const char *
+grub_install_get_default_powerpc_machtype (void)
+{
+  return "generic";
+}
index 35f1bcc0e1d2bc9062925b8ce7e914a92ead0ae5..9805c36d43b2189c418c29deb6db748f2fde4556 100644 (file)
@@ -24,6 +24,7 @@
 #include <grub/emu/misc.h>
 #include <sys/types.h>
 #include <dirent.h>
+#include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
 
@@ -145,3 +146,74 @@ grub_install_get_default_x86_platform (void)
   grub_util_info ("... not found");
   return "i386-pc";
 }
+
+const char *
+grub_install_get_default_powerpc_machtype (void)
+{
+  FILE *fp;
+  char *buf = NULL;
+  size_t len = 0;
+  const char *machtype = "generic";
+
+  fp = grub_util_fopen ("/proc/cpuinfo", "r");
+  if (! fp)
+    return machtype;
+
+  while (getline (&buf, &len, fp) > 0)
+    {
+      if (strncmp (buf, "pmac-generation",
+                  sizeof ("pmac-generation") - 1) == 0)
+       {
+         if (strstr (buf, "NewWorld"))
+           {
+             machtype = "pmac_newworld";
+             break;
+           }
+         if (strstr (buf, "OldWorld"))
+           {
+             machtype = "pmac_oldworld";
+             break;
+           }
+       }
+
+      if (strncmp (buf, "motherboard", sizeof ("motherboard") - 1) == 0 &&
+         strstr (buf, "AAPL"))
+       {
+         machtype = "pmac_oldworld";
+         break;
+       }
+
+      if (strncmp (buf, "machine", sizeof ("machine") - 1) == 0 &&
+         strstr (buf, "CHRP IBM"))
+       {
+         if (strstr (buf, "qemu"))
+           {
+             machtype = "chrp_ibm_qemu";
+             break;
+           }
+         else
+           {
+             machtype = "chrp_ibm";
+             break;
+           }
+       }
+
+      if (strncmp (buf, "platform", sizeof ("platform") - 1) == 0)
+       {
+         if (strstr (buf, "Maple"))
+           {
+             machtype = "maple";
+             break;
+           }
+         if (strstr (buf, "Cell"))
+           {
+             machtype = "cell";
+             break;
+           }
+       }
+    }
+
+  free (buf);
+  fclose (fp);
+  return machtype;
+}
index a3fcfcacaa814d3ab62104f0dd406ef0c2163613..28cb37e1530092355a121a007cd79cde63841dcc 100644 (file)
@@ -212,13 +212,29 @@ grub_install_register_ieee1275 (int is_prep, const char *install_device,
   else
     boot_device = get_ofpathname (install_device);
 
-  if (grub_util_exec ((const char * []){ "nvsetenv", "boot-device",
-         boot_device, NULL }))
+  if (strcmp (grub_install_get_default_powerpc_machtype (), "chrp_ibm") == 0)
     {
-      char *cmd = xasprintf ("setenv boot-device %s", boot_device);
-      grub_util_error (_("`nvsetenv' failed. \nYou will have to set `boot-device' variable manually.  At the IEEE1275 prompt, type:\n  %s\n"),
-                      cmd);
-      free (cmd);
+      char *arg = xasprintf ("boot-device=%s", boot_device);
+      if (grub_util_exec ((const char * []){ "nvram",
+         "--update-config", arg, NULL }))
+       {
+         char *cmd = xasprintf ("setenv boot-device %s", boot_device);
+         grub_util_error (_("`nvram' failed. \nYou will have to set `boot-device' variable manually.  At the IEEE1275 prompt, type:\n  %s\n"),
+                          cmd);
+         free (cmd);
+       }
+      free (arg);
+    }
+  else
+    {
+      if (grub_util_exec ((const char * []){ "nvsetenv", "boot-device",
+             boot_device, NULL }))
+       {
+         char *cmd = xasprintf ("setenv boot-device %s", boot_device);
+         grub_util_error (_("`nvsetenv' failed. \nYou will have to set `boot-device' variable manually.  At the IEEE1275 prompt, type:\n  %s\n"),
+                          cmd);
+         free (cmd);
+       }
     }
 
   free (boot_device);
index 912269191ebf65a1e0ab50d5cd1f21b4614fd78b..c30025b13588f643cce1375e63b6b7bc75a241b6 100644 (file)
@@ -128,6 +128,12 @@ grub_install_get_default_x86_platform (void)
     return "i386-efi";
 }
 
+const char *
+grub_install_get_default_powerpc_machtype (void)
+{
+  return "generic";
+}
+
 static void *
 get_efi_variable (const wchar_t *varname, ssize_t *len)
 {
index 5ca4811cd130f6810f07e6fbce89af1de36827c7..9f517a1bbbff3bfa102a12f9b864d5a75c5c1879 100644 (file)
@@ -206,6 +206,9 @@ grub_install_create_envblk_file (const char *name);
 const char *
 grub_install_get_default_x86_platform (void);
 
+const char *
+grub_install_get_default_powerpc_machtype (void);
+
 void
 grub_install_register_efi (grub_device_t efidir_grub_dev,
                           const char *efifile_path,
index 99c075d578873264fe579eef0181abad07064673..3ca3d1ade7f17ea45e56c03687edeca4cdbd3c3f 100644 (file)
@@ -1155,7 +1155,18 @@ main (int argc, char *argv[])
 
   if (platform == GRUB_INSTALL_PLATFORM_POWERPC_IEEE1275)
     {
+      const char *machtype = grub_install_get_default_powerpc_machtype ();
       int is_guess = 0;
+
+      if (strcmp (machtype, "pmac_oldworld") == 0)
+       update_nvram = 0;
+      else if (strcmp (machtype, "cell") == 0)
+       update_nvram = 0;
+      else if (strcmp (machtype, "generic") == 0)
+       update_nvram = 0;
+      else if (strcmp (machtype, "chrp_ibm_qemu") == 0)
+       update_nvram = 0;
+
       if (!macppcdir)
        {
          char *d;