Commit fed23ed7 authored by Cédric Le Goater's avatar Cédric Le Goater Committed by Benjamin Herrenschmidt

powerpc/boot: Use a common prom_args struct in oflib

This patch fixes warnings when the wrapper is compiled in 64bit and
updates the boot wrapper code related to prom to converge with the
kernel code in prom_init. This should make the review of changes easier.

The kernel has a different number of possible arguments (10) when
entering prom. There does not seem to be any good reason to have
12 in the wrapper, so the patch changes this value to args[10] in
the prom_args struct.
Signed-off-by: default avatarCédric Le Goater <clg@fr.ibm.com>
Signed-off-by: default avatarBenjamin Herrenschmidt <benh@kernel.crashing.org>
parent f4bce2f7
...@@ -18,4 +18,6 @@ int of_setprop(const void *phandle, const char *name, const void *buf, ...@@ -18,4 +18,6 @@ int of_setprop(const void *phandle, const char *name, const void *buf,
/* Console functions */ /* Console functions */
void of_console_init(void); void of_console_init(void);
typedef u32 __be32;
#endif /* _PPC_BOOT_OF_H_ */ #endif /* _PPC_BOOT_OF_H_ */
...@@ -16,6 +16,15 @@ ...@@ -16,6 +16,15 @@
#include "of.h" #include "of.h"
/* The following structure is used to communicate with open firmware.
* All arguments in and out are in big endian format. */
struct prom_args {
__be32 service; /* Address of service name string. */
__be32 nargs; /* Number of input arguments. */
__be32 nret; /* Number of output arguments. */
__be32 args[10]; /* Input/output arguments. */
};
static int (*prom) (void *); static int (*prom) (void *);
void of_init(void *promptr) void of_init(void *promptr)
...@@ -23,18 +32,15 @@ void of_init(void *promptr) ...@@ -23,18 +32,15 @@ void of_init(void *promptr)
prom = (int (*)(void *))promptr; prom = (int (*)(void *))promptr;
} }
#define ADDR(x) (u32)(unsigned long)(x)
int of_call_prom(const char *service, int nargs, int nret, ...) int of_call_prom(const char *service, int nargs, int nret, ...)
{ {
int i; int i;
struct prom_args { struct prom_args args;
const char *service;
int nargs;
int nret;
unsigned int args[12];
} args;
va_list list; va_list list;
args.service = service; args.service = ADDR(service);
args.nargs = nargs; args.nargs = nargs;
args.nret = nret; args.nret = nret;
...@@ -56,15 +62,10 @@ static int of_call_prom_ret(const char *service, int nargs, int nret, ...@@ -56,15 +62,10 @@ static int of_call_prom_ret(const char *service, int nargs, int nret,
unsigned int *rets, ...) unsigned int *rets, ...)
{ {
int i; int i;
struct prom_args { struct prom_args args;
const char *service;
int nargs;
int nret;
unsigned int args[12];
} args;
va_list list; va_list list;
args.service = service; args.service = ADDR(service);
args.nargs = nargs; args.nargs = nargs;
args.nret = nret; args.nret = nret;
......
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