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 */ 124