1996-11-14 22:19:17 +00:00
|
|
|
/*-
|
|
|
|
* Copyright (c) 1996 Kazutaka YOKOTA (yokota@zodiac.mech.utsunomiya-u.ac.jp)
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 3. The name of the author may not be used to endorse or promote
|
|
|
|
* products derived from this software without specific prior written
|
|
|
|
* permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*
|
1999-01-06 05:49:30 +00:00
|
|
|
* $Id: kbdio.h,v 1.8 1998/08/06 09:15:53 dfr Exp $
|
1998-08-06 09:15:54 +00:00
|
|
|
* from: i386/isa kbdio.h,v 1.7
|
1996-11-14 22:19:17 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _I386_ISA_KBDIO_H_
|
|
|
|
#define _I386_ISA_KBDIO_H_
|
|
|
|
|
|
|
|
/* constants */
|
|
|
|
|
|
|
|
/* I/O ports */
|
1996-12-04 04:21:30 +00:00
|
|
|
#ifdef PC98
|
|
|
|
#define KBD_STATUS_PORT 2 /* status port, read */
|
|
|
|
#define KBD_COMMAND_PORT 2 /* controller command port, write */
|
|
|
|
#define KBD_DATA_PORT 0 /* data port, read/write
|
1997-01-15 18:16:32 +00:00
|
|
|
* also used as keyboard command
|
|
|
|
* and mouse command port
|
|
|
|
*/
|
1996-12-04 04:21:30 +00:00
|
|
|
#else
|
1996-11-14 22:19:17 +00:00
|
|
|
#define KBD_STATUS_PORT 4 /* status port, read */
|
|
|
|
#define KBD_COMMAND_PORT 4 /* controller command port, write */
|
|
|
|
#define KBD_DATA_PORT 0 /* data port, read/write
|
1997-01-15 18:16:32 +00:00
|
|
|
* also used as keyboard command
|
|
|
|
* and mouse command port
|
|
|
|
*/
|
1996-12-04 04:21:30 +00:00
|
|
|
#endif /* PC98 */
|
1997-01-15 18:16:32 +00:00
|
|
|
|
1996-11-14 22:19:17 +00:00
|
|
|
/* controller commands (sent to KBD_COMMAND_PORT) */
|
|
|
|
#define KBDC_SET_COMMAND_BYTE 0x0060
|
|
|
|
#define KBDC_GET_COMMAND_BYTE 0x0020
|
|
|
|
#define KBDC_WRITE_TO_AUX 0x00d4
|
|
|
|
#define KBDC_DISABLE_AUX_PORT 0x00a7
|
|
|
|
#define KBDC_ENABLE_AUX_PORT 0x00a8
|
|
|
|
#define KBDC_TEST_AUX_PORT 0x00a9
|
|
|
|
#define KBDC_DIAGNOSE 0x00aa
|
|
|
|
#define KBDC_TEST_KBD_PORT 0x00ab
|
|
|
|
#define KBDC_DISABLE_KBD_PORT 0x00ad
|
|
|
|
#define KBDC_ENABLE_KBD_PORT 0x00ae
|
|
|
|
|
|
|
|
/* controller command byte (set by KBDC_SET_COMMAND_BYTE) */
|
|
|
|
#define KBD_TRANSLATION 0x0040
|
|
|
|
#define KBD_RESERVED_BITS 0x0004
|
Alot of fixes from kazu:
1. All the suggestions earlier made by Bruce: renaming some symbols,
stricter error checking, removing redundant code, etc.
2. The `psm' driver preserves the default counter resolution and
report rate, whatever they are after reset. (Based on reports and
suggestion from Nate and Rob Bolin).
3. The `psm' driver now does not check the so-called sync. bit in the
first byte of the data packet by default, so that the tapping feature
of ALPUS GlidePoint works (based on reports from Louis Mamakos). I
tested the code with ALPUS Desktop GlidePoint (M/N GP101) and found
no problem; tapping worked. It appears ALPUS produces several models
of GlidePoint. I hope the other models are OK too.
The check code can still be activated by defining the PSM_CHECKSYNC
option in the config file. (The bit checking slightly reduces, if not
completely eliminates, weird mouse behavior cased by unsynchronized
mouse data packets. It also helps us to detect if the mouse interrupt
can ever be lost. But, well, if there are devices which cannot be
supported this way...)
4. The `psm' driver does not include the protocol emulation code by
default. The code can still be compiled in if the PSM_EMULATION option
is specified in the config file. Louis Mamakos suggests the emulation
code is putting too much in the kernel, and `moused' works well.
I will think about this later and decide if the entire emulation
code should be removed.
5. And, of course, the fix in `scprobe()' from Bruce to cure the
UserConfig problem. My code in `kbdio.c' is slightly different from
his patch, but has the same effect. There still is a possibility that
`scprobe()' gets confused, if, for whatever reasons, the user holds
down a key for very long time during the boot process. But we cannot
cope with everything, can we?
Submitted by: Kazutaka YOKOTA (yokota@zodiac.mech.utsunomiya-u.ac.jp)
1996-12-01 19:05:50 +00:00
|
|
|
#define KBD_OVERRIDE_KBD_LOCK 0x0008
|
1996-11-14 22:19:17 +00:00
|
|
|
#define KBD_ENABLE_KBD_PORT 0x0000
|
|
|
|
#define KBD_DISABLE_KBD_PORT 0x0010
|
|
|
|
#define KBD_ENABLE_AUX_PORT 0x0000
|
|
|
|
#define KBD_DISABLE_AUX_PORT 0x0020
|
|
|
|
#define KBD_ENABLE_AUX_INT 0x0002
|
|
|
|
#define KBD_DISABLE_AUX_INT 0x0000
|
|
|
|
#define KBD_ENABLE_KBD_INT 0x0001
|
|
|
|
#define KBD_DISABLE_KBD_INT 0x0000
|
|
|
|
#define KBD_KBD_CONTROL_BITS (KBD_DISABLE_KBD_PORT | KBD_ENABLE_KBD_INT)
|
|
|
|
#define KBD_AUX_CONTROL_BITS (KBD_DISABLE_AUX_PORT | KBD_ENABLE_AUX_INT)
|
|
|
|
|
|
|
|
/* keyboard device commands (sent to KBD_DATA_PORT) */
|
|
|
|
#define KBDC_RESET_KBD 0x00ff
|
|
|
|
#define KBDC_ENABLE_KBD 0x00f4
|
|
|
|
#define KBDC_DISABLE_KBD 0x00f5
|
|
|
|
#define KBDC_SET_DEFAULTS 0x00f6
|
|
|
|
#define KBDC_SEND_DEV_ID 0x00f2
|
|
|
|
#define KBDC_SET_LEDS 0x00ed
|
|
|
|
#define KBDC_ECHO 0x00ee
|
1997-01-15 18:16:32 +00:00
|
|
|
#define KBDC_SET_SCANCODE_SET 0x00f0
|
1996-11-14 22:19:17 +00:00
|
|
|
#define KBDC_SET_TYPEMATIC 0x00f3
|
|
|
|
|
|
|
|
/* aux device commands (sent to KBD_DATA_PORT) */
|
|
|
|
#define PSMC_RESET_DEV 0x00ff
|
|
|
|
#define PSMC_ENABLE_DEV 0x00f4
|
|
|
|
#define PSMC_DISABLE_DEV 0x00f5
|
1997-01-15 18:16:32 +00:00
|
|
|
#define PSMC_SET_DEFAULTS 0x00f6
|
1996-11-14 22:19:17 +00:00
|
|
|
#define PSMC_SEND_DEV_ID 0x00f2
|
|
|
|
#define PSMC_SEND_DEV_STATUS 0x00e9
|
Alot of fixes from kazu:
1. All the suggestions earlier made by Bruce: renaming some symbols,
stricter error checking, removing redundant code, etc.
2. The `psm' driver preserves the default counter resolution and
report rate, whatever they are after reset. (Based on reports and
suggestion from Nate and Rob Bolin).
3. The `psm' driver now does not check the so-called sync. bit in the
first byte of the data packet by default, so that the tapping feature
of ALPUS GlidePoint works (based on reports from Louis Mamakos). I
tested the code with ALPUS Desktop GlidePoint (M/N GP101) and found
no problem; tapping worked. It appears ALPUS produces several models
of GlidePoint. I hope the other models are OK too.
The check code can still be activated by defining the PSM_CHECKSYNC
option in the config file. (The bit checking slightly reduces, if not
completely eliminates, weird mouse behavior cased by unsynchronized
mouse data packets. It also helps us to detect if the mouse interrupt
can ever be lost. But, well, if there are devices which cannot be
supported this way...)
4. The `psm' driver does not include the protocol emulation code by
default. The code can still be compiled in if the PSM_EMULATION option
is specified in the config file. Louis Mamakos suggests the emulation
code is putting too much in the kernel, and `moused' works well.
I will think about this later and decide if the entire emulation
code should be removed.
5. And, of course, the fix in `scprobe()' from Bruce to cure the
UserConfig problem. My code in `kbdio.c' is slightly different from
his patch, but has the same effect. There still is a possibility that
`scprobe()' gets confused, if, for whatever reasons, the user holds
down a key for very long time during the boot process. But we cannot
cope with everything, can we?
Submitted by: Kazutaka YOKOTA (yokota@zodiac.mech.utsunomiya-u.ac.jp)
1996-12-01 19:05:50 +00:00
|
|
|
#define PSMC_SEND_DEV_DATA 0x00eb
|
1996-11-14 22:19:17 +00:00
|
|
|
#define PSMC_SET_SCALING11 0x00e6
|
|
|
|
#define PSMC_SET_SCALING21 0x00e7
|
|
|
|
#define PSMC_SET_RESOLUTION 0x00e8
|
|
|
|
#define PSMC_SET_STREAM_MODE 0x00ea
|
Alot of fixes from kazu:
1. All the suggestions earlier made by Bruce: renaming some symbols,
stricter error checking, removing redundant code, etc.
2. The `psm' driver preserves the default counter resolution and
report rate, whatever they are after reset. (Based on reports and
suggestion from Nate and Rob Bolin).
3. The `psm' driver now does not check the so-called sync. bit in the
first byte of the data packet by default, so that the tapping feature
of ALPUS GlidePoint works (based on reports from Louis Mamakos). I
tested the code with ALPUS Desktop GlidePoint (M/N GP101) and found
no problem; tapping worked. It appears ALPUS produces several models
of GlidePoint. I hope the other models are OK too.
The check code can still be activated by defining the PSM_CHECKSYNC
option in the config file. (The bit checking slightly reduces, if not
completely eliminates, weird mouse behavior cased by unsynchronized
mouse data packets. It also helps us to detect if the mouse interrupt
can ever be lost. But, well, if there are devices which cannot be
supported this way...)
4. The `psm' driver does not include the protocol emulation code by
default. The code can still be compiled in if the PSM_EMULATION option
is specified in the config file. Louis Mamakos suggests the emulation
code is putting too much in the kernel, and `moused' works well.
I will think about this later and decide if the entire emulation
code should be removed.
5. And, of course, the fix in `scprobe()' from Bruce to cure the
UserConfig problem. My code in `kbdio.c' is slightly different from
his patch, but has the same effect. There still is a possibility that
`scprobe()' gets confused, if, for whatever reasons, the user holds
down a key for very long time during the boot process. But we cannot
cope with everything, can we?
Submitted by: Kazutaka YOKOTA (yokota@zodiac.mech.utsunomiya-u.ac.jp)
1996-12-01 19:05:50 +00:00
|
|
|
#define PSMC_SET_REMOTE_MODE 0x00f0
|
1996-11-14 22:19:17 +00:00
|
|
|
#define PSMC_SET_SAMPLING_RATE 0x00f3
|
|
|
|
|
|
|
|
/* PSMC_SET_RESOLUTION argument */
|
1997-01-15 18:16:32 +00:00
|
|
|
#define PSMD_RES_LOW 0 /* typically 25ppi */
|
|
|
|
#define PSMD_RES_MEDIUM_LOW 1 /* typically 50ppi */
|
|
|
|
#define PSMD_RES_MEDIUM_HIGH 2 /* typically 100ppi (default) */
|
|
|
|
#define PSMD_RES_HIGH 3 /* typically 200ppi */
|
|
|
|
#define PSMD_MAX_RESOLUTION PSMD_RES_HIGH
|
1996-11-14 22:19:17 +00:00
|
|
|
|
|
|
|
/* PSMC_SET_SAMPLING_RATE */
|
|
|
|
#define PSMD_MAX_RATE 255 /* FIXME: not sure if it's possible */
|
|
|
|
|
|
|
|
/* status bits (KBD_STATUS_PORT) */
|
1996-12-04 04:21:30 +00:00
|
|
|
#ifdef PC98
|
|
|
|
#define KBDS_BUFFER_FULL 0x0002
|
|
|
|
#define KBDS_ANY_BUFFER_FULL 0x0002
|
|
|
|
#define KBDS_KBD_BUFFER_FULL 0x0002
|
|
|
|
#define KBDS_AUX_BUFFER_FULL 0x0002
|
|
|
|
#else
|
1996-11-14 22:19:17 +00:00
|
|
|
#define KBDS_BUFFER_FULL 0x0021
|
|
|
|
#define KBDS_ANY_BUFFER_FULL 0x0001
|
|
|
|
#define KBDS_KBD_BUFFER_FULL 0x0001
|
|
|
|
#define KBDS_AUX_BUFFER_FULL 0x0021
|
1996-12-04 04:21:30 +00:00
|
|
|
#endif
|
Alot of fixes from kazu:
1. All the suggestions earlier made by Bruce: renaming some symbols,
stricter error checking, removing redundant code, etc.
2. The `psm' driver preserves the default counter resolution and
report rate, whatever they are after reset. (Based on reports and
suggestion from Nate and Rob Bolin).
3. The `psm' driver now does not check the so-called sync. bit in the
first byte of the data packet by default, so that the tapping feature
of ALPUS GlidePoint works (based on reports from Louis Mamakos). I
tested the code with ALPUS Desktop GlidePoint (M/N GP101) and found
no problem; tapping worked. It appears ALPUS produces several models
of GlidePoint. I hope the other models are OK too.
The check code can still be activated by defining the PSM_CHECKSYNC
option in the config file. (The bit checking slightly reduces, if not
completely eliminates, weird mouse behavior cased by unsynchronized
mouse data packets. It also helps us to detect if the mouse interrupt
can ever be lost. But, well, if there are devices which cannot be
supported this way...)
4. The `psm' driver does not include the protocol emulation code by
default. The code can still be compiled in if the PSM_EMULATION option
is specified in the config file. Louis Mamakos suggests the emulation
code is putting too much in the kernel, and `moused' works well.
I will think about this later and decide if the entire emulation
code should be removed.
5. And, of course, the fix in `scprobe()' from Bruce to cure the
UserConfig problem. My code in `kbdio.c' is slightly different from
his patch, but has the same effect. There still is a possibility that
`scprobe()' gets confused, if, for whatever reasons, the user holds
down a key for very long time during the boot process. But we cannot
cope with everything, can we?
Submitted by: Kazutaka YOKOTA (yokota@zodiac.mech.utsunomiya-u.ac.jp)
1996-12-01 19:05:50 +00:00
|
|
|
#define KBDS_INPUT_BUFFER_FULL 0x0002
|
1996-11-14 22:19:17 +00:00
|
|
|
|
|
|
|
/* return code */
|
|
|
|
#define KBD_ACK 0x00fa
|
|
|
|
#define KBD_RESEND 0x00fe
|
|
|
|
#define KBD_RESET_DONE 0x00aa
|
|
|
|
#define KBD_RESET_FAIL 0x00fc
|
|
|
|
#define KBD_DIAG_DONE 0x0055
|
|
|
|
#define KBD_DIAG_FAIL 0x00fd
|
|
|
|
#define KBD_ECHO 0x00ee
|
|
|
|
|
|
|
|
#define PSM_ACK 0x00fa
|
|
|
|
#define PSM_RESEND 0x00fe
|
|
|
|
#define PSM_RESET_DONE 0x00aa
|
|
|
|
#define PSM_RESET_FAIL 0x00fc
|
|
|
|
|
|
|
|
/* aux device ID */
|
|
|
|
#define PSM_MOUSE_ID 0
|
|
|
|
#define PSM_BALLPOINT_ID 2
|
- Add support for the following mice to psm/moused/sysmouse:
MS IntelliMouse, Kensington Thinking Mouse, Genius NetScroll,
Genius NetMouse, Genius NetMouse Pro, ALPS GlidePoint, ASCII
MieMouse, Logitech MouseMan+, FirstMouse+
- The `psm' driver is made to recognize various models of PS/2 mice
and enable their extra features so that their additional buttons and
wheel/roller are recognized. The name of the detected model will be
printed at boot time.
- A set of new ioctl functions are added to the `psm', `mse' and
`sysmouse' drivers so that the userland program (such as the X server)
can query device information and change driver settings.
- The wheel/roller movement is handled as the `Z' axis movement by the
mouse drivers and the moused daemon. The Z axis movement may be mapped
to another axis movement or buttons.
- The mouse drivers support a new, standard mouse data format,
MOUSE_PROTO_SYSMOUSE format which can encode x, y, and x axis movement
and up to 10 buttons.
/sys/i386/include/mouse.h
- Added some fields to `mousestatus_t' to store Z axis movement
and flag bits.
- Added the field `model' to `mousehw_t' to store mouse model code.
Defined model codes.
- Extended `mousemode_t'.
- Added new protocols and some constants for them.
- Added new ioctl functions and structures.
- Removed obsolete ioctl definitions.
/sys/i386/include/console.h
- Added `dz' field to the structure `mouse_data' to pass Z axis movement
to `syscons/sysmouse'.
- Removed LEFT_BUTTON, MIDDLE_BUTTON and RIGHT_BUTTON. Use button bits
defined in `mouse.h' instead.
/sys/i386/isa/psm.c
- Added a set of functions to detect various mice which have additional
features (wheel and buttons) unavailable in the standard PS/2 mouse.
- Refined existing ioctl functions and added new ones. Most important
of all is MOUSE_SETLEVEL which manipulates the output level of the driver.
While the output level remains zero, the output from the `psm' driver is
in the standard PS/2 mouse format (three bytes long). When the level
is set to one, the `psm' driver will send data in the extended format.
At the level two the driver uses the format which is native to the
connected mouse is used. (Meaning that the output from the device is
passed to the caller as is, unmodified.) The `psm' driver will pass
such extended data format as is to the caller if the output level is
two, but emulates the standard format if the output level is zero.
- Added kernel configuration flags to set initial resolution
(PSM_CONFIG_RESOLUTION) and acceleration (PSM_CONFIG_ACCEL).
- Removed the compile options PSM_ACCEL, PSM_CHECKSYNC and PSM_EMULATION.
Acceleration ratio is now specified by the kernel configuration flags
stated above. Sync check logic is refined and now standard.
The sync check can be turned off by the new kernel configuration flags
PSM_CONFIG_NOCHECKSYNC (0x100). PSM_EMULATION has been of little use.
- Summer clean up :-) Removed unused code and obsolete comments.
/sys/i386/isa/mse.c
- Created mseioctl() to deal with ioctl functions MOUSE_XXXX.
Most importantly, the MOUSE_SETLEVEL ioctl will change the
output format from the 5 byte format to the new, extended format
so that the caller can take advantage of Z axis movement and additional
buttons.
- Use constants defined in `mouse.h' rather than magic numbers.
/sys/i386/isa/syscons.c
- Changed scioctl() to reflect the new `console.h' and some of the new
ioctls defined in `mouse.h'. Most importantly, the MOUSE_SETLEVEL
ioctl will change the `sysmouse' output format from the MouseSystems
5 byte format to the new, extended format so that the caller can
take advantage of Z axis movement and additional buttons.
- Added support for double/triple click actions of the left button and
single click action of the right button in the virtual console. The
left button double click will select a word under the mouse pointer.
The triple click will select a line and the single click of the right
button will extend the selected region to the current position of
the mouse pointer. This will make the cut/paste support more compatible
with xterm.
/sys/i386/isa/kbdio.h
- Added PSM_INTELLI_ID.
1997-12-07 08:09:19 +00:00
|
|
|
#define PSM_INTELLI_ID 3
|
1996-11-14 22:19:17 +00:00
|
|
|
|
|
|
|
#ifdef KERNEL
|
|
|
|
|
|
|
|
#ifndef TRUE
|
1997-01-15 18:16:32 +00:00
|
|
|
#define TRUE 1
|
1996-11-14 22:19:17 +00:00
|
|
|
#endif
|
|
|
|
#ifndef FALSE
|
|
|
|
#define FALSE 0
|
|
|
|
#endif
|
|
|
|
|
1997-01-15 18:16:32 +00:00
|
|
|
/* types/structures */
|
|
|
|
|
|
|
|
typedef caddr_t KBDC;
|
|
|
|
|
1996-11-14 22:19:17 +00:00
|
|
|
/* function prototypes */
|
|
|
|
|
1997-01-15 18:16:32 +00:00
|
|
|
KBDC kbdc_open __P((int port));
|
|
|
|
|
|
|
|
int kbdc_lock __P((KBDC kbdc, int lock));
|
|
|
|
|
|
|
|
int kbdc_data_ready __P((KBDC kbdc));
|
1996-11-14 22:19:17 +00:00
|
|
|
|
1997-01-15 18:16:32 +00:00
|
|
|
int write_controller_command __P((KBDC kbdc,int c));
|
|
|
|
int write_controller_data __P((KBDC kbdc,int c));
|
1996-11-14 22:19:17 +00:00
|
|
|
|
1997-01-15 18:16:32 +00:00
|
|
|
int write_kbd_command __P((KBDC kbdc,int c));
|
|
|
|
int write_aux_command __P((KBDC kbdc,int c));
|
|
|
|
int send_kbd_command __P((KBDC kbdc,int c));
|
|
|
|
int send_aux_command __P((KBDC kbdc,int c));
|
|
|
|
int send_kbd_command_and_data __P((KBDC kbdc,int c,int d));
|
|
|
|
int send_aux_command_and_data __P((KBDC kbdc,int c,int d));
|
1996-11-14 22:19:17 +00:00
|
|
|
|
1997-01-15 18:16:32 +00:00
|
|
|
int read_controller_data __P((KBDC kbdc));
|
|
|
|
int read_kbd_data __P((KBDC kbdc));
|
|
|
|
int read_kbd_data_no_wait __P((KBDC kbdc));
|
|
|
|
int read_aux_data __P((KBDC kbdc));
|
|
|
|
int read_aux_data_no_wait __P((KBDC kbdc));
|
1996-11-14 22:19:17 +00:00
|
|
|
|
1997-01-15 18:16:32 +00:00
|
|
|
void empty_kbd_buffer __P((KBDC kbdc, int t));
|
|
|
|
void empty_aux_buffer __P((KBDC kbdc, int t));
|
|
|
|
void empty_both_buffers __P((KBDC kbdc, int t));
|
1996-11-14 22:19:17 +00:00
|
|
|
|
1997-01-15 18:16:32 +00:00
|
|
|
int reset_kbd __P((KBDC kbdc));
|
|
|
|
int reset_aux_dev __P((KBDC kbdc));
|
1996-11-14 22:19:17 +00:00
|
|
|
|
1997-01-15 18:16:32 +00:00
|
|
|
int test_controller __P((KBDC kbdc));
|
|
|
|
int test_kbd_port __P((KBDC kbdc));
|
|
|
|
int test_aux_port __P((KBDC kbdc));
|
1996-11-14 22:19:17 +00:00
|
|
|
|
1997-01-15 18:16:32 +00:00
|
|
|
int kbdc_get_device_mask __P((KBDC kbdc));
|
|
|
|
void kbdc_set_device_mask __P((KBDC kbdc, int mask));
|
1996-11-14 22:19:17 +00:00
|
|
|
|
1997-01-15 18:16:32 +00:00
|
|
|
int get_controller_command_byte __P((KBDC kbdc));
|
|
|
|
int set_controller_command_byte __P((KBDC kbdc, int command, int flag));
|
1996-11-14 22:19:17 +00:00
|
|
|
|
|
|
|
#endif /* KERNEL */
|
|
|
|
|
|
|
|
#endif /* !_I386_ISA_KBDIO_H_ */
|