kbio.h revision 1.3 1 1.3 minoura /* $NetBSD: kbio.h,v 1.3 2004/05/08 08:40:08 minoura Exp $ */
2 1.1 oki
3 1.1 oki /*
4 1.1 oki * Copyright (c) 1992, 1993
5 1.1 oki * The Regents of the University of California. All rights reserved.
6 1.1 oki *
7 1.1 oki * This software was developed by the Computer Systems Engineering group
8 1.1 oki * at Lawrence Berkeley Laboratory under DARPA contract BG 91-66 and
9 1.1 oki * contributed to Berkeley.
10 1.1 oki *
11 1.1 oki * All advertising materials mentioning features or use of this software
12 1.1 oki * must display the following acknowledgement:
13 1.1 oki * This product includes software developed by the University of
14 1.1 oki * California, Lawrence Berkeley Laboratory.
15 1.1 oki *
16 1.1 oki * Redistribution and use in source and binary forms, with or without
17 1.1 oki * modification, are permitted provided that the following conditions
18 1.1 oki * are met:
19 1.1 oki * 1. Redistributions of source code must retain the above copyright
20 1.1 oki * notice, this list of conditions and the following disclaimer.
21 1.1 oki * 2. Redistributions in binary form must reproduce the above copyright
22 1.1 oki * notice, this list of conditions and the following disclaimer in the
23 1.1 oki * documentation and/or other materials provided with the distribution.
24 1.2 agc * 3. Neither the name of the University nor the names of its contributors
25 1.1 oki * may be used to endorse or promote products derived from this software
26 1.1 oki * without specific prior written permission.
27 1.1 oki *
28 1.1 oki * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
29 1.1 oki * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
30 1.1 oki * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
31 1.1 oki * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
32 1.1 oki * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
33 1.1 oki * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
34 1.1 oki * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
35 1.1 oki * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
36 1.1 oki * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
37 1.1 oki * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
38 1.1 oki * SUCH DAMAGE.
39 1.1 oki *
40 1.1 oki * @(#)kbio.h 8.1 (Berkeley) 6/11/93
41 1.1 oki */
42 1.1 oki
43 1.3 minoura #ifndef _X68K_KBIO_H_
44 1.3 minoura #define _X68K_KBIO_H_
45 1.3 minoura
46 1.1 oki /*
47 1.1 oki * The following is a minimal emulation of Sun's `kio' structures
48 1.1 oki * and related operations necessary to make X11 happy (i.e., make it
49 1.1 oki * compile, and make old X11 binaries run).
50 1.1 oki */
51 1.1 oki
52 1.1 oki /*
53 1.1 oki * The kiockey structure apparently gets and/or sets keyboard mappings.
54 1.1 oki * It seems to be kind of useless, but X11 uses it (according to the
55 1.1 oki * comments) to figure out when a Sun 386i has a type-4 keyboard but
56 1.1 oki * claims to have a type-3 keyboard. We need just enough to cause the
57 1.1 oki * appropriate ioctl to return the appropriate magic value.
58 1.1 oki *
59 1.1 oki * KIOCGETKEY fills in kio_entry from kio_station. Not sure what tablemask
60 1.1 oki * is for; X sets it before the call, so it is not an output, but we do not
61 1.1 oki * care anyway. KIOCSDIRECT is supposed to tell the kernel whether to send
62 1.1 oki * keys to the console or to X; we just send them to X whenever the keyboard
63 1.1 oki * is open at all. (XXX may need to change this later)
64 1.1 oki *
65 1.1 oki * Keyboard commands and types are defined in kbd.h as they are actually
66 1.1 oki * real hardware commands and type numbers.
67 1.1 oki */
68 1.1 oki struct okiockey { /* Out-dated key translation structure */
69 1.1 oki int kio_tablemask; /* whatever */
70 1.1 oki u_char kio_station; /* key number */
71 1.1 oki u_char kio_entry; /* HOLE if not present */
72 1.1 oki char kio_text[10]; /* the silly escape sequences (unsupported) */
73 1.1 oki };
74 1.1 oki
75 1.1 oki struct kiockey {
76 1.1 oki int kio_tablemask; /* whatever */
77 1.1 oki u_char kio_station; /* key number */
78 1.1 oki u_short kio_entry; /* HOLE if not present */
79 1.1 oki char kio_text[10]; /* the silly escape sequences (unsupported) */
80 1.1 oki };
81 1.1 oki
82 1.1 oki /* Same as bell_info */
83 1.1 oki struct kbiocbell {
84 1.1 oki int volume;
85 1.1 oki int pitch;
86 1.1 oki int msec;
87 1.1 oki };
88 1.1 oki
89 1.1 oki /*
90 1.1 oki * Keyboard LED masks (used to set LED's)
91 1.1 oki */
92 1.1 oki #define LED_ZENKAKU 0x40
93 1.1 oki #define LED_HIRAGANA 0x20
94 1.1 oki #define LED_INSERT 0x10
95 1.1 oki #define LED_CAPS_LOCK 0x08
96 1.1 oki #define LED_CODE_INPUT 0x04
97 1.1 oki #define LED_ROMAJI 0x02
98 1.1 oki #define LED_KANA_LOCK 0x01
99 1.1 oki
100 1.1 oki /*
101 1.1 oki * Values for kio_tablemask. These determine which table to read/modify
102 1.1 oki * in KIOC[SG]KEY ioctls. Currently, we only have "non-shift" and "shift"
103 1.1 oki * tables.
104 1.1 oki */
105 1.1 oki #define KIOC_NOMASK 0x0
106 1.1 oki #define KIOC_CAPSMASK 0x1
107 1.1 oki #define KIOC_SHIFTMASK 0xe
108 1.1 oki #define KIOC_CTRLMASK 0x30
109 1.1 oki #define KIOC_ALTGMASK 0x200
110 1.1 oki #define KIOC_NUMLMASK 0x800
111 1.1 oki
112 1.1 oki #define HOLE 0x302 /* value for kio_entry to say `really type 3' */
113 1.1 oki
114 1.1 oki #define KIOCTRANS _IOW('k', 0, int) /* set translation mode */
115 1.1 oki /* (we only accept TR_UNTRANS_EVENT) */
116 1.1 oki #define KIOCGETKEY _IOWR('k', 2, struct okiockey) /* fill in kio_entry */
117 1.1 oki #define KIOCGTRANS _IOR('k', 5, int) /* get translation mode */
118 1.1 oki #define KIOCCMD _IOW('k', 8, int) /* X uses this to ring bell */
119 1.1 oki #define KIOCTYPE _IOR('k', 9, int) /* get keyboard type */
120 1.1 oki #define KIOCSDIRECT _IOW('k', 10, int) /* keys to console? */
121 1.1 oki #define KIOCSKEY _IOW('k', 12, struct kiockey) /* set xlat mode */
122 1.1 oki #define KIOCGKEY _IOWR('k', 13, struct kiockey) /* get xlat mode */
123 1.1 oki #define KIOCLAYOUT _IOR('k', 20, int) /* get keyboard layout */
124 1.1 oki #define KIOCSLED _IOW('k', 14, char) /* set LED state */
125 1.1 oki #define KIOCGLED _IOR('k', 15, char) /* get LED state */
126 1.1 oki #define KIOCSBELL _IOW('k', 16, struct kbiocbell) /* set bell parameter */
127 1.1 oki
128 1.1 oki #define TR_NONE 0 /* X compat, unsupported */
129 1.1 oki #define TR_ASCII 1 /* X compat, unsupported */
130 1.1 oki #define TR_EVENT 2 /* X compat, unsupported */
131 1.1 oki #define TR_UNTRANS_EVENT 3
132 1.3 minoura
133 1.3 minoura #endif
134