mirror of
https://github.com/Interlisp/maiko.git
synced 2026-01-15 07:54:13 +00:00
The code is being re-licensed under the MIT license. modified: bin/fixid modified: bin/launch.asm modified: bin/makefile-hpux.hp9000-x modified: bin/makefile-init.sgi modified: bin/makefile-init.sparc modified: bin/makefile-init.sparc-multi modified: bin/makefile-irix.sgi-x modified: bin/makefile-sunos4.sparc modified: bin/makefile-sunos4.sparc% modified: bin/makefile-sunos4.sparc-multi modified: bin/makefile-sunos5.386-x modified: bin/makefile-sunos5.i386-x modified: bin/makefile-sunos5.sparc-x modified: bin/makefile-tail modified: bin/makeisc modified: bin/makeright modified: inc/Check.h modified: inc/MyWindow.h modified: inc/Stipple.h modified: inc/XCursors.h modified: inc/XKeymap.h modified: inc/XVersion.h modified: inc/Xdeflt.h modified: inc/Xicon.h modified: inc/address.h modified: inc/arith.h modified: inc/arith2.h modified: inc/array.h modified: inc/bb.h modified: inc/cell.h modified: inc/cell.h% modified: inc/copyright modified: inc/dbprint.h modified: inc/debug.h modified: inc/devif.h modified: inc/display.h modified: inc/dspdata.h modified: inc/ether.h modified: inc/fast_dsp.h modified: inc/fp.h modified: inc/gc.h modified: inc/gc.h.save modified: inc/gcscan.h modified: inc/hdw_conf.h modified: inc/ifpage.h modified: inc/inlineC.h modified: inc/inlnMIPS.h modified: inc/inlnPS2.h modified: inc/inlndos.h modified: inc/iopage.h modified: inc/kbdif.h modified: inc/keyboard.h modified: inc/keyboard.h% modified: inc/keysym.h modified: inc/ldeXdefs.h modified: inc/lispemul.h modified: inc/lispemul.h.save modified: inc/lispmap.h modified: inc/lldsp.h modified: inc/lnk-Xdeflt.h modified: inc/lnk-debug.h modified: inc/lnk-fast_dsp.h modified: inc/lnk-inlineC.h modified: inc/lnk-lispmap.h modified: inc/lnk-tosfns.h modified: inc/lnk-tosret.h modified: inc/locfile.h modified: inc/lpdefs.h modified: inc/lpglobl.h modified: inc/lspglob.h modified: inc/lsptypes.h modified: inc/medleyfp.h modified: inc/mnxdefs.h modified: inc/my.h modified: inc/native.h modified: inc/ocr.h modified: inc/osmsg.h modified: inc/picture.h modified: inc/pilotbbt.h modified: inc/print.h modified: inc/profile.h modified: inc/rawrs232c.h modified: inc/return.h modified: inc/rs232c.h modified: inc/stack.h modified: inc/stream.h modified: inc/stream.h% modified: inc/stream.h2 modified: inc/sysatms.h modified: inc/timeout.h modified: inc/tos1defs.h modified: inc/tosfns.h modified: inc/tosret.h modified: inc/tty.h modified: inc/version.h modified: inc/vmemsave.h modified: inc/xbitmaps.h modified: inc/xdefs.h modified: src/Cldeetr.c modified: src/allocmds.c modified: src/arith2.c modified: src/arith3.c modified: src/arith4.c modified: src/array.c modified: src/array2.c modified: src/array3.c modified: src/array4.c modified: src/array5.c modified: src/array6.c modified: src/asmbbt.c modified: src/asmbitblt.c modified: src/atom.c modified: src/bbtSPARC.s modified: src/bbtsub.c modified: src/bin.c modified: src/binds.c modified: src/bitblt.c modified: src/blt.c modified: src/byteswap.c modified: src/call-c.c modified: src/car-cdr.c modified: src/cdaudio.c modified: src/cdrom.c modified: src/chardev.c modified: src/chatter.c modified: src/codeconv.c modified: src/codetbl.c modified: src/colorbltfns.c modified: src/common.c modified: src/conspage.c modified: src/cr modified: src/dbgtool.c modified: src/dir.c modified: src/doscomm.c modified: src/doskbd.c modified: src/dosmouse.c modified: src/draw.c modified: src/dsk.c modified: src/dspif.c modified: src/dspsubrs.c modified: src/ejlisp.c modified: src/eqf.c modified: src/ether.c modified: src/findkey.c modified: src/foreign.c modified: src/fp.c modified: src/fvar.c modified: src/gc.c modified: src/gc2.c modified: src/gcarray.c modified: src/gccode.c modified: src/gcfinal.c modified: src/gchtfind.c modified: src/gcmain3.c modified: src/gcoflow.c modified: src/gcr.c modified: src/gcrcell.c modified: src/gcscan.c modified: src/gvar2.c modified: src/hacks.c modified: src/hardrtn.c modified: src/imagefile.c modified: src/imagefile2.c modified: src/inet.c modified: src/initdsp.c modified: src/initkbd.c modified: src/initsout.c modified: src/intcall.c modified: src/kbdif.c modified: src/kbdsubrs.c modified: src/keyevent.c modified: src/keylib.c modified: src/keymaker.c modified: src/keytst.c modified: src/keytstno.c modified: src/kprint.c modified: src/launch.asm modified: src/ldeboot.c modified: src/ldeether.c modified: src/ldsout.c modified: src/lineblt8.c modified: src/lisp2c.c modified: src/llcolor.c modified: src/llstk.c modified: src/loader.c modified: src/loopsops.c modified: src/lowlev1.c modified: src/lowlev2.c modified: src/lpdual.c modified: src/lpkit.c modified: src/lplexyy.c modified: src/lpmain.c modified: src/lpread.c modified: src/lpsolve.c modified: src/lptran.c modified: src/lpwrite.c modified: src/lpytab.c modified: src/lsthandl.c modified: src/main.c modified: src/misc7.c modified: src/miscn.c modified: src/mkatom.c modified: src/mkcell.c modified: src/mkkey.c modified: src/mkvdate.c modified: src/mnwevent.c modified: src/mnxmeth.c modified: src/mouseif.c modified: src/mvs.c modified: src/ocr.c modified: src/ocrproc.c modified: src/oether.c modified: src/oldeether.c modified: src/optck.c modified: src/osmsg.c modified: src/perrno.c modified: src/picture.c modified: src/rawcolor.c modified: src/rawrs232c.c modified: src/return.c modified: src/rpc.c modified: src/rplcons.c modified: src/rs232c.c modified: src/setsout.c modified: src/shift.c modified: src/socdvr.c modified: src/storage.c modified: src/subr.c modified: src/subr0374.c modified: src/sxhash.c modified: src/testdsp.c modified: src/testtool.c modified: src/timeoday.c modified: src/timeofday.c modified: src/timer.c modified: src/truecolor.c modified: src/tstsout.c modified: src/tty.c modified: src/typeof.c modified: src/ubf1.c modified: src/ubf2.c modified: src/ubf3.c modified: src/ufn.c modified: src/ufs.c modified: src/unixcomm.c modified: src/unixfork.c modified: src/unwind.c modified: src/uraid.c modified: src/usrsubr.c modified: src/uutils.c modified: src/vars3.c modified: src/vesafns.asm modified: src/vesainit.c modified: src/vgainit.c modified: src/vmemsave.c modified: src/xbbt.c modified: src/xc.c modified: src/xc.c.orig modified: src/xcursor.c modified: src/xinit.c modified: src/xlspwin.c modified: src/xmkicon.c modified: src/xrdopt.c modified: src/xscroll.c modified: src/xwinman.c modified: src/z2.c
316 lines
12 KiB
C
316 lines
12 KiB
C
/* $Id: doskbd.c,v 1.2 1999/01/03 02:06:55 sybalsky Exp $ (C) Copyright Venue, All Rights Reserved
|
|
*/
|
|
static char *id = "$Id: doskbd.c,v 1.2 1999/01/03 02:06:55 sybalsky Exp $ Copyright (C) Venue";
|
|
/************************************************************************/
|
|
/* */
|
|
/* D O S K E Y B O A R D H A N D L E R */
|
|
/* */
|
|
/* */
|
|
/************************************************************************/
|
|
|
|
/************************************************************************/
|
|
/* */
|
|
/* (C) Copyright 1989, 1990, 1990, 1991, 1992, 1993, 1994, 1995 Venue. */
|
|
/* All Rights Reserved. */
|
|
/* Manufactured in the United States of America. */
|
|
/* */
|
|
/************************************************************************/
|
|
|
|
#include "version.h"
|
|
|
|
#include <dos.h> /* defines REGS & other structs */
|
|
#include <i32.h> /* "#pragma interrupt" & '_chain_intr'*/
|
|
#include <stk.h>
|
|
#include <conio.h>
|
|
|
|
#include "lispemul.h"
|
|
#include "keyboard.h"
|
|
#include "keysym.h"
|
|
#include "devif.h"
|
|
|
|
int nokbdflag = FALSE;
|
|
extern int eurokbd;
|
|
extern KbdInterface currentkbd;
|
|
extern MouseInterface currentmouse;
|
|
extern IOPAGE *IOPage68K;
|
|
extern IFPAGE *InterfacePage;
|
|
extern int KBDEventFlg;
|
|
|
|
extern keybuffer *CTopKeyevent;
|
|
|
|
extern LispPTR *LASTUSERACTION68k;
|
|
extern LispPTR *KEYBUFFERING68k;
|
|
|
|
/************************************************/
|
|
/* Keyboard-Interface Registers, Status Codes */
|
|
/************************************************/
|
|
#define KBD_COMMAND_PORT 0x64 /* I/O port commands go out on */
|
|
#define KBD_ENABLE 0xAE
|
|
#define KBD_DISABLE 0xAD
|
|
#define KBD_RESET 0xF6
|
|
|
|
#define PORT_8042 0x60 /* Port scan codes come in on */
|
|
#define KBD_SCAN_CODE_PORT 0x60
|
|
#define KBD_resend 0xFE /* KBD asked for resend */
|
|
#define KBD_ack 0xFA /* KBD ack's our command */
|
|
#define KBD_echo_response 0xEE /* KBD responds to echo req */
|
|
#define KBD_failure 0xFD /* Failure code */
|
|
#define KBD_prefix 0xE0 /* Prefix for extended chars */
|
|
#define KBD_pause_prefix 0xE1 /* Pause prefix?? */
|
|
#define KBD_overflow 0x00 /* Overflow of some kind */
|
|
#define KBD_overrun 0xFF /* KBD buffer overrun */
|
|
|
|
#define KBD_STATUS_PORT 0x64 /* Port KBD status comes in on */
|
|
#define KBD_INP_FULL 0x02 /* input buffer full */
|
|
|
|
#define INTA00 0x20 /* The 8259 port, to reset irq */
|
|
#define ENDOFINTERRUPT 0x20
|
|
|
|
#define PRTSC_KEY 0x37 /* Keyboard codes for extended chars */
|
|
#define HOME_KEY 0x47
|
|
#define UPARROW_KEY 0x48
|
|
#define PGUP_KEY 0x49
|
|
#define LEFTARROW_KEY 0x4b
|
|
#define RIGHTARROW_KEY 0x4d
|
|
#define END_KEY 0x4f
|
|
#define DOWNARROW_KEY 0x50
|
|
#define PGDOWN_KEY 0x51
|
|
#define INS_KEY 0x52
|
|
#define DEL_KEY 0x53
|
|
|
|
/******************************************************/
|
|
/* Tell the Interrupt-dispatch IC we're done, and */
|
|
/* Tell the keyboard itself that we're ready again. */
|
|
/* */
|
|
/* (This process is critical to the proper function */
|
|
/* of the handler, so let's do it once, correctly.) */
|
|
/******************************************************/
|
|
#define ENABLE_KBD \
|
|
{ \
|
|
outp(INTA00, ENDOFINTERRUPT); \
|
|
outp(KBD_COMMAND_PORT, KBD_ENABLE); /* Turn kbd on again. */ \
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* */
|
|
/* K B D _ E V E N T */
|
|
/* */
|
|
/* Keyboard interrupt handler routine */
|
|
/************************************************************************/
|
|
extern DLword *DisplayRegion68k;
|
|
|
|
#pragma interrupt(Kbd_event)
|
|
|
|
void Kbd_event() {
|
|
_XSTACK *ebp; /* Real-mode handler stack frame */
|
|
DLword w, r;
|
|
KBEVENT *kbevent;
|
|
unsigned char keycode, tmpkey;
|
|
|
|
ebp = (_XSTACK *)_get_stk_frame(); /* Get stack frame address */
|
|
ebp->opts |= _STK_NOINT; /* Bypass real-mode handler */
|
|
|
|
/*************************************************/
|
|
/* First, get the scan code from the keyboard. */
|
|
/* Handle exceptional conditions & errors, and */
|
|
/* the extended-character prefix, 0xE0 */
|
|
/* generated for, e.g., the INSERT key. */
|
|
/*************************************************/
|
|
|
|
_disable(); /* prevent further interrupts from killing us */
|
|
outp(KBD_COMMAND_PORT, KBD_DISABLE); /* Turn the kbd off. */
|
|
do { tmpkey = inp(KBD_STATUS_PORT); } while (tmpkey & KBD_INP_FULL);
|
|
|
|
/* Finite state machine that either returns or goes to label handle: */
|
|
switch (tmpkey = inp(KBD_SCAN_CODE_PORT)) {
|
|
case KBD_overflow: /* Ignore these. */
|
|
case KBD_pause_prefix:
|
|
case KBD_echo_response:
|
|
case KBD_ack:
|
|
case KBD_failure:
|
|
case KBD_resend:
|
|
case KBD_overrun:
|
|
ENABLE_KBD;
|
|
return;
|
|
break;
|
|
|
|
case KBD_prefix: /* It's a prefix, so really use next char. */
|
|
/* Remember that we saw the prefix: */
|
|
currentkbd->lastbyte = tmpkey;
|
|
ENABLE_KBD;
|
|
return;
|
|
break;
|
|
|
|
default:
|
|
tmpkey = inp(KBD_SCAN_CODE_PORT);
|
|
if (currentkbd->lastbyte == KBD_prefix)
|
|
switch (tmpkey) /* deal with prefixed characters */
|
|
{
|
|
case 0x2A: /* by ignoring some (what are they??) */
|
|
case 0xAA:
|
|
case 0xB6:
|
|
case 0x36:
|
|
ENABLE_KBD;
|
|
return;
|
|
break;
|
|
|
|
default: /* and passing the rest thru as-is */
|
|
currentkbd->lastbyte = tmpkey; /* Set the state. */
|
|
goto handle;
|
|
break;
|
|
}
|
|
else {
|
|
currentkbd->lastbyte = tmpkey; /* Set the state. */
|
|
goto handle;
|
|
}
|
|
}
|
|
|
|
return; /* Don't have anything to handle yet, so just return */
|
|
|
|
/*****************************************************/
|
|
/* Second, translate the scan code into a LISP key */
|
|
/* transition, add it to the ring buffer, and set */
|
|
/* the interrupt-request flags so lisp sees it. */
|
|
/*****************************************************/
|
|
handle:
|
|
/* The upflag is the eight bit in the char ie. upflag = currentkbd->lastbyte >> 7 */
|
|
/* The event is the lower seven bits of the byte */
|
|
|
|
keycode = currentkbd->KeyMap[currentkbd->lastbyte & 0x7f];
|
|
|
|
if (keycode != 0xff) {
|
|
if (keycode < 64) {
|
|
PUTBASEBIT68K(&(IOPage68K->dlkbdad0), keycode, (currentkbd->lastbyte >> 7) & 1);
|
|
} else if (keycode >= 80) {
|
|
PUTBASEBIT68K(&(IOPage68K->dlkbdad0), keycode - 16, (currentkbd->lastbyte >> 7) & 1);
|
|
} else {
|
|
PUTBASEBIT68K(&(IOPage68K->dlutilin), (keycode & 0xf), (currentkbd->lastbyte >> 7) & 1);
|
|
PUTBASEBIT68K(&(InterfacePage->fakemousebits), (keycode & 0xf),
|
|
(currentkbd->lastbyte >> 7) & 1);
|
|
}
|
|
}
|
|
|
|
/* In DOS we can't enter uraid inside an exception handler. */
|
|
/* Uraid may touch a swapped out address and that dumps Medley */
|
|
if (((IOPage68K->dlkbdad2 & 2113) == 0) || /* Ctrl-shift-NEXT */
|
|
((IOPage68K->dlkbdad2 & 2114) == 0)) { /* Ctrl-shift-DEL */
|
|
currentkbd->URaid = TRUE; /* Tell the dispatch loop about it. */
|
|
return;
|
|
}
|
|
|
|
r = CTopKeyevent->ring.vectorindex.read;
|
|
w = CTopKeyevent->ring.vectorindex.write;
|
|
|
|
if (r != w) {
|
|
kbevent = (KBEVENT *)((DLword *)CTopKeyevent + w);
|
|
/* Copy the Hardware bits. */
|
|
kbevent->W0 = IOPage68K->dlkbdad0;
|
|
kbevent->W1 = IOPage68K->dlkbdad1;
|
|
kbevent->W2 = IOPage68K->dlkbdad2;
|
|
kbevent->W3 = IOPage68K->dlkbdad3;
|
|
kbevent->W4 = IOPage68K->dlkbdad4;
|
|
kbevent->W5 = IOPage68K->dlkbdad5;
|
|
kbevent->WU = IOPage68K->dlutilin;
|
|
|
|
/* If queue was empty, update the read pointer */
|
|
if (r == 0) CTopKeyevent->ring.vectorindex.read = w;
|
|
|
|
/* Update the write pointer */
|
|
if (w >= currentkbd->maxkeyevent)
|
|
CTopKeyevent->ring.vectorindex.write = MINKEYEVENT;
|
|
else
|
|
CTopKeyevent->ring.vectorindex.write += currentkbd->keyeventsize;
|
|
}
|
|
if (*KEYBUFFERING68k == NIL) *KEYBUFFERING68k = ATOM_T;
|
|
|
|
KBDEventFlg++;
|
|
Irq_Stk_End = 0;
|
|
Irq_Stk_Check = 0;
|
|
|
|
ENABLE_KBD;
|
|
return;
|
|
}
|
|
|
|
extern u_char DOSLispKeyMap_101[];
|
|
|
|
/************************************************************************/
|
|
/* */
|
|
/* E X I T D O S K B D */
|
|
/* */
|
|
/* Turn off the DOS keyboard handler, and reinstall the */
|
|
/* normal DOS handler. */
|
|
/************************************************************************/
|
|
|
|
void ExitDosKbd(KbdInterface kbd)
|
|
{
|
|
if (kbd->device.active == TRUE) {
|
|
kbd->device.active = FALSE;
|
|
|
|
_dpmi_unlockregion((void *)¤tkbd, sizeof(currentkbd));
|
|
_dpmi_unlockregion((void *)kbd, sizeof(*kbd));
|
|
_dpmi_unlockregion((void *)&InterfacePage, sizeof(InterfacePage));
|
|
_dpmi_unlockregion((void *)InterfacePage, sizeof(IFPAGE));
|
|
_dpmi_unlockregion((void *)&IOPage68K, sizeof(IOPage68K));
|
|
_dpmi_unlockregion((void *)IOPage68K, sizeof(IOPAGE));
|
|
|
|
_dpmi_unlockregion((void *)&CTopKeyevent, sizeof(CTopKeyevent));
|
|
_dpmi_unlockregion((void *)CTopKeyevent, sizeof(*CTopKeyevent));
|
|
|
|
_dpmi_unlockregion((void *)&MachineState, sizeof(MachineState));
|
|
_dpmi_unlockregion((void *)&KEYBUFFERING68k, sizeof(KEYBUFFERING68k));
|
|
_dpmi_unlockregion((void *)&ExitDosKbd, 4096);
|
|
_dpmi_unlockregion((void *)&Kbd_event, 4096);
|
|
|
|
_dos_setvect(0x09, kbd->prev_handler); /* unhook our handlr, install previous*/
|
|
}
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* */
|
|
/* E N T E R D O S K B D */
|
|
/* */
|
|
/* Turn on the DOS keyboard device. */
|
|
/* */
|
|
/************************************************************************/
|
|
|
|
void EnterDosKbd(KbdInterface kbd)
|
|
{
|
|
int i;
|
|
|
|
if (kbd->device.active == FALSE) {
|
|
kbd->device.active = TRUE;
|
|
for (i = 0; i < 0x80; i++) kbd->KeyMap[i] = DOSLispKeyMap_101[i];
|
|
|
|
if (eurokbd)
|
|
kbd->keyeventsize = EUROKEYEVENTSIZE;
|
|
else
|
|
kbd->keyeventsize = NOEUROKEYEVENTSIZE;
|
|
kbd->eurokbd = eurokbd;
|
|
|
|
/* Offset of the end of the ring buffer */
|
|
kbd->maxkeyevent = (MINKEYEVENT + (NUMBEROFKEYEVENTS * kbd->keyeventsize));
|
|
|
|
_dpmi_lockregion((void *)¤tkbd, sizeof(currentkbd));
|
|
_dpmi_lockregion((void *)kbd, sizeof(*kbd));
|
|
_dpmi_lockregion((void *)&InterfacePage, sizeof(InterfacePage));
|
|
_dpmi_lockregion((void *)InterfacePage, sizeof(IFPAGE));
|
|
_dpmi_lockregion((void *)&IOPage68K, sizeof(IOPage68K));
|
|
_dpmi_lockregion((void *)IOPage68K, sizeof(IOPAGE));
|
|
_dpmi_lockregion((void *)&MachineState, sizeof(MachineState));
|
|
|
|
_dpmi_lockregion((void *)&CTopKeyevent, sizeof(CTopKeyevent));
|
|
_dpmi_lockregion((void *)CTopKeyevent, sizeof(*CTopKeyevent));
|
|
|
|
_dpmi_lockregion((void *)&KEYBUFFERING68k, sizeof(KEYBUFFERING68k));
|
|
_dpmi_lockregion((void *)&ExitDosKbd, 4096);
|
|
_dpmi_lockregion((void *)&Kbd_event, 4096);
|
|
|
|
/* Don't hook in our handler if the user flagged he wants to run */
|
|
/* without a kbd. */
|
|
if (!nokbdflag) {
|
|
kbd->prev_handler = _dos_getvect(0x09); /* get addr of currnt 09 hndlr */
|
|
_dos_setvect(0x09, kbd->device_event); /* hook our int handler to interrupt */
|
|
}
|
|
}
|
|
}
|