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
31extern "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 */
41typedef 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 */
52typedef 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
58	char	*cons_fb_path;		/* Frame Buffer path */
59
60	int	cons_input_type;	/* Type of console input (See below) */
61	int	cons_keyboard_problem;	/* problem with console keyboard */
62
63	ldi_ident_t	cons_li;
64	vnode_t		*cons_wc_vp;
65
66	ldi_handle_t	conskbd_lh;
67	int		conskbd_muxid;
68
69	ldi_handle_t	consms_lh;
70	dev_t		consms_dev;
71
72	kmutex_t	cons_lock;
73
74	cons_prop_t	*cons_km_prop;
75	int		cons_tem_supported;
76	int		cons_stdin_is_kbd;
77	int		cons_stdout_is_fb;
78	boolean_t	cons_initialized;
79} cons_state_t;
80
81/*
82 * Types of console input
83 */
84#define	CONSOLE_LOCAL			0x1	/* keyboard */
85#define	CONSOLE_TIP			0x2	/* serial line */
86#define	CONSOLE_SERIAL_KEYBOARD		0x4	/* serial kbd */
87
88/*
89 * These macros indicate the state of the system while
90 * the console configuration is running.
91 * CONSCONFIG_BOOTING implies that the driver loading
92 * is in process during boot.  CONSCONFIG_DRIVERS_LOADED
93 * means that the driver loading during boot has completed.
94 *
95 * During driver loading while the boot is happening, the
96 * keyboard and mouse minor nodes that are hooked into the console
97 * stream must match those defined by the firmware.  After boot
98 * minor nodes are hooked according to a first come first serve
99 * basis.
100 */
101#define	CONSCONFIG_BOOTING			1
102#define	CONSCONFIG_DRIVERS_LOADED		0
103
104/*
105 * Debug information
106 * Severity levels for printing
107 */
108#define	DPRINT_L0	0	/* print every message */
109#define	DPRINT_L1	1	/* debug */
110#define	DPRINT_L2	2	/* minor errors */
111#define	DPRINT_L3	3	/* major errors */
112#define	DPRINT_L4	4	/* catastrophic errors */
113
114#define	DPRINTF consconfig_dprintf
115
116extern void	kadb_uses_kernel(void);
117
118#ifdef	__cplusplus
119}
120#endif
121
122#endif	/* _SYS_CONSCONFIG_DACF_H */
123