2007-10-27 15:13:04 +08:00
|
|
|
/* console.c: Routines that deal with sending and receiving IO
|
2005-04-17 06:20:36 +08:00
|
|
|
* to/from the current console device using the PROM.
|
|
|
|
*
|
2007-10-27 15:13:04 +08:00
|
|
|
* Copyright (C) 1995 David S. Miller (davem@davemloft.net)
|
2005-04-17 06:20:36 +08:00
|
|
|
* Copyright (C) 1996,1997 Jakub Jelinek (jj@sunsite.mff.cuni.cz)
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/types.h>
|
|
|
|
#include <linux/kernel.h>
|
|
|
|
#include <linux/sched.h>
|
|
|
|
#include <asm/openprom.h>
|
|
|
|
#include <asm/oplib.h>
|
|
|
|
#include <asm/system.h>
|
|
|
|
#include <linux/string.h>
|
|
|
|
|
|
|
|
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.
|
|
|
|
*/
|
2010-11-18 02:22:56 +08:00
|
|
|
static int prom_nbgetchar(void)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
2010-08-24 14:10:57 +08:00
|
|
|
unsigned long args[7];
|
2005-04-17 06:20:36 +08:00
|
|
|
char inc;
|
|
|
|
|
2010-08-24 14:10:57 +08:00
|
|
|
args[0] = (unsigned long) "read";
|
|
|
|
args[1] = 3;
|
|
|
|
args[2] = 1;
|
|
|
|
args[3] = (unsigned int) prom_stdin;
|
|
|
|
args[4] = (unsigned long) &inc;
|
|
|
|
args[5] = 1;
|
|
|
|
args[6] = (unsigned long) -1;
|
|
|
|
|
|
|
|
p1275_cmd_direct(args);
|
|
|
|
|
|
|
|
if (args[6] == 1)
|
2005-04-17 06:20:36 +08:00
|
|
|
return inc;
|
2010-08-24 14:10:57 +08:00
|
|
|
return -1;
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Non blocking put character to console device, returns -1 if
|
|
|
|
* unsuccessful.
|
|
|
|
*/
|
2010-11-18 02:22:56 +08:00
|
|
|
static int prom_nbputchar(char c)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
2010-08-24 14:10:57 +08:00
|
|
|
unsigned long args[7];
|
2005-04-17 06:20:36 +08:00
|
|
|
char outc;
|
|
|
|
|
|
|
|
outc = c;
|
2010-08-24 14:10:57 +08:00
|
|
|
|
|
|
|
args[0] = (unsigned long) "write";
|
|
|
|
args[1] = 3;
|
|
|
|
args[2] = 1;
|
|
|
|
args[3] = (unsigned int) prom_stdout;
|
|
|
|
args[4] = (unsigned long) &outc;
|
|
|
|
args[5] = 1;
|
|
|
|
args[6] = (unsigned long) -1;
|
|
|
|
|
|
|
|
p1275_cmd_direct(args);
|
|
|
|
|
|
|
|
if (args[6] == 1)
|
2005-04-17 06:20:36 +08:00
|
|
|
return 0;
|
|
|
|
else
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Blocking version of get character routine above. */
|
|
|
|
char
|
|
|
|
prom_getchar(void)
|
|
|
|
{
|
|
|
|
int character;
|
|
|
|
while((character = prom_nbgetchar()) == -1) ;
|
|
|
|
return (char) character;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Blocking version of put character routine above. */
|
|
|
|
void
|
|
|
|
prom_putchar(char c)
|
|
|
|
{
|
|
|
|
prom_nbputchar(c);
|
|
|
|
}
|