1 /* $Id: console.c,v 1.9 1997/10/29 07:41:43 ecd Exp $
 
   2  * console.c: Routines that deal with sending and receiving IO
 
   3  *            to/from the current console device using the PROM.
 
   5  * Copyright (C) 1995 David S. Miller (davem@caip.rutgers.edu)
 
   6  * Copyright (C) 1996,1997 Jakub Jelinek (jj@sunsite.mff.cuni.cz)
 
   9 #include <linux/types.h>
 
  10 #include <linux/kernel.h>
 
  11 #include <linux/sched.h>
 
  12 #include <asm/openprom.h>
 
  13 #include <asm/oplib.h>
 
  14 #include <asm/system.h>
 
  15 #include <linux/string.h>
 
  17 extern int prom_stdin, prom_stdout;
 
  19 /* Non blocking get character from console input device, returns -1
 
  20  * if no input was taken.  This can be used for polling.
 
  27         if (p1275_cmd("read", P1275_ARG(1,P1275_ARG_OUT_BUF)|
 
  29                               prom_stdin, &inc, P1275_SIZE(1)) == 1)
 
  35 /* Non blocking put character to console device, returns -1 if
 
  39 prom_nbputchar(char c)
 
  44         if (p1275_cmd("write", P1275_ARG(1,P1275_ARG_IN_BUF)|
 
  46                                prom_stdout, &outc, P1275_SIZE(1)) == 1)
 
  52 /* Blocking version of get character routine above. */
 
  57         while((character = prom_nbgetchar()) == -1) ;
 
  58         return (char) character;
 
  61 /* Blocking version of put character routine above. */
 
  70 prom_puts(const char *s, int len)
 
  72         p1275_cmd("write", P1275_ARG(1,P1275_ARG_IN_BUF)|
 
  74                            prom_stdout, s, P1275_SIZE(len));
 
  77 /* Query for input device type */
 
  78 enum prom_input_device
 
  79 prom_query_input_device(void)
 
  84         st_p = prom_inst2pkg(prom_stdin);
 
  85         if(prom_node_has_property(st_p, "keyboard"))
 
  87         prom_getproperty(st_p, "device_type", propb, sizeof(propb));
 
  88         if(strncmp(propb, "serial", 6))
 
  90         /* FIXME: Is there any better way how to find out? */   
 
  91         memset(propb, 0, sizeof(propb));
 
  92         st_p = prom_finddevice ("/options");
 
  93         prom_getproperty(st_p, "input-device", propb, sizeof(propb));
 
  96          * If we get here with propb == 'keyboard', we are on ttya, as
 
  97          * the PROM defaulted to this due to 'no input device'.
 
  99         if (!strncmp(propb, "keyboard", 8))
 
 100                 return PROMDEV_ITTYA;
 
 102         if (!strncmp (propb, "rsc", 3))
 
 105         if (strncmp (propb, "tty", 3) || !propb[3])
 
 106                 return PROMDEV_I_UNK;
 
 109                 case 'a': return PROMDEV_ITTYA;
 
 110                 case 'b': return PROMDEV_ITTYB;
 
 111                 default: return PROMDEV_I_UNK;
 
 115 /* Query for output device type */
 
 117 enum prom_output_device
 
 118 prom_query_output_device(void)
 
 124         st_p = prom_inst2pkg(prom_stdout);
 
 125         propl = prom_getproperty(st_p, "device_type", propb, sizeof(propb));
 
 126         if (propl >= 0 && propl == sizeof("display") &&
 
 127             strncmp("display", propb, sizeof("display")) == 0)
 
 128                 return PROMDEV_OSCREEN;
 
 129         if(strncmp("serial", propb, 6))
 
 130                 return PROMDEV_O_UNK;
 
 131         /* FIXME: Is there any better way how to find out? */   
 
 132         memset(propb, 0, sizeof(propb));
 
 133         st_p = prom_finddevice ("/options");
 
 134         prom_getproperty(st_p, "output-device", propb, sizeof(propb));
 
 137          * If we get here with propb == 'screen', we are on ttya, as
 
 138          * the PROM defaulted to this due to 'no input device'.
 
 140         if (!strncmp(propb, "screen", 6))
 
 141                 return PROMDEV_OTTYA;
 
 143         if (!strncmp (propb, "rsc", 3))
 
 146         if (strncmp (propb, "tty", 3) || !propb[3])
 
 147                 return PROMDEV_O_UNK;
 
 150                 case 'a': return PROMDEV_OTTYA;
 
 151                 case 'b': return PROMDEV_OTTYB;
 
 152                 default: return PROMDEV_O_UNK;