]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
sparc: Pass buffer pointer all the way down to prom_{get,put}char().
authorDavid S. Miller <davem@davemloft.net>
Tue, 30 Nov 2010 22:33:29 +0000 (14:33 -0800)
committerAK <andi@firstfloor.org>
Sun, 6 Feb 2011 19:03:33 +0000 (11:03 -0800)
[ Upstream commit e62cac1fd035b4cde707285008499dbe71955a86 ]

This gets us closer to being able to eliminate the use
of dynamic and stack based buffers, so that we can adhere
to the "no buffer addresses above 4GB" rule for PROM calls.

Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Signed-off-by: Andi Kleen <ak@linux.intel.com>
arch/sparc/include/asm/openprom.h
arch/sparc/include/asm/oplib_32.h
arch/sparc/include/asm/oplib_64.h
arch/sparc/prom/console_32.c
arch/sparc/prom/console_64.c
arch/sparc/prom/printf.c

index 963e1a45c35faa9df9197e38bb9e5b8c05bf4434..f61a5017878fa36b9b986d5054be8caed72cc78e 100644 (file)
@@ -37,7 +37,7 @@ struct linux_dev_v2_funcs {
        int (*v2_dev_open)(char *devpath);
        void (*v2_dev_close)(int d);
        int (*v2_dev_read)(int d, char *buf, int nbytes);
-       int (*v2_dev_write)(int d, char *buf, int nbytes);
+       int (*v2_dev_write)(int d, const char *buf, int nbytes);
        int (*v2_dev_seek)(int d, int hi, int lo);
 
        /* Never issued (multistage load support) */
index ca51a666f6239030168aa66d170f8301772bf66b..4d708b7d5528426b3aa346c8174d48bad26e67dd 100644 (file)
@@ -105,10 +105,10 @@ extern int prom_getprev(void);
 /* Character operations to/from the console.... */
 
 /* Blocking get character from console. */
-extern char prom_getchar(void);
+extern void prom_getchar(char *buf);
 
 /* Blocking put character to console. */
-extern void prom_putchar(char character);
+extern void prom_putchar(const char *buf);
 
 /* Prom's internal routines, don't use in kernel/boot code. */
 extern void prom_printf(const char *fmt, ...);
index 0d614e3f0871fbfab9480c763bffa25f875292f4..891a00b655eeb5c9771a5fe6322ea06a815fa322 100644 (file)
@@ -97,10 +97,10 @@ extern unsigned char prom_get_idprom(char *idp_buffer, int idpbuf_size);
 /* Character operations to/from the console.... */
 
 /* Blocking get character from console. */
-extern char prom_getchar(void);
+extern void prom_getchar(char *buf);
 
 /* Blocking put character to console. */
-extern void prom_putchar(char character);
+extern void prom_putchar(const char *buf);
 
 /* Prom's internal routines, don't use in kernel/boot code. */
 extern void prom_printf(const char *fmt, ...);
index 2ce5acb45f2dcf0fe77f1fe0f1d04d602efb0c83..69c16bbf1f48612132fdbf83cdbdb95bb48d69d4 100644 (file)
@@ -19,27 +19,27 @@ extern void restore_current(void);
 /* Non blocking get character from console input device, returns -1
  * if no input was taken.  This can be used for polling.
  */
-static int prom_nbgetchar(void)
+static int prom_nbgetchar(char *buf)
 {
-       static char inc;
-       int i = -1;
        unsigned long flags;
+       int i = -1;
 
        spin_lock_irqsave(&prom_lock, flags);
        switch(prom_vers) {
        case PROM_V0:
                i = (*(romvec->pv_nbgetchar))();
+               if (i != -1) {
+                       *buf = i;
+                       i = 0;
+               }
                break;
        case PROM_V2:
        case PROM_V3:
-               if( (*(romvec->pv_v2devops).v2_dev_read)(*romvec->pv_v2bootargs.fd_stdin , &inc, 0x1) == 1) {
-                       i = inc;
-               } else {
-                       i = -1;
-               }
+               if ((*(romvec->pv_v2devops).v2_dev_read)(*romvec->pv_v2bootargs.fd_stdin,
+                                                        buf, 0x1) == 1)
+                       i = 0;
                break;
        default:
-               i = -1;
                break;
        };
        restore_current();
@@ -50,27 +50,23 @@ static int prom_nbgetchar(void)
 /* Non blocking put character to console device, returns -1 if
  * unsuccessful.
  */
-static int prom_nbputchar(char c)
+static int prom_nbputchar(const char *buf)
 {
-       static char outc;
        unsigned long flags;
        int i = -1;
 
        spin_lock_irqsave(&prom_lock, flags);
        switch(prom_vers) {
        case PROM_V0:
-               i = (*(romvec->pv_nbputchar))(c);
+               i = (*(romvec->pv_nbputchar))(*buf);
                break;
        case PROM_V2:
        case PROM_V3:
-               outc = c;
-               if( (*(romvec->pv_v2devops).v2_dev_write)(*romvec->pv_v2bootargs.fd_stdout, &outc, 0x1) == 1)
+               if ((*(romvec->pv_v2devops).v2_dev_write)(*romvec->pv_v2bootargs.fd_stdout,
+                                                         buf, 0x1) == 1)
                        i = 0;
-               else
-                       i = -1;
                break;
        default:
-               i = -1;
                break;
        };
        restore_current();
@@ -79,17 +75,21 @@ static int prom_nbputchar(char c)
 }
 
 /* Blocking version of get character routine above. */
-char
-prom_getchar(void)
+void prom_getchar(char *buf)
 {
-       int character;
-       while((character = prom_nbgetchar()) == -1) ;
-       return (char) character;
+       while (1) {
+               int err = prom_nbgetchar(buf);
+               if (!err)
+                       break;
+       }
 }
 
 /* Blocking version of put character routine above. */
-void
-prom_putchar(char c)
+void prom_putchar(const char *buf)
 {
-       while(prom_nbputchar(c) == -1) ;
+       while (1) {
+               int err = prom_nbputchar(buf);
+               if (!err)
+                       break;
+       }
 }
index 33a8b275d6af0166a3eddd08b97e824ffe849de6..a9a575433ce9de43046d19d2d4d182425bbcb2bd 100644 (file)
@@ -18,41 +18,37 @@ extern int prom_stdin, prom_stdout;
 /* Non blocking get character from console input device, returns -1
  * if no input was taken.  This can be used for polling.
  */
-static int prom_nbgetchar(void)
+static int prom_nbgetchar(char *buf)
 {
        unsigned long args[7];
-       char inc;
 
        args[0] = (unsigned long) "read";
        args[1] = 3;
        args[2] = 1;
        args[3] = (unsigned int) prom_stdin;
-       args[4] = (unsigned long) &inc;
+       args[4] = (unsigned long) buf;
        args[5] = 1;
        args[6] = (unsigned long) -1;
 
        p1275_cmd_direct(args);
 
        if (args[6] == 1)
-               return inc;
+               return 0;
        return -1;
 }
 
 /* Non blocking put character to console device, returns -1 if
  * unsuccessful.
  */
-static int prom_nbputchar(char c)
+static int prom_nbputchar(const char *buf)
 {
        unsigned long args[7];
-       char outc;
-       
-       outc = c;
 
        args[0] = (unsigned long) "write";
        args[1] = 3;
        args[2] = 1;
        args[3] = (unsigned int) prom_stdout;
-       args[4] = (unsigned long) &outc;
+       args[4] = (unsigned long) buf;
        args[5] = 1;
        args[6] = (unsigned long) -1;
 
@@ -65,17 +61,21 @@ static int prom_nbputchar(char c)
 }
 
 /* Blocking version of get character routine above. */
-char
-prom_getchar(void)
+void prom_getchar(char *buf)
 {
-       int character;
-       while((character = prom_nbgetchar()) == -1) ;
-       return (char) character;
+       while (1) {
+               int err = prom_nbgetchar(buf);
+               if (!err)
+                       break;
+       }
 }
 
 /* Blocking version of put character routine above. */
-void
-prom_putchar(char c)
+void prom_putchar(const char *buf)
 {
-       prom_nbputchar(c);
+       while (1) {
+               int err = prom_nbputchar(buf);
+               if (!err)
+                       break;
+       }
 }
index ca869266b9f3d0106e60d7b8c28f5cdcf614826b..24031971f8067b9c9770f34b8f682d62c54b865c 100644 (file)
@@ -23,13 +23,14 @@ static char ppbuf[1024];
 
 void notrace prom_write(const char *buf, unsigned int n)
 {
-       char ch;
-
-       while (n != 0) {
-               --n;
-               if ((ch = *buf++) == '\n')
-                       prom_putchar('\r');
-               prom_putchar(ch);
+       while (n-- != 0) {
+               char ch = *buf;
+               if (ch == '\n') {
+                       char tmp = '\r';
+                       prom_putchar(&tmp);
+               }
+               prom_putchar(buf);
+               buf++;
        }
 }