Gitweb:     
http://git.kernel.org/git/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commit;h=084647125227b870267859d544c91c03743816dc
Commit:     084647125227b870267859d544c91c03743816dc
Parent:     131208c5bb51b794ee73013aeb3396bd015fb79e
Author:     David Gibson <[EMAIL PROTECTED]>
AuthorDate: Wed Jun 27 16:54:58 2007 +1000
Committer:  Paul Mackerras <[EMAIL PROTECTED]>
CommitDate: Thu Jun 28 19:19:28 2007 +1000

    [POWERPC] Make more OF-related bootwrapper functions available to non-OF 
platforms
    
    Commit 2e6016133755eb3cc44e8efab92573d23ed75888 split up
    arch/powerpc/boot/of.c so that some OF functions can be used on
    platforms that don't want to use the overall OF platform boot code.
    This is useful on things like PReP which can have an OF implementation
    which is useful for debugging output, but inadequate for booting.
    
    However, that commit didn't export quite enough things to make a
    usable OF console on a non-OF system.  In particular, the device tree
    manipulation performed to initialize the OF console code must
    explicitly use the OF device tree, rather than the flattened device
    tree, even if the system is otherwise booting using a flattened device
    tree.  This makes it so.
    
    Signed-off-by: David Gibson <[EMAIL PROTECTED]>
    Signed-off-by: Paul Mackerras <[EMAIL PROTECTED]>
---
 arch/powerpc/boot/of.c        |   30 ------------------------------
 arch/powerpc/boot/of.h        |    6 ++++++
 arch/powerpc/boot/ofconsole.c |    8 ++++----
 arch/powerpc/boot/oflib.c     |   40 +++++++++++++++++++++++++++++++++++-----
 4 files changed, 45 insertions(+), 39 deletions(-)

diff --git a/arch/powerpc/boot/of.c b/arch/powerpc/boot/of.c
index 6108aef..385e08b 100644
--- a/arch/powerpc/boot/of.c
+++ b/arch/powerpc/boot/of.c
@@ -63,36 +63,6 @@ static void of_image_hdr(const void *hdr)
        }
 }
 
-static void *of_vmlinux_alloc(unsigned long size)
-{
-       void *p = malloc(size);
-
-       if (!p)
-               fatal("Can't allocate memory for kernel image!\n\r");
-
-       return p;
-}
-
-/*
- * OF device tree routines
- */
-static void *of_finddevice(const char *name)
-{
-       return (phandle) of_call_prom("finddevice", 1, 1, name);
-}
-
-static int of_getprop(const void *phandle, const char *name, void *buf,
-               const int buflen)
-{
-       return of_call_prom("getprop", 4, 1, phandle, name, buf, buflen);
-}
-
-static int of_setprop(const void *phandle, const char *name, const void *buf,
-               const int buflen)
-{
-       return of_call_prom("setprop", 4, 1, phandle, name, buf, buflen);
-}
-
 void platform_init(unsigned long a1, unsigned long a2, void *promptr)
 {
        platform_ops.image_hdr = of_image_hdr;
diff --git a/arch/powerpc/boot/of.h b/arch/powerpc/boot/of.h
index 169d311..e4c68f7 100644
--- a/arch/powerpc/boot/of.h
+++ b/arch/powerpc/boot/of.h
@@ -7,7 +7,13 @@ typedef void *ihandle;
 void of_init(void *promptr);
 int of_call_prom(const char *service, int nargs, int nret, ...);
 void *of_claim(unsigned long virt, unsigned long size, unsigned long align);
+void *of_vmlinux_alloc(unsigned long size);
 void of_exit(void);
+void *of_finddevice(const char *name);
+int of_getprop(const void *phandle, const char *name, void *buf,
+              const int buflen);
+int of_setprop(const void *phandle, const char *name, const void *buf,
+              const int buflen);
 
 /* Console functions */
 void of_console_init(void);
diff --git a/arch/powerpc/boot/ofconsole.c b/arch/powerpc/boot/ofconsole.c
index 43c0f36..ce0e024 100644
--- a/arch/powerpc/boot/ofconsole.c
+++ b/arch/powerpc/boot/ofconsole.c
@@ -24,10 +24,10 @@ static int of_console_open(void)
 {
        void *devp;
 
-       if (((devp = finddevice("/chosen")) != NULL)
-                       && (getprop(devp, "stdout", &of_stdout_handle,
-                               sizeof(of_stdout_handle))
-                               == sizeof(of_stdout_handle)))
+       if (((devp = of_finddevice("/chosen")) != NULL)
+           && (of_getprop(devp, "stdout", &of_stdout_handle,
+                          sizeof(of_stdout_handle))
+               == sizeof(of_stdout_handle)))
                return 0;
 
        return -1;
diff --git a/arch/powerpc/boot/oflib.c b/arch/powerpc/boot/oflib.c
index e9b95d8..95b8fd6 100644
--- a/arch/powerpc/boot/oflib.c
+++ b/arch/powerpc/boot/oflib.c
@@ -110,25 +110,25 @@ static int check_of_version(void)
        phandle oprom, chosen;
        char version[64];
 
-       oprom = finddevice("/openprom");
+       oprom = of_finddevice("/openprom");
        if (oprom == (phandle) -1)
                return 0;
-       if (getprop(oprom, "model", version, sizeof(version)) <= 0)
+       if (of_getprop(oprom, "model", version, sizeof(version)) <= 0)
                return 0;
        version[sizeof(version)-1] = 0;
        printf("OF version = '%s'\r\n", version);
        if (!string_match(version, "Open Firmware, 1.")
            && !string_match(version, "FirmWorks,3."))
                return 0;
-       chosen = finddevice("/chosen");
+       chosen = of_finddevice("/chosen");
        if (chosen == (phandle) -1) {
-               chosen = finddevice("/[EMAIL PROTECTED]");
+               chosen = of_finddevice("/[EMAIL PROTECTED]");
                if (chosen == (phandle) -1) {
                        printf("no chosen\n");
                        return 0;
                }
        }
-       if (getprop(chosen, "mmu", &chosen_mmu, sizeof(chosen_mmu)) <= 0) {
+       if (of_getprop(chosen, "mmu", &chosen_mmu, sizeof(chosen_mmu)) <= 0) {
                printf("no mmu\n");
                return 0;
        }
@@ -166,7 +166,37 @@ void *of_claim(unsigned long virt, unsigned long size, 
unsigned long align)
        return (void *) virt;
 }
 
+void *of_vmlinux_alloc(unsigned long size)
+{
+       void *p = malloc(size);
+
+       if (!p)
+               fatal("Can't allocate memory for kernel image!\n\r");
+
+       return p;
+}
+
 void of_exit(void)
 {
        of_call_prom("exit", 0, 0);
 }
+
+/*
+ * OF device tree routines
+ */
+void *of_finddevice(const char *name)
+{
+       return (phandle) of_call_prom("finddevice", 1, 1, name);
+}
+
+int of_getprop(const void *phandle, const char *name, void *buf,
+              const int buflen)
+{
+       return of_call_prom("getprop", 4, 1, phandle, name, buf, buflen);
+}
+
+int of_setprop(const void *phandle, const char *name, const void *buf,
+              const int buflen)
+{
+       return of_call_prom("setprop", 4, 1, phandle, name, buf, buflen);
+}
-
To unsubscribe from this list: send the line "unsubscribe git-commits-head" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to