diff --git a/stand/libofw/ofw_console.c b/stand/libofw/ofw_console.c index 75f9bfba0968..6925641eb606 100644 --- a/stand/libofw/ofw_console.c +++ b/stand/libofw/ofw_console.c @@ -1,120 +1,120 @@ /* $NetBSD: prom.c,v 1.3 1997/09/06 14:03:58 drochner Exp $ */ /*- * Mach Operating System * Copyright (c) 1992 Carnegie Mellon University * All Rights Reserved. * * Permission to use, copy, modify and distribute this software and its * documentation is hereby granted, provided that both the copyright * notice and this permission notice appear in all copies of the * software, derivative works or modified versions, and any portions * thereof, and that both notices appear in supporting documentation. * * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. * * Carnegie Mellon requests users of this software to return to * * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU * School of Computer Science * Carnegie Mellon University * Pittsburgh PA 15213-3890 * * any improvements or extensions that they make and grant Carnegie Mellon * the rights to redistribute these changes. */ #include #include "bootstrap.h" #include "openfirm.h" static void ofw_cons_probe(struct console *cp); static int ofw_cons_init(int); void ofw_cons_putchar(int); int ofw_cons_getchar(void); int ofw_cons_poll(void); static ihandle_t stdin; static ihandle_t stdout; struct console ofwconsole = { - .c_cname = "ofw", + .c_name = "ofw", .c_desc = "Open Firmware console", .c_probe = ofw_cons_probe, .c_init = ofw_cons_init, .c_out = ofw_cons_putchar, .c_in = ofw_cons_getchar, .c_ready = ofw_cons_poll, }; static void ofw_cons_probe(struct console *cp) { OF_getprop(chosen, "stdin", &stdin, sizeof(stdin)); OF_getprop(chosen, "stdout", &stdout, sizeof(stdout)); cp->c_flags |= C_PRESENTIN|C_PRESENTOUT; } static int ofw_cons_init(int arg) { return (0); } void ofw_cons_putchar(int c) { char cbuf; if (c == '\n') { cbuf = '\r'; OF_write(stdout, &cbuf, 1); } cbuf = c; OF_write(stdout, &cbuf, 1); } static int saved_char = -1; int ofw_cons_getchar(void) { unsigned char ch = '\0'; int l; if (saved_char != -1) { l = saved_char; saved_char = -1; return (l); } /* At least since version 4.0.0, QEMU became bug-compatible * with PowerVM's vty, by inserting a \0 after every \r. * As this confuses loader's interpreter and as a \0 coming * from the console doesn't seem reasonable, it's filtered here. */ if (OF_read(stdin, &ch, 1) > 0 && ch != '\0') return (ch); return (-1); } int ofw_cons_poll(void) { unsigned char ch; if (saved_char != -1) return (1); if (OF_read(stdin, &ch, 1) > 0) { saved_char = ch; return (1); } return (0); } diff --git a/stand/uboot/uboot_console.c b/stand/uboot/uboot_console.c index c02ba9aba5f0..b850a88c4018 100644 --- a/stand/uboot/uboot_console.c +++ b/stand/uboot/uboot_console.c @@ -1,85 +1,85 @@ /*- * Copyright (c) 2007 Semihalf, Rafal Jaworowski * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. */ #include #include "bootstrap.h" #include "glue.h" int console; static void uboot_cons_probe(struct console *cp); static int uboot_cons_init(int); static void uboot_cons_putchar(int); static int uboot_cons_getchar(void); static int uboot_cons_poll(void); struct console uboot_console = { .c_name = "uboot", .c_desc = "U-Boot console", .c_probe = uboot_cons_probe, .c_init = uboot_cons_init, .c_out = uboot_cons_putchar, - .c_int = uboot_cons_getchar, + .c_in = uboot_cons_getchar, .c_ready = uboot_cons_poll, }; static void uboot_cons_probe(struct console *cp) { cp->c_flags |= (C_PRESENTIN | C_PRESENTOUT); } static int uboot_cons_init(int arg) { return (0); } static void uboot_cons_putchar(int c) { if (c == '\n') ub_putc('\r'); ub_putc(c); } static int uboot_cons_getchar(void) { return (ub_getc()); } static int uboot_cons_poll(void) { return (ub_tstc()); }