kbdvar.h revision 1.5.108.3 1 1.5.108.3 yamt /* $NetBSD: kbdvar.h,v 1.5.108.3 2010/03/11 15:02:09 yamt Exp $ */
2 1.1 leo
3 1.1 leo /*
4 1.1 leo * Copyright (c) 1996 Leo Weppelman.
5 1.1 leo * All rights reserved.
6 1.1 leo *
7 1.1 leo * Redistribution and use in source and binary forms, with or without
8 1.1 leo * modification, are permitted provided that the following conditions
9 1.1 leo * are met:
10 1.1 leo * 1. Redistributions of source code must retain the above copyright
11 1.1 leo * notice, this list of conditions and the following disclaimer.
12 1.1 leo * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 leo * notice, this list of conditions and the following disclaimer in the
14 1.1 leo * documentation and/or other materials provided with the distribution.
15 1.1 leo *
16 1.1 leo * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17 1.1 leo * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18 1.1 leo * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19 1.1 leo * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20 1.1 leo * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21 1.1 leo * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 1.1 leo * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 1.1 leo * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 1.1 leo * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25 1.1 leo * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 1.1 leo */
27 1.1 leo
28 1.1 leo #ifndef _KBDVAR_H
29 1.1 leo #define _KBDVAR_H
30 1.1 leo
31 1.1 leo /*
32 1.1 leo * The ringbuffer is the interface between the hard and soft interrupt handler.
33 1.1 leo * The hard interrupt runs straight from the MFP interrupt.
34 1.1 leo */
35 1.1 leo #define KBD_RING_SIZE 256 /* Sz of input ring buffer, must be power of 2 */
36 1.1 leo #define KBD_RING_MASK 255 /* Modulo mask for above */
37 1.1 leo
38 1.1 leo struct kbd_softc {
39 1.1 leo int k_event_mode; /* if 1, collect events, */
40 1.1 leo /* else pass to ite */
41 1.1 leo struct evvar k_events; /* event queue state */
42 1.5.108.2 yamt uint8_t k_soft_cs; /* control-reg. copy */
43 1.5.108.2 yamt uint8_t k_package[20]; /* XXX package being build */
44 1.5.108.2 yamt uint8_t k_pkg_size; /* Size of the package */
45 1.5.108.2 yamt uint8_t k_pkg_idx; /* Running pkg assembly index */
46 1.5.108.2 yamt uint8_t k_pkg_type; /* Type of package */
47 1.5.108.2 yamt const uint8_t *k_sendp; /* Output pointer */
48 1.1 leo int k_send_cnt; /* Chars left for output */
49 1.5 thomas #if NWSKBD>0
50 1.5 thomas struct device *k_wskbddev; /* pointer to wskbd for sending strokes */
51 1.5 thomas int k_pollingmode; /* polling mode on? whatever it isss... */
52 1.5 thomas #endif
53 1.5.108.2 yamt void *k_sicookie; /* softint(9) cookie */
54 1.1 leo };
55 1.1 leo
56 1.1 leo /*
57 1.1 leo * Package types
58 1.1 leo */
59 1.1 leo #define KBD_MEM_PKG 0 /* Memory read package */
60 1.1 leo #define KBD_AMS_PKG 1 /* Absolute mouse package */
61 1.1 leo #define KBD_RMS_PKG 2 /* Relative mouse package */
62 1.1 leo #define KBD_CLK_PKG 3 /* Clock package */
63 1.1 leo #define KBD_JOY0_PKG 4 /* Joystick-0 package */
64 1.1 leo #define KBD_JOY1_PKG 5 /* Joystick-1 package */
65 1.1 leo #define KBD_TIMEO_PKG 6 /* Timeout package */
66 1.1 leo
67 1.1 leo #ifdef _KERNEL
68 1.5.108.2 yamt extern uint8_t kbd_modifier;
69 1.2 leo
70 1.5.108.1 yamt void kbd_bell_gparms(u_int *, u_int *, u_int *);
71 1.5.108.1 yamt void kbd_bell_sparms(u_int, u_int, u_int);
72 1.5.108.2 yamt void kbd_write(const uint8_t *, int);
73 1.5.108.1 yamt int kbdgetcn(void);
74 1.5.108.1 yamt void kbdbell(void);
75 1.5.108.1 yamt void kbdenable(void);
76 1.4 simonb #endif /* _KERNEL */
77 1.1 leo
78 1.1 leo #endif /* _KBDVAR_H */
79