1a9643ea8Slogwang /*- 2*22ce4affSfengbojiang * SPDX-License-Identifier: BSD-3-Clause 3*22ce4affSfengbojiang * 4a9643ea8Slogwang * Copyright (c) 1988 University of Utah. 5a9643ea8Slogwang * Copyright (c) 1991 The Regents of the University of California. 6a9643ea8Slogwang * All rights reserved. 7a9643ea8Slogwang * 8a9643ea8Slogwang * This code is derived from software contributed to Berkeley by 9a9643ea8Slogwang * the Systems Programming Group of the University of Utah Computer 10a9643ea8Slogwang * Science Department. 11a9643ea8Slogwang * 12a9643ea8Slogwang * Redistribution and use in source and binary forms, with or without 13a9643ea8Slogwang * modification, are permitted provided that the following conditions 14a9643ea8Slogwang * are met: 15a9643ea8Slogwang * 1. Redistributions of source code must retain the above copyright 16a9643ea8Slogwang * notice, this list of conditions and the following disclaimer. 17a9643ea8Slogwang * 2. Redistributions in binary form must reproduce the above copyright 18a9643ea8Slogwang * notice, this list of conditions and the following disclaimer in the 19a9643ea8Slogwang * documentation and/or other materials provided with the distribution. 20*22ce4affSfengbojiang * 3. Neither the name of the University nor the names of its contributors 21a9643ea8Slogwang * may be used to endorse or promote products derived from this software 22a9643ea8Slogwang * without specific prior written permission. 23a9643ea8Slogwang * 24a9643ea8Slogwang * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 25a9643ea8Slogwang * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 26a9643ea8Slogwang * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 27a9643ea8Slogwang * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 28a9643ea8Slogwang * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 29a9643ea8Slogwang * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 30a9643ea8Slogwang * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 31a9643ea8Slogwang * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 32a9643ea8Slogwang * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 33a9643ea8Slogwang * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 34a9643ea8Slogwang * SUCH DAMAGE. 35a9643ea8Slogwang * 36a9643ea8Slogwang * from: @(#)cons.h 7.2 (Berkeley) 5/9/91 37a9643ea8Slogwang * $FreeBSD$ 38a9643ea8Slogwang */ 39a9643ea8Slogwang 40a9643ea8Slogwang #ifndef _MACHINE_CONS_H_ 41a9643ea8Slogwang #define _MACHINE_CONS_H_ 42a9643ea8Slogwang 43a9643ea8Slogwang struct consdev; 44a9643ea8Slogwang struct tty; 45a9643ea8Slogwang 46a9643ea8Slogwang typedef void cn_probe_t(struct consdev *); 47a9643ea8Slogwang typedef void cn_init_t(struct consdev *); 48a9643ea8Slogwang typedef void cn_term_t(struct consdev *); 49a9643ea8Slogwang typedef void cn_grab_t(struct consdev *); 50a9643ea8Slogwang typedef void cn_ungrab_t(struct consdev *); 51a9643ea8Slogwang typedef int cn_getc_t(struct consdev *); 52a9643ea8Slogwang typedef void cn_putc_t(struct consdev *, int); 53a9643ea8Slogwang 54a9643ea8Slogwang struct consdev_ops { 55a9643ea8Slogwang cn_probe_t *cn_probe; 56a9643ea8Slogwang /* probe hardware and fill in consdev info */ 57a9643ea8Slogwang cn_init_t *cn_init; 58a9643ea8Slogwang /* turn on as console */ 59a9643ea8Slogwang cn_term_t *cn_term; 60a9643ea8Slogwang /* turn off as console */ 61a9643ea8Slogwang cn_getc_t *cn_getc; 62a9643ea8Slogwang /* kernel getchar interface */ 63a9643ea8Slogwang cn_putc_t *cn_putc; 64a9643ea8Slogwang /* kernel putchar interface */ 65a9643ea8Slogwang cn_grab_t *cn_grab; 66a9643ea8Slogwang /* grab console for exclusive kernel use */ 67a9643ea8Slogwang cn_ungrab_t *cn_ungrab; 68a9643ea8Slogwang /* ungrab console */ 69*22ce4affSfengbojiang cn_init_t *cn_resume; 70*22ce4affSfengbojiang /* set up console after sleep, optional */ 71a9643ea8Slogwang }; 72a9643ea8Slogwang 73a9643ea8Slogwang struct consdev { 74a9643ea8Slogwang const struct consdev_ops *cn_ops; 75a9643ea8Slogwang /* console device operations. */ 76a9643ea8Slogwang short cn_pri; /* pecking order; the higher the better */ 77a9643ea8Slogwang void *cn_arg; /* drivers method argument */ 78a9643ea8Slogwang int cn_flags; /* capabilities of this console */ 79a9643ea8Slogwang char cn_name[SPECNAMELEN + 1]; /* console (device) name */ 80a9643ea8Slogwang }; 81a9643ea8Slogwang 82a9643ea8Slogwang /* values for cn_pri - reflect our policy for console selection */ 83a9643ea8Slogwang #define CN_DEAD 0 /* device doesn't exist */ 84a9643ea8Slogwang #define CN_LOW 1 /* device is a last restort only */ 85a9643ea8Slogwang #define CN_NORMAL 2 /* device exists but is nothing special */ 86a9643ea8Slogwang #define CN_INTERNAL 3 /* "internal" bit-mapped display */ 87a9643ea8Slogwang #define CN_REMOTE 4 /* serial interface with remote bit set */ 88a9643ea8Slogwang 89a9643ea8Slogwang /* Values for cn_flags. */ 90a9643ea8Slogwang #define CN_FLAG_NODEBUG 0x00000001 /* Not supported with debugger. */ 91a9643ea8Slogwang #define CN_FLAG_NOAVAIL 0x00000002 /* Temporarily not available. */ 92a9643ea8Slogwang 93a9643ea8Slogwang /* Visibility of characters in cngets() */ 94a9643ea8Slogwang #define GETS_NOECHO 0 /* Disable echoing of characters. */ 95a9643ea8Slogwang #define GETS_ECHO 1 /* Enable echoing of characters. */ 96a9643ea8Slogwang #define GETS_ECHOPASS 2 /* Print a * for every character. */ 97a9643ea8Slogwang 98a9643ea8Slogwang #ifdef _KERNEL 99a9643ea8Slogwang 100a9643ea8Slogwang extern struct msgbuf consmsgbuf; /* Message buffer for constty. */ 101a9643ea8Slogwang extern struct tty *constty; /* Temporary virtual console. */ 102a9643ea8Slogwang 103a9643ea8Slogwang #define CONSOLE_DEVICE(name, ops, arg) \ 104a9643ea8Slogwang static struct consdev name = { \ 105a9643ea8Slogwang .cn_ops = &ops, \ 106a9643ea8Slogwang .cn_arg = (arg), \ 107a9643ea8Slogwang }; \ 108a9643ea8Slogwang DATA_SET(cons_set, name) 109a9643ea8Slogwang 110*22ce4affSfengbojiang #define CONSOLE_DRIVER(name, ...) \ 111a9643ea8Slogwang static const struct consdev_ops name##_consdev_ops = { \ 112*22ce4affSfengbojiang /* Mandatory methods. */ \ 113a9643ea8Slogwang .cn_probe = name##_cnprobe, \ 114a9643ea8Slogwang .cn_init = name##_cninit, \ 115a9643ea8Slogwang .cn_term = name##_cnterm, \ 116a9643ea8Slogwang .cn_getc = name##_cngetc, \ 117a9643ea8Slogwang .cn_putc = name##_cnputc, \ 118a9643ea8Slogwang .cn_grab = name##_cngrab, \ 119a9643ea8Slogwang .cn_ungrab = name##_cnungrab, \ 120*22ce4affSfengbojiang /* Optional fields. */ \ 121*22ce4affSfengbojiang __VA_ARGS__ \ 122a9643ea8Slogwang }; \ 123a9643ea8Slogwang CONSOLE_DEVICE(name##_consdev, name##_consdev_ops, NULL) 124a9643ea8Slogwang 125a9643ea8Slogwang /* Other kernel entry points. */ 126a9643ea8Slogwang void cninit(void); 127a9643ea8Slogwang void cninit_finish(void); 128a9643ea8Slogwang int cnadd(struct consdev *); 129a9643ea8Slogwang void cnavailable(struct consdev *, int); 130a9643ea8Slogwang void cnremove(struct consdev *); 131a9643ea8Slogwang void cnselect(struct consdev *); 132a9643ea8Slogwang void cngrab(void); 133a9643ea8Slogwang void cnungrab(void); 134*22ce4affSfengbojiang void cnresume(void); 135a9643ea8Slogwang int cncheckc(void); 136a9643ea8Slogwang int cngetc(void); 137a9643ea8Slogwang void cngets(char *, size_t, int); 138a9643ea8Slogwang void cnputc(int); 139*22ce4affSfengbojiang void cnputs(const char *); 140*22ce4affSfengbojiang void cnputsn(const char *, size_t); 141a9643ea8Slogwang int cnunavailable(void); 142a9643ea8Slogwang void constty_set(struct tty *tp); 143a9643ea8Slogwang void constty_clear(void); 144a9643ea8Slogwang 145a9643ea8Slogwang /* sc(4) / vt(4) coexistence shim */ 146a9643ea8Slogwang #define VTY_SC 0x01 147a9643ea8Slogwang #define VTY_VT 0x02 148a9643ea8Slogwang int vty_enabled(unsigned int); 149a9643ea8Slogwang void vty_set_preferred(unsigned int); 150a9643ea8Slogwang 151a9643ea8Slogwang #endif /* _KERNEL */ 152a9643ea8Slogwang 153a9643ea8Slogwang #endif /* !_MACHINE_CONS_H_ */ 154