Annotation of 43BSDReno/sys/hpdev/hilreg.h, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 1988 University of Utah.
        !             3:  * Copyright (c) 1990 The Regents of the University of California.
        !             4:  * All rights reserved.
        !             5:  *
        !             6:  * This code is derived from software contributed to Berkeley by
        !             7:  * the Systems Programming Group of the University of Utah Computer
        !             8:  * Science Department.
        !             9:  *
        !            10:  * Redistribution is only permitted until one year after the first shipment
        !            11:  * of 4.4BSD by the Regents.  Otherwise, redistribution and use in source and
        !            12:  * binary forms are permitted provided that: (1) source distributions retain
        !            13:  * this entire copyright notice and comment, and (2) distributions including
        !            14:  * binaries display the following acknowledgement:  This product includes
        !            15:  * software developed by the University of California, Berkeley and its
        !            16:  * contributors'' in the documentation or other materials provided with the
        !            17:  * distribution and in all advertising materials mentioning features or use
        !            18:  * of this software.  Neither the name of the University nor the names of
        !            19:  * its contributors may be used to endorse or promote products derived from
        !            20:  * this software without specific prior written permission.
        !            21:  * THIS SOFTWARE IS PROVIDED AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
        !            22:  * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
        !            23:  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
        !            24:  *
        !            25:  * from: Utah $Hdr: hilreg.h 1.8 89/08/24$
        !            26:  *
        !            27:  *     @(#)hilreg.h    7.1 (Berkeley) 5/8/90
        !            28:  */
        !            29: 
        !            30: struct hil_dev {
        !            31:        char    hil_pad0;
        !            32:        volatile char   hil_data;
        !            33:        char    hil_pad1;
        !            34:        volatile char   hil_cmd;
        !            35: #define hil_stat hil_cmd
        !            36: };
        !            37: 
        !            38: #define        HILADDR                 ((struct hil_dev *)IOV(0x428000))
        !            39: #define BBCADDR                        ((struct hil_dev *)IOV(0x420000))  
        !            40: 
        !            41: #define splhil                 spl1
        !            42: 
        !            43: #define        HIL_BUSY                0x02
        !            44: #define HIL_DATA_RDY           0x01
        !            45: 
        !            46: #define HILWAIT(hil_dev)       while ((hil_dev->hil_stat & HIL_BUSY))
        !            47: #define HILDATAWAIT(hil_dev)   while ((hil_dev->hil_stat & HIL_DATA_RDY) == 0)
        !            48: 
        !            49: /* HIL status bits */
        !            50: #define        HIL_POLLDATA    0x10            /* HIL poll data follows */
        !            51: #define HIL_COMMAND    0x08            /* Start of original command */
        !            52: #define HIL_ERROR      0x080           /* HIL error */
        !            53: #define HIL_RECONFIG   0x080           /* HIL has reconfigured */
        !            54: #define        HIL_STATMASK    (HIL_DATA | HIL_COMMAND)
        !            55: 
        !            56: #define HIL_SSHIFT             4       /* Bits to shift status over */
        !            57: #define HIL_SMASK              0xF     /* Service request status mask */
        !            58: #define HIL_DEVMASK            0x07
        !            59: 
        !            60: /* HIL status types */
        !            61: #define        HIL_STATUS      0x5             /* HIL status in data register */
        !            62: #define        HIL_DATA        0x6             /* HIL data in data register */
        !            63: #define        HIL_CTRLSHIFT   0x8             /* key + CTRL + SHIFT */
        !            64: #define        HIL_CTRL        0x9             /* key + CTRL */
        !            65: #define        HIL_SHIFT       0xA             /* key + SHIFT */
        !            66: #define        HIL_KEY         0xB             /* key only */
        !            67: #define HIL_68K                0x4             /* Data from the 68k is ready */
        !            68: 
        !            69: /* HIL commands */
        !            70: #define        HIL_SETARD      0xA0            /* set auto-repeat delay */
        !            71: #define        HIL_SETARR      0xA2            /* set auto-repeat rate */
        !            72: #define        HIL_SETTONE     0xA3            /* set tone generator */
        !            73: #define HIL_CNMT       0xB2            /* clear nmi */
        !            74: #define HIL_INTON      0x5C            /* Turn on interrupts. */
        !            75: #define HIL_INTOFF     0x5D            /* Turn off interrupts. */
        !            76: #define HIL_TRIGGER    0xC5            /* trigger command */
        !            77: #define HIL_STARTCMD   0xE0            /* start loop command */
        !            78: #define HIL_TIMEOUT    0xFE            /* timeout */
        !            79: #define HIL_READTIME   0x13            /* Read real time register */
        !            80: 
        !            81: /* Read/write various registers on the 8042. */
        !            82: #define        HIL_READBUSY            0x02    /* internal "busy" register */
        !            83: #define HIL_READKBDLANG                0x12    /* read keyboard language code */
        !            84: #define        HIL_READKBDSADR         0xF9
        !            85: #define        HIL_WRITEKBDSADR        0xE9
        !            86: #define HIL_READLPSTAT         0xFA
        !            87: #define HIL_WRITELPSTAT        0xEA
        !            88: #define HIL_READLPCTRL         0xFB
        !            89: #define HIL_WRITELPCTRL        0xEB
        !            90: 
        !            91: /* BUSY bits */
        !            92: #define BSY_LOOPBUSY   0x04
        !            93: 
        !            94: /* LPCTRL bits */
        !            95: #define LPC_AUTOPOLL   0x01    /* enable auto-polling */
        !            96: #define LPC_NOERROR    0x02    /* don't report errors */
        !            97: #define LPC_NORECONF   0x04    /* don't report reconfigure */
        !            98: #define LPC_KBDCOOK    0x10    /* cook all keyboards */
        !            99: #define LPC_RECONF     0x80    /* reconfigure the loop */
        !           100: 
        !           101: /* LPSTAT bits */
        !           102: #define LPS_DEVMASK    0x07    /* number of loop devices */
        !           103: #define LPS_CONFGOOD   0x08    /* reconfiguration worked */
        !           104: #define LPS_CONFFAIL   0x80    /* reconfiguration failed */
        !           105: 
        !           106: /* HIL packet headers */
        !           107: #define HIL_MOUSEDATA   0x2
        !           108: #define HIL_KBDDATA     0x40
        !           109:   
        !           110: #define        HIL_MOUSEMOTION 0x02            /* mouse movement event */
        !           111: #define        HIL_KBDBUTTON   0x40            /* keyboard button event */
        !           112: #define HIL_MOUSEBUTTON 0x40            /* mouse button event */
        !           113: #define HIL_BUTTONBOX   0x60            /* button box event */
        !           114: #define HIL_TABLET      0x02            /* tablet motion event */
        !           115: #define HIL_KNOBBOX     0x03            /* knob box motion data */
        !           116: 
        !           117: /* Magic */
        !           118: #define KBDNMISTAT             ((volatile char *)IOV(0x478005))
        !           119: #define        KBDNMI                  0x04
        !           120: 
        !           121: /* For setting auto repeat on the keyboard */
        !           122: #define ar_format(x)   ~((x - 10) / 10)
        !           123: #define KBD_ARD                400             /* initial delay in msec (10 - 2560) */
        !           124: #define KBD_ARR                60              /* rate (10 - 2550 msec, 2551 == off)*/

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.