1 /*
2 * CDDL HEADER START
3 *
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21
22 /*
23 * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
25 */
26
27 #ifndef _SYS_CONSCONFIG_DACF_H
28 #define _SYS_CONSCONFIG_DACF_H
29
30 #ifdef __cplusplus
31 extern "C" {
32 #endif
33
34 #define CONS_MS 1
35 #define CONS_KBD 2
36
37 /*
38 * This structure contains information about keyboard
39 * and mouse used for auto-configuration.
40 */
41 typedef struct cons_prop {
42 struct cons_prop *cp_next;
43 int cp_type;
44 dev_t cp_dev;
45 int cp_muxid;
46 char *cp_pushmod;
47 } cons_prop_t;
48
49 /*
50 * This structure contains information about the console
51 */
52 typedef struct cons_state {
53 char *cons_keyboard_path; /* Keyboard path */
54 char *cons_mouse_path; /* Mouse path */
55 char *cons_stdin_path; /* Standard input path */
56 char *cons_stdout_path; /* Standard output path */
57 char *cons_diag_path; /* Diag device path */
58
59 char *cons_fb_path; /* Frame Buffer path */
60
61 int cons_input_type; /* Type of console input (See below) */
62 int cons_keyboard_problem; /* problem with console keyboard */
63
64 ldi_ident_t cons_li;
65 vnode_t *cons_wc_vp;
66
67 ldi_handle_t conskbd_lh;
68 int conskbd_muxid;
69
70 ldi_handle_t consms_lh;
71 dev_t consms_dev;
72
73 kmutex_t cons_lock;
74
75 cons_prop_t *cons_km_prop;
76 int cons_tem_supported;
77 int cons_stdin_is_kbd;
78 int cons_stdout_is_fb;
79 boolean_t cons_initialized;
80 } cons_state_t;
81
82 /*
83 * Types of console input
84 */
85 #define CONSOLE_LOCAL 0x1 /* keyboard */
86 #define CONSOLE_TIP 0x2 /* serial line */
87 #define CONSOLE_SERIAL_KEYBOARD 0x4 /* serial kbd */
88
89 /*
90 * These macros indicate the state of the system while
91 * the console configuration is running.
92 * CONSCONFIG_BOOTING implies that the driver loading
93 * is in process during boot. CONSCONFIG_DRIVERS_LOADED
94 * means that the driver loading during boot has completed.
95 *
96 * During driver loading while the boot is happening, the
97 * keyboard and mouse minor nodes that are hooked into the console
98 * stream must match those defined by the firmware. After boot
99 * minor nodes are hooked according to a first come first serve
100 * basis.
101 */
102 #define CONSCONFIG_BOOTING 1
103 #define CONSCONFIG_DRIVERS_LOADED 0
104
105 /*
106 * Debug information
107 * Severity levels for printing
108 */
109 #define DPRINT_L0 0 /* print every message */
110 #define DPRINT_L1 1 /* debug */
111 #define DPRINT_L2 2 /* minor errors */
112 #define DPRINT_L3 3 /* major errors */
113 #define DPRINT_L4 4 /* catastrophic errors */
114
115 #define DPRINTF consconfig_dprintf
116
117 extern void kadb_uses_kernel(void);
118
119 #ifdef __cplusplus
120 }
121 #endif
122
123 #endif /* _SYS_CONSCONFIG_DACF_H */