Commit 08464712 authored by David Gibson's avatar David Gibson Committed by Paul Mackerras

[POWERPC] Make more OF-related bootwrapper functions available to non-OF platforms

Commit 2e601613 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: default avatarDavid Gibson <david@gibson.dropbear.id.au>
Signed-off-by: default avatarPaul Mackerras <paulus@samba.org>
parent 131208c5
...@@ -63,36 +63,6 @@ static void of_image_hdr(const void *hdr) ...@@ -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) void platform_init(unsigned long a1, unsigned long a2, void *promptr)
{ {
platform_ops.image_hdr = of_image_hdr; platform_ops.image_hdr = of_image_hdr;
......
...@@ -7,7 +7,13 @@ typedef void *ihandle; ...@@ -7,7 +7,13 @@ typedef void *ihandle;
void of_init(void *promptr); void of_init(void *promptr);
int of_call_prom(const char *service, int nargs, int nret, ...); 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_claim(unsigned long virt, unsigned long size, unsigned long align);
void *of_vmlinux_alloc(unsigned long size);
void of_exit(void); 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 */ /* Console functions */
void of_console_init(void); void of_console_init(void);
......
...@@ -24,10 +24,10 @@ static int of_console_open(void) ...@@ -24,10 +24,10 @@ static int of_console_open(void)
{ {
void *devp; void *devp;
if (((devp = finddevice("/chosen")) != NULL) if (((devp = of_finddevice("/chosen")) != NULL)
&& (getprop(devp, "stdout", &of_stdout_handle, && (of_getprop(devp, "stdout", &of_stdout_handle,
sizeof(of_stdout_handle)) sizeof(of_stdout_handle))
== sizeof(of_stdout_handle))) == sizeof(of_stdout_handle)))
return 0; return 0;
return -1; return -1;
......
...@@ -110,25 +110,25 @@ static int check_of_version(void) ...@@ -110,25 +110,25 @@ static int check_of_version(void)
phandle oprom, chosen; phandle oprom, chosen;
char version[64]; char version[64];
oprom = finddevice("/openprom"); oprom = of_finddevice("/openprom");
if (oprom == (phandle) -1) if (oprom == (phandle) -1)
return 0; return 0;
if (getprop(oprom, "model", version, sizeof(version)) <= 0) if (of_getprop(oprom, "model", version, sizeof(version)) <= 0)
return 0; return 0;
version[sizeof(version)-1] = 0; version[sizeof(version)-1] = 0;
printf("OF version = '%s'\r\n", version); printf("OF version = '%s'\r\n", version);
if (!string_match(version, "Open Firmware, 1.") if (!string_match(version, "Open Firmware, 1.")
&& !string_match(version, "FirmWorks,3.")) && !string_match(version, "FirmWorks,3."))
return 0; return 0;
chosen = finddevice("/chosen"); chosen = of_finddevice("/chosen");
if (chosen == (phandle) -1) { if (chosen == (phandle) -1) {
chosen = finddevice("/chosen@0"); chosen = of_finddevice("/chosen@0");
if (chosen == (phandle) -1) { if (chosen == (phandle) -1) {
printf("no chosen\n"); printf("no chosen\n");
return 0; 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"); printf("no mmu\n");
return 0; return 0;
} }
...@@ -166,7 +166,37 @@ void *of_claim(unsigned long virt, unsigned long size, unsigned long align) ...@@ -166,7 +166,37 @@ void *of_claim(unsigned long virt, unsigned long size, unsigned long align)
return (void *) virt; 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) void of_exit(void)
{ {
of_call_prom("exit", 0, 0); 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);
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment