summaryrefslogtreecommitdiff
path: root/sys/arch/hp300/dev/hil.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/hp300/dev/hil.c')
-rw-r--r--sys/arch/hp300/dev/hil.c129
1 files changed, 100 insertions, 29 deletions
diff --git a/sys/arch/hp300/dev/hil.c b/sys/arch/hp300/dev/hil.c
index bf93d1eec0a..fc159f1fe9d 100644
--- a/sys/arch/hp300/dev/hil.c
+++ b/sys/arch/hp300/dev/hil.c
@@ -1,4 +1,5 @@
-/* $NetBSD: hil.c,v 1.22 1996/02/14 02:44:24 thorpej Exp $ */
+/* $OpenBSD: hil.c,v 1.8 1997/01/12 15:12:41 downsj Exp $ */
+/* $NetBSD: hil.c,v 1.29 1996/10/14 07:09:41 thorpej Exp $ */
/*
* Copyright (c) 1988 University of Utah.
@@ -93,6 +94,13 @@ int hildebug = 0;
extern struct emul emul_hpux;
#endif
+/* XXX ITE interface */
+char *kbd_keymap;
+char *kbd_shiftmap;
+char *kbd_ctrlmap;
+char *kbd_ctrlshiftmap;
+char **kbd_stringmap;
+
/* symbolic sleep message strings */
char hilin[] = "hilin";
@@ -103,6 +111,10 @@ hilsoftinit(unit, hilbase)
register struct hil_softc *hilp = &hil_softc[unit];
register int i;
+ /* XXX ITE interface */
+ extern char *us_keymap, *us_shiftmap, *us_ctrlmap,
+ *us_ctrlshiftmap, **us_stringmap;
+
#ifdef DEBUG
if (hildebug & HDB_FOLLOW)
printf("hilsoftinit(%d, %x)\n", unit, hilbase);
@@ -117,7 +129,6 @@ hilsoftinit(unit, hilbase)
hilp->hl_cmdbp = hilp->hl_cmdbuf;
hilp->hl_pollbp = hilp->hl_pollbuf;
hilp->hl_kbddev = 0;
- hilp->hl_kbdlang = KBD_DEFAULT;
hilp->hl_kbdflags = 0;
/*
* Clear all queues and device associations with queues
@@ -130,6 +141,18 @@ hilsoftinit(unit, hilbase)
for (i = 0; i < NHILD; i++)
hilp->hl_device[i].hd_qmask = 0;
hilp->hl_device[HILLOOPDEV].hd_flags = (HIL_ALIVE|HIL_PSEUDO);
+
+ /*
+ * Set up default keyboard language. We always default
+ * to US ASCII - it seems to work OK for non-recognized
+ * keyboards.
+ */
+ hilp->hl_kbdlang = KBD_DEFAULT;
+ kbd_keymap = us_keymap; /* XXX */
+ kbd_shiftmap = us_shiftmap; /* XXX */
+ kbd_ctrlmap = us_ctrlmap; /* XXX */
+ kbd_ctrlshiftmap = us_ctrlshiftmap; /* XXX */
+ kbd_stringmap = us_stringmap; /* XXX */
}
hilinit(unit, hilbase)
@@ -681,6 +704,7 @@ hilmmap(dev, off, prot)
}
/*ARGSUSED*/
+int
hilselect(dev, rw, p)
dev_t dev;
int rw;
@@ -691,7 +715,7 @@ hilselect(dev, rw, p)
register struct hiliqueue *qp;
register int mask;
int s, device;
-
+
if (rw == FWRITE)
return (1);
device = HILUNIT(dev);
@@ -831,10 +855,6 @@ hil_process_int(hilp, stat, c)
}
}
-#if (defined(DDB) || defined(DEBUG)) && !defined(PANICBUTTON)
-#define PANICBUTTON
-#endif
-
/*
* Optimized macro to compute:
* eq->head == (eq->tail + 1) % eq->size
@@ -857,20 +877,6 @@ hilevent(hilp)
int s, len0;
long tenths;
-#ifdef PANICBUTTON
- static int first;
- extern int panicbutton;
-
- cp = hilp->hl_pollbuf;
- if (panicbutton && (*cp & HIL_KBDDATA)) {
- if (*++cp == 0x4E)
- first = 1;
- else if (first && *cp == 0x46 && !panicstr)
- panic("are we having fun yet?");
- else
- first = 0;
- }
-#endif
#ifdef DEBUG
if (hildebug & HDB_EVENTS) {
printf("hilevent: dev %d pollbuf: ", hilp->hl_actdev);
@@ -1128,28 +1134,86 @@ kbddisable(unit)
}
/*
+ * The following chunk of code implements HIL console keyboard
+ * support.
+ */
+
+struct hil_dev *hilkbd_cn_device;
+char *kbd_cn_keymap;
+char *kbd_cn_shiftmap;
+char *kbd_cn_ctrlmap;
+
+/*
* XXX: read keyboard directly and return code.
* Used by console getchar routine. Could really screw up anybody
* reading from the keyboard in the normal, interrupt driven fashion.
*/
-kbdgetc(unit, statp)
- int unit, *statp;
+int
+kbdgetc(statp)
+ int *statp;
{
- struct hil_softc *hilp = &hil_softc[unit];
- register struct hil_dev *hildevice = hilp->hl_addr;
register int c, stat;
int s;
+ if (hilkbd_cn_device == NULL)
+ return (0);
+
+ /*
+ * XXX needs to be splraise because we could be called
+ * XXX at splhigh, e.g. in DDB.
+ */
s = splhil();
- while (((stat = READHILSTAT(hildevice)) & HIL_DATA_RDY) == 0)
+ while (((stat = READHILSTAT(hilkbd_cn_device)) & HIL_DATA_RDY) == 0)
;
- c = READHILDATA(hildevice);
+ c = READHILDATA(hilkbd_cn_device);
splx(s);
*statp = stat;
- return(c);
+ return (c);
}
/*
+ * Perform basic initialization of the HIL keyboard, suitable
+ * for early console use.
+ */
+void
+kbdcninit()
+{
+ struct hil_dev *h = HILADDR; /* == VA (see hilreg.h) */
+ struct kbdmap *km;
+ u_char lang;
+
+ /* XXX from hil_keymaps.c */
+ extern char *us_keymap, *us_shiftmap, *us_ctrlmap;
+
+ hilkbd_cn_device = h;
+
+ /* Default to US-ASCII keyboard. */
+ kbd_cn_keymap = us_keymap;
+ kbd_cn_shiftmap = us_shiftmap;
+ kbd_cn_ctrlmap = us_ctrlmap;
+
+ HILWAIT(h);
+ WRITEHILCMD(h, HIL_SETARR);
+ HILWAIT(h);
+ WRITEHILDATA(h, ar_format(KBD_ARR));
+ HILWAIT(h);
+ WRITEHILCMD(h, HIL_READKBDLANG);
+ HILDATAWAIT(h);
+ lang = READHILDATA(h);
+ for (km = kbd_map; km->kbd_code; km++) {
+ if (km->kbd_code == lang) {
+ kbd_cn_keymap = km->kbd_keymap;
+ kbd_cn_shiftmap = km->kbd_shiftmap;
+ kbd_cn_ctrlmap = km->kbd_ctrlmap;
+ }
+ }
+ HILWAIT(h);
+ WRITEHILCMD(h, HIL_INTON);
+}
+
+/* End of HIL console keyboard code. */
+
+/*
* Recoginize and clear keyboard generated NMIs.
* Returns 1 if it was ours, 0 otherwise. Note that we cannot use
* send_hil_cmd() to issue the clear NMI command as that would actually
@@ -1335,7 +1399,7 @@ hilconfig(hilp)
if (hilp->hl_kbdlang != KBD_SPECIAL) {
struct kbdmap *km;
- for (km = kbd_map; km->kbd_code; km++)
+ for (km = kbd_map; km->kbd_code; km++) {
if (km->kbd_code == db) {
hilp->hl_kbdlang = db;
/* XXX */
@@ -1344,7 +1408,14 @@ hilconfig(hilp)
kbd_ctrlmap = km->kbd_ctrlmap;
kbd_ctrlshiftmap = km->kbd_ctrlshiftmap;
kbd_stringmap = km->kbd_stringmap;
+ break;
}
+ }
+ if (km->kbd_code == 0) {
+ printf(
+ "hilconfig: unknown keyboard type 0x%x, using default\n",
+ db);
+ }
}
splx(s);
}