a5bd9f6
From 8a592c562319ba4c802fa97605ef18bb8bddd112 Mon Sep 17 00:00:00 2001
a5bd9f6
From: Vladimir 'phcoder' Serbinenko <phcoder@gmail.com>
a5bd9f6
Date: Sun, 14 Apr 2013 17:01:31 +0200
a5bd9f6
Subject: [PATCH 302/364] 	Allow IEEE1275 ports on path even if it wasn't
a5bd9f6
 detected automatically. 	Needed on OpenBIOS due to incomplete device
a5bd9f6
 tree.
a5bd9f6
a5bd9f6
---
a5bd9f6
 ChangeLog                        |  5 +++
a5bd9f6
 grub-core/term/ieee1275/serial.c | 78 ++++++++++++++++++++++++++--------------
a5bd9f6
 grub-core/term/serial.c          | 16 +++++++++
a5bd9f6
 include/grub/ieee1275/console.h  |  3 ++
a5bd9f6
 4 files changed, 76 insertions(+), 26 deletions(-)
a5bd9f6
a5bd9f6
diff --git a/ChangeLog b/ChangeLog
a5bd9f6
index 1088061..df9e300 100644
a5bd9f6
--- a/ChangeLog
a5bd9f6
+++ b/ChangeLog
a5bd9f6
@@ -1,5 +1,10 @@
a5bd9f6
 2013-04-14  Vladimir Serbinenko  <phcoder@gmail.com>
a5bd9f6
 
a5bd9f6
+	Allow IEEE1275 ports on path even if it wasn't detected automatically.
a5bd9f6
+	Needed on OpenBIOS due to incomplete device tree.
a5bd9f6
+
a5bd9f6
+2013-04-14  Vladimir Serbinenko  <phcoder@gmail.com>
a5bd9f6
+
a5bd9f6
 	* grub-core/disk/ieee1275/ofdisk.c: Iterate over bootpath even if it
a5bd9f6
 	would be otherwise excluded.
a5bd9f6
 
a5bd9f6
diff --git a/grub-core/term/ieee1275/serial.c b/grub-core/term/ieee1275/serial.c
a5bd9f6
index cda97d0..9e71ca4 100644
a5bd9f6
--- a/grub-core/term/ieee1275/serial.c
a5bd9f6
+++ b/grub-core/term/ieee1275/serial.c
a5bd9f6
@@ -23,6 +23,7 @@
a5bd9f6
 #include <grub/mm.h>
a5bd9f6
 #include <grub/time.h>
a5bd9f6
 #include <grub/i18n.h>
a5bd9f6
+#include <grub/ieee1275/console.h>
a5bd9f6
 
a5bd9f6
 #define IEEE1275_IHANDLE_INVALID  ((grub_ieee1275_cell_t) 0)
a5bd9f6
 
a5bd9f6
@@ -216,11 +217,59 @@ dev_iterate (struct grub_ieee1275_devalias *alias)
a5bd9f6
   return 0;
a5bd9f6
 }
a5bd9f6
 
a5bd9f6
+static const char *
a5bd9f6
+add_port (struct ofserial_hash_ent *ent)
a5bd9f6
+{
a5bd9f6
+  struct grub_serial_port *port;
a5bd9f6
+  char *ptr;
a5bd9f6
+  grub_err_t err;
a5bd9f6
+
a5bd9f6
+  if (!ent->shortest)
a5bd9f6
+    return NULL;
a5bd9f6
+
a5bd9f6
+  port = grub_zalloc (sizeof (*port));
a5bd9f6
+  if (!port)
a5bd9f6
+    return NULL;
a5bd9f6
+  port->name = grub_malloc (sizeof ("ieee1275/")
a5bd9f6
+			    + grub_strlen (ent->shortest));
a5bd9f6
+  port->elem = ent;
a5bd9f6
+  if (!port->name)
a5bd9f6
+    return NULL;
a5bd9f6
+  ptr = grub_stpcpy (port->name, "ieee1275/");
a5bd9f6
+  grub_strcpy (ptr, ent->shortest);
a5bd9f6
+
a5bd9f6
+  port->driver = &grub_ofserial_driver;
a5bd9f6
+  err = grub_serial_config_defaults (port);
a5bd9f6
+  if (err)
a5bd9f6
+    grub_print_error ();
a5bd9f6
+
a5bd9f6
+  grub_serial_register (port);
a5bd9f6
+
a5bd9f6
+  return port->name;
a5bd9f6
+}
a5bd9f6
+
a5bd9f6
+const char *
a5bd9f6
+grub_ofserial_add_port (const char *path)
a5bd9f6
+{
a5bd9f6
+  struct ofserial_hash_ent *ent;
a5bd9f6
+  char *name = grub_strdup (path);
a5bd9f6
+  char *can = grub_strdup (path);
a5bd9f6
+
a5bd9f6
+  if (!name || ! can)
a5bd9f6
+    {
a5bd9f6
+      grub_free (name);
a5bd9f6
+      grub_free (can);
a5bd9f6
+      return NULL;
a5bd9f6
+    }
a5bd9f6
+
a5bd9f6
+  ent = ofserial_hash_add (name, can);
a5bd9f6
+  return add_port (ent);
a5bd9f6
+}
a5bd9f6
+
a5bd9f6
 void
a5bd9f6
 grub_ofserial_init (void)
a5bd9f6
 {
a5bd9f6
   unsigned i;
a5bd9f6
-  grub_err_t err;
a5bd9f6
   struct grub_ieee1275_devalias alias;
a5bd9f6
 
a5bd9f6
   FOR_IEEE1275_DEVALIASES(alias)
a5bd9f6
@@ -230,32 +279,9 @@ grub_ofserial_init (void)
a5bd9f6
   
a5bd9f6
   for (i = 0; i < ARRAY_SIZE (ofserial_hash); i++)
a5bd9f6
     {
a5bd9f6
-      static struct ofserial_hash_ent *ent;
a5bd9f6
+      struct ofserial_hash_ent *ent;
a5bd9f6
       for (ent = ofserial_hash[i]; ent; ent = ent->next)
a5bd9f6
-	{
a5bd9f6
-	  struct grub_serial_port *port;
a5bd9f6
-	  char *ptr;
a5bd9f6
-	  if (!ent->shortest)
a5bd9f6
-	    continue;
a5bd9f6
-
a5bd9f6
-	  port = grub_zalloc (sizeof (*port));
a5bd9f6
-	  if (!port)
a5bd9f6
-	    return;
a5bd9f6
-	  port->name = grub_malloc (sizeof ("ieee1275/")
a5bd9f6
-				    + grub_strlen (ent->shortest));
a5bd9f6
-	  port->elem = ent;
a5bd9f6
-	  if (!port->name)
a5bd9f6
-	    return;
a5bd9f6
-	  ptr = grub_stpcpy (port->name, "ieee1275/");
a5bd9f6
-	  grub_strcpy (ptr, ent->shortest);
a5bd9f6
-
a5bd9f6
-	  port->driver = &grub_ofserial_driver;
a5bd9f6
-	  err = grub_serial_config_defaults (port);
a5bd9f6
-	  if (err)
a5bd9f6
-	    grub_print_error ();
a5bd9f6
-
a5bd9f6
-	  grub_serial_register (port);
a5bd9f6
-	}
a5bd9f6
+	add_port (ent);
a5bd9f6
     }
a5bd9f6
 }
a5bd9f6
 
a5bd9f6
diff --git a/grub-core/term/serial.c b/grub-core/term/serial.c
a5bd9f6
index cfcfe84..96f9d7f 100644
a5bd9f6
--- a/grub-core/term/serial.c
a5bd9f6
+++ b/grub-core/term/serial.c
a5bd9f6
@@ -31,6 +31,9 @@
a5bd9f6
 #ifdef GRUB_MACHINE_MIPS_LOONGSON
a5bd9f6
 #include <grub/machine/kernel.h>
a5bd9f6
 #endif
a5bd9f6
+#ifdef GRUB_MACHINE_IEEE1275
a5bd9f6
+#include <grub/ieee1275/console.h>
a5bd9f6
+#endif
a5bd9f6
 
a5bd9f6
 GRUB_MOD_LICENSE ("GPLv3+");
a5bd9f6
 
a5bd9f6
@@ -149,6 +152,19 @@ grub_serial_find (const char *name)
a5bd9f6
     }
a5bd9f6
 #endif
a5bd9f6
 
a5bd9f6
+#ifdef GRUB_MACHINE_IEEE1275
a5bd9f6
+  if (!port && grub_memcmp (name, "ieee1275/", sizeof ("ieee1275/") - 1) == 0)
a5bd9f6
+    {
a5bd9f6
+      name = grub_ofserial_add_port (&name[sizeof ("ieee1275/") - 1]);
a5bd9f6
+      if (!name)
a5bd9f6
+	return NULL;
a5bd9f6
+
a5bd9f6
+      FOR_SERIAL_PORTS (port)
a5bd9f6
+	if (grub_strcmp (port->name, name) == 0)
a5bd9f6
+	  break;
a5bd9f6
+    }
a5bd9f6
+#endif
a5bd9f6
+
a5bd9f6
   return port;
a5bd9f6
 }
a5bd9f6
 
a5bd9f6
diff --git a/include/grub/ieee1275/console.h b/include/grub/ieee1275/console.h
a5bd9f6
index e054f54..bdd98fe 100644
a5bd9f6
--- a/include/grub/ieee1275/console.h
a5bd9f6
+++ b/include/grub/ieee1275/console.h
a5bd9f6
@@ -28,4 +28,7 @@ void grub_console_init_lately (void);
a5bd9f6
 /* Finish the console system.  */
a5bd9f6
 void grub_console_fini (void);
a5bd9f6
 
a5bd9f6
+const char *
a5bd9f6
+grub_ofserial_add_port (const char *name);
a5bd9f6
+
a5bd9f6
 #endif /* ! GRUB_CONSOLE_MACHINE_HEADER */
a5bd9f6
-- 
a5bd9f6
1.8.1.4
a5bd9f6