summaryrefslogtreecommitdiff
path: root/sys/arch/i386/isa/pccons.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/i386/isa/pccons.c')
-rw-r--r--sys/arch/i386/isa/pccons.c103
1 files changed, 66 insertions, 37 deletions
diff --git a/sys/arch/i386/isa/pccons.c b/sys/arch/i386/isa/pccons.c
index 70c50329c7e..e0cd32945d9 100644
--- a/sys/arch/i386/isa/pccons.c
+++ b/sys/arch/i386/isa/pccons.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: pccons.c,v 1.11 1996/04/24 18:16:55 mickey Exp $ */
-/* $NetBSD: pccons.c,v 1.96 1996/04/11 22:15:25 cgd Exp $ */
+/* $OpenBSD: pccons.c,v 1.12 1996/05/07 07:22:23 deraadt Exp $ */
+/* $NetBSD: pccons.c,v 1.97 1996/05/03 19:15:00 christos Exp $ */
/*-
* Copyright (c) 1993, 1994, 1995 Charles Hannum. All rights reserved.
@@ -46,7 +46,6 @@
#include <sys/param.h>
#include <sys/systm.h>
-#include <sys/conf.h>
#include <sys/ioctl.h>
#include <sys/proc.h>
#include <sys/user.h>
@@ -64,6 +63,7 @@
#include <machine/pio.h>
#include <machine/pc/display.h>
#include <machine/pccons.h>
+#include <machine/conf.h>
#include <dev/isa/isareg.h>
#include <dev/isa/isavar.h>
@@ -140,19 +140,36 @@ void sput __P((u_char *, int));
void pc_xmode_on __P((void));
void pc_xmode_off __P((void));
-void pcstart();
-int pcparam();
+void pcstart __P((struct tty *));
+int pcparam __P((struct tty *, struct termios *));
+
char partab[];
-extern pcopen(dev_t, int, int, struct proc *);
+int kbd_cmd __P((u_char, u_char));
+void set_cursor_shape __P((void));
+void get_cursor_shape __P((void));
+void do_async_update __P((void *));
+void async_update __P((void));
+
+static __inline int kbd_wait_output __P((void));
+static __inline int kbd_wait_input __P((void));
+static __inline void kbd_flush_input __P((void));
+static u_char kbc_get8042cmd __P((void));
+static int kbc_put8042cmd __P((u_char));
+
+void pccnprobe __P((struct consdev *));
+void pccninit __P((struct consdev *));
+void pccnputc __P((dev_t, char));
+int pccngetc __P((dev_t));
+void pccnpollc __P((dev_t, int));
#define KBD_DELAY \
- { u_char x = inb(0x84); } \
- { u_char x = inb(0x84); } \
- { u_char x = inb(0x84); } \
- { u_char x = inb(0x84); }
+ { u_char x = inb(0x84); (void) x; } \
+ { u_char x = inb(0x84); (void) x; } \
+ { u_char x = inb(0x84); (void) x; } \
+ { u_char x = inb(0x84); (void) x; }
-static inline int
+static __inline int
kbd_wait_output()
{
u_int i;
@@ -165,7 +182,7 @@ kbd_wait_output()
return 0;
}
-static inline int
+static __inline int
kbd_wait_input()
{
u_int i;
@@ -178,7 +195,7 @@ kbd_wait_input()
return 0;
}
-static inline void
+static __inline void
kbd_flush_input()
{
u_int i;
@@ -311,9 +328,10 @@ get_cursor_shape()
}
void
-do_async_update(poll)
- u_char poll;
+do_async_update(v)
+ void *v;
{
+ u_char poll = v ? 1 : 0;
int pos;
static int old_pos = -1;
@@ -359,7 +377,7 @@ async_update()
if (kernel || polling) {
if (async)
untimeout(do_async_update, NULL);
- do_async_update(1);
+ do_async_update((void *)1);
} else {
if (async)
return;
@@ -462,7 +480,7 @@ pcattach(parent, self, aux)
struct isa_attach_args *ia = aux;
printf(": %s\n", vs.color ? "color" : "mono");
- do_async_update(1);
+ do_async_update((void *)1);
screen_restore(0);
sc->sc_ih = isa_intr_establish(ia->ia_ic, ia->ia_irq, IST_EDGE,
@@ -688,7 +706,7 @@ pcstart(tp)
struct tty *tp;
{
struct clist *cl;
- int s, len, n;
+ int s, len;
u_char buf[PCBURST];
s = spltty();
@@ -720,12 +738,12 @@ out:
splx(s);
}
-void
+int
pcstop(tp, flag)
struct tty *tp;
int flag;
{
-
+ return 0;
}
void
@@ -967,7 +985,7 @@ sput(cp, n)
else
vs.so_at = FG_YELLOW | BG_BLACK;
- fillw((vs.at << 8) | ' ', crtat, vs.nchr - cursorat);
+ fillw((vs.at << 8) | ' ', (caddr_t) crtat, vs.nchr - cursorat);
}
while (n--) {
@@ -1015,7 +1033,6 @@ sput(cp, n)
break;
default:
- bypass:
switch (vs.state) {
case 0:
if (c == '\a')
@@ -1054,8 +1071,8 @@ sput(cp, n)
vs.cx = vs.cy = 0;
vs.state = VSS_EBRACE;
} else if (c == 'c') { /* Clear screen & home */
- fillw((vs.at << 8) | ' ', Crtat,
- vs.nchr);
+ fillw((vs.at << 8) | ' ',
+ (caddr_t) Crtat, vs.nchr);
crtat = Crtat;
vs.col = 0;
vs.state = 0;
@@ -1145,17 +1162,20 @@ sput(cp, n)
switch (vs.cx) {
case 0:
/* ... to end of display */
- fillw((vs.at << 8) | ' ', crtat,
+ fillw((vs.at << 8) | ' ',
+ (caddr_t) crtat,
Crtat + vs.nchr - crtat);
break;
case 1:
/* ... to next location */
- fillw((vs.at << 8) | ' ', Crtat,
+ fillw((vs.at << 8) | ' ',
+ (caddr_t) Crtat,
crtat - Crtat + 1);
break;
case 2:
/* ... whole display */
- fillw((vs.at << 8) | ' ', Crtat,
+ fillw((vs.at << 8) | ' ',
+ (caddr_t) Crtat,
vs.nchr);
break;
}
@@ -1165,19 +1185,21 @@ sput(cp, n)
switch (vs.cx) {
case 0:
/* ... current to EOL */
- fillw((vs.at << 8) | ' ', crtat,
+ fillw((vs.at << 8) | ' ',
+ (caddr_t) crtat,
vs.ncol - vs.col);
break;
case 1:
/* ... beginning to next */
fillw((vs.at << 8) | ' ',
- crtat - vs.col,
+ (caddr_t) (crtat - vs.col),
vs.col + 1);
break;
case 2:
/* ... entire line */
fillw((vs.at << 8) | ' ',
- crtat - vs.col, vs.ncol);
+ (caddr_t) (crtat - vs.col),
+ vs.ncol);
break;
}
vs.state = 0;
@@ -1215,7 +1237,7 @@ sput(cp, n)
crtAt, vs.ncol * (nrow -
cx) * CHR);
fillw((vs.at << 8) | ' ',
- crtAt + vs.ncol * (nrow - cx),
+ (caddr_t) (crtAt + vs.ncol * (nrow - cx)),
vs.ncol * cx);
vs.state = 0;
break;
@@ -1231,9 +1253,11 @@ sput(cp, n)
Crtat, vs.ncol * (vs.nrow -
cx) * CHR);
fillw((vs.at << 8) | ' ',
- Crtat + vs.ncol * (vs.nrow - cx),
+ (caddr_t) (Crtat + vs.ncol * (vs.nrow - cx)),
vs.ncol * cx);
- /* crtat -= vs.ncol * cx; /* XXX */
+#if 0
+ crtat -= vs.ncol * cx; /* XXX */
+#endif
vs.state = 0;
break;
}
@@ -1251,7 +1275,8 @@ sput(cp, n)
crtAt + vs.ncol * cx,
vs.ncol * (nrow - cx) *
CHR);
- fillw((vs.at << 8) | ' ', crtAt,
+ fillw((vs.at << 8) | ' ',
+ (caddr_t) crtAt,
vs.ncol * cx);
vs.state = 0;
break;
@@ -1267,9 +1292,12 @@ sput(cp, n)
Crtat + vs.ncol * cx,
vs.ncol * (vs.nrow - cx) *
CHR);
- fillw((vs.at << 8) | ' ', Crtat,
+ fillw((vs.at << 8) | ' ',
+ (caddr_t) Crtat,
vs.ncol * cx);
- /* crtat += vs.ncol * cx; /* XXX */
+#if 0
+ crtat += vs.ncol * cx; /* XXX */
+#endif
vs.state = 0;
break;
}
@@ -1339,7 +1367,8 @@ sput(cp, n)
bcopy(Crtat + vs.ncol, Crtat,
(vs.nchr - vs.ncol) * CHR);
fillw((vs.at << 8) | ' ',
- Crtat + vs.nchr - vs.ncol, vs.ncol);
+ (caddr_t) (Crtat + vs.nchr - vs.ncol),
+ vs.ncol);
crtat -= vs.ncol;
}
}