1*2c2f96dcSApple OSS Distributions /* 2*2c2f96dcSApple OSS Distributions * Copyright (c) 2005-2020 Apple Computer, Inc. All rights reserved. 3*2c2f96dcSApple OSS Distributions * 4*2c2f96dcSApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ 5*2c2f96dcSApple OSS Distributions * 6*2c2f96dcSApple OSS Distributions * This file contains Original Code and/or Modifications of Original Code 7*2c2f96dcSApple OSS Distributions * as defined in and that are subject to the Apple Public Source License 8*2c2f96dcSApple OSS Distributions * Version 2.0 (the 'License'). You may not use this file except in 9*2c2f96dcSApple OSS Distributions * compliance with the License. The rights granted to you under the License 10*2c2f96dcSApple OSS Distributions * may not be used to create, or enable the creation or redistribution of, 11*2c2f96dcSApple OSS Distributions * unlawful or unlicensed copies of an Apple operating system, or to 12*2c2f96dcSApple OSS Distributions * circumvent, violate, or enable the circumvention or violation of, any 13*2c2f96dcSApple OSS Distributions * terms of an Apple operating system software license agreement. 14*2c2f96dcSApple OSS Distributions * 15*2c2f96dcSApple OSS Distributions * Please obtain a copy of the License at 16*2c2f96dcSApple OSS Distributions * http://www.opensource.apple.com/apsl/ and read it before using this file. 17*2c2f96dcSApple OSS Distributions * 18*2c2f96dcSApple OSS Distributions * The Original Code and all software distributed under the License are 19*2c2f96dcSApple OSS Distributions * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 20*2c2f96dcSApple OSS Distributions * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 21*2c2f96dcSApple OSS Distributions * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 22*2c2f96dcSApple OSS Distributions * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 23*2c2f96dcSApple OSS Distributions * Please see the License for the specific language governing rights and 24*2c2f96dcSApple OSS Distributions * limitations under the License. 25*2c2f96dcSApple OSS Distributions * 26*2c2f96dcSApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ 27*2c2f96dcSApple OSS Distributions */ 28*2c2f96dcSApple OSS Distributions /* 29*2c2f96dcSApple OSS Distributions * @OSF_COPYRIGHT@ 30*2c2f96dcSApple OSS Distributions */ 31*2c2f96dcSApple OSS Distributions /* 32*2c2f96dcSApple OSS Distributions * @APPLE_FREE_COPYRIGHT@ 33*2c2f96dcSApple OSS Distributions */ 34*2c2f96dcSApple OSS Distributions 35*2c2f96dcSApple OSS Distributions #ifndef _CONSOLE_SERIAL_PROTOS_H_ 36*2c2f96dcSApple OSS Distributions #define _CONSOLE_SERIAL_PROTOS_H_ 37*2c2f96dcSApple OSS Distributions 38*2c2f96dcSApple OSS Distributions #ifdef __cplusplus 39*2c2f96dcSApple OSS Distributions extern "C" { 40*2c2f96dcSApple OSS Distributions #endif 41*2c2f96dcSApple OSS Distributions 42*2c2f96dcSApple OSS Distributions #include <stdbool.h> 43*2c2f96dcSApple OSS Distributions 44*2c2f96dcSApple OSS Distributions void serial_keyboard_init(void); 45*2c2f96dcSApple OSS Distributions void serial_keyboard_start(void) __dead2; 46*2c2f96dcSApple OSS Distributions void serial_keyboard_poll(void) __dead2; 47*2c2f96dcSApple OSS Distributions 48*2c2f96dcSApple OSS Distributions /* Boot serial mode (see bits below). */ 49*2c2f96dcSApple OSS Distributions extern uint32_t serialmode; 50*2c2f96dcSApple OSS Distributions 51*2c2f96dcSApple OSS Distributions /* Is output supported ? */ 52*2c2f96dcSApple OSS Distributions #define SERIALMODE_OUTPUT 0x01 53*2c2f96dcSApple OSS Distributions 54*2c2f96dcSApple OSS Distributions /* Is input supported ? */ 55*2c2f96dcSApple OSS Distributions #define SERIALMODE_INPUT 0x02 56*2c2f96dcSApple OSS Distributions 57*2c2f96dcSApple OSS Distributions /* Force synchronous output ? */ 58*2c2f96dcSApple OSS Distributions #define SERIALMODE_SYNCDRAIN 0x04 59*2c2f96dcSApple OSS Distributions 60*2c2f96dcSApple OSS Distributions /* Load Base/Recovery/FVUnlock TTY */ 61*2c2f96dcSApple OSS Distributions #define SERIALMODE_BASE_TTY 0x08 62*2c2f96dcSApple OSS Distributions 63*2c2f96dcSApple OSS Distributions /* Prevent IOLogs writing to serial */ 64*2c2f96dcSApple OSS Distributions #define SERIALMODE_NO_IOLOG 0x10 65*2c2f96dcSApple OSS Distributions 66*2c2f96dcSApple OSS Distributions /* Allow DriverKit os_log/IOLogs writing to serial */ 67*2c2f96dcSApple OSS Distributions #define SERIALMODE_DKLOG 0x20 68*2c2f96dcSApple OSS Distributions 69*2c2f96dcSApple OSS Distributions /** Start logging on to a serial only once data has been received on this 70*2c2f96dcSApple OSS Distributions * serial. Requires SERIALMODE_INPUT set, ingored otherwise. */ 71*2c2f96dcSApple OSS Distributions #define SERIALMODE_ON_DEMAND 0x40 72*2c2f96dcSApple OSS Distributions 73*2c2f96dcSApple OSS Distributions extern uint32_t cons_ops_index; 74*2c2f96dcSApple OSS Distributions extern const uint32_t nconsops; 75*2c2f96dcSApple OSS Distributions 76*2c2f96dcSApple OSS Distributions /* disable_serial_output disables kprintf() *and* unbuffered panic output. */ 77*2c2f96dcSApple OSS Distributions extern bool disable_serial_output; 78*2c2f96dcSApple OSS Distributions 79*2c2f96dcSApple OSS Distributions /* Shortcuts for serialmode & {SERIALMODE_NOIOLOG, SERIALMODE_DKLOG}. */ 80*2c2f96dcSApple OSS Distributions extern bool disable_iolog_serial_output; 81*2c2f96dcSApple OSS Distributions extern bool enable_dklog_serial_output; 82*2c2f96dcSApple OSS Distributions 83*2c2f96dcSApple OSS Distributions void console_init(void); 84*2c2f96dcSApple OSS Distributions 85*2c2f96dcSApple OSS Distributions int _serial_getc(bool wait); 86*2c2f96dcSApple OSS Distributions int _vcgetc(bool wait); 87*2c2f96dcSApple OSS Distributions 88*2c2f96dcSApple OSS Distributions struct console_ops { 89*2c2f96dcSApple OSS Distributions void (*putc)(char, bool); 90*2c2f96dcSApple OSS Distributions int (*getc)(bool); 91*2c2f96dcSApple OSS Distributions }; 92*2c2f96dcSApple OSS Distributions 93*2c2f96dcSApple OSS Distributions boolean_t console_is_serial(void); 94*2c2f96dcSApple OSS Distributions int switch_to_serial_console(void); 95*2c2f96dcSApple OSS Distributions int switch_to_video_console(void); 96*2c2f96dcSApple OSS Distributions void switch_to_old_console(int old_console); 97*2c2f96dcSApple OSS Distributions 98*2c2f96dcSApple OSS Distributions #define SERIAL_CONS_OPS 0 99*2c2f96dcSApple OSS Distributions #define VC_CONS_OPS 1 100*2c2f96dcSApple OSS Distributions 101*2c2f96dcSApple OSS Distributions #ifdef XNU_KERNEL_PRIVATE 102*2c2f96dcSApple OSS Distributions 103*2c2f96dcSApple OSS Distributions #define SERIAL_CONS_BUF_SIZE 256 104*2c2f96dcSApple OSS Distributions struct console_printbuf_state { 105*2c2f96dcSApple OSS Distributions int pos; 106*2c2f96dcSApple OSS Distributions int total; 107*2c2f96dcSApple OSS Distributions int flags; 108*2c2f96dcSApple OSS Distributions #define CONS_PB_WRITE_NEWLINE 0x1 109*2c2f96dcSApple OSS Distributions #define CONS_PB_CANBLOCK 0x2 110*2c2f96dcSApple OSS Distributions char str[SERIAL_CONS_BUF_SIZE]; 111*2c2f96dcSApple OSS Distributions }; 112*2c2f96dcSApple OSS Distributions 113*2c2f96dcSApple OSS Distributions extern int console_printbuf_drain_initialized; 114*2c2f96dcSApple OSS Distributions void console_printbuf_state_init(struct console_printbuf_state * data, int write_on_newline, int can_block); 115*2c2f96dcSApple OSS Distributions void console_printbuf_putc(int ch, void *arg); 116*2c2f96dcSApple OSS Distributions void console_printbuf_clear(struct console_printbuf_state * info); 117*2c2f96dcSApple OSS Distributions int console_write_try(char * str, int size); 118*2c2f96dcSApple OSS Distributions 119*2c2f96dcSApple OSS Distributions 120*2c2f96dcSApple OSS Distributions #endif /* XNU_KERNEL_PRIVATE */ 121*2c2f96dcSApple OSS Distributions 122*2c2f96dcSApple OSS Distributions #ifdef __cplusplus 123*2c2f96dcSApple OSS Distributions } 124*2c2f96dcSApple OSS Distributions #endif 125*2c2f96dcSApple OSS Distributions 126*2c2f96dcSApple OSS Distributions 127*2c2f96dcSApple OSS Distributions #endif /* _CONSOLE_SERIAL_PROTOS_H_ */ 128