Home | History | Annotate | Line # | Download | only in libefi
efi_console.c revision 1.3
      1  1.3  cegger /*	$NetBSD: efi_console.c,v 1.3 2009/03/18 10:22:31 cegger Exp $	*/
      2  1.1  cherry 
      3  1.1  cherry /*-
      4  1.1  cherry  * Copyright (c) 2000 Doug Rabson
      5  1.1  cherry  * All rights reserved.
      6  1.1  cherry  *
      7  1.1  cherry  * Redistribution and use in source and binary forms, with or without
      8  1.1  cherry  * modification, are permitted provided that the following conditions
      9  1.1  cherry  * are met:
     10  1.1  cherry  * 1. Redistributions of source code must retain the above copyright
     11  1.1  cherry  *    notice, this list of conditions and the following disclaimer.
     12  1.1  cherry  * 2. Redistributions in binary form must reproduce the above copyright
     13  1.1  cherry  *    notice, this list of conditions and the following disclaimer in the
     14  1.1  cherry  *    documentation and/or other materials provided with the distribution.
     15  1.1  cherry  *
     16  1.1  cherry  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
     17  1.1  cherry  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     18  1.1  cherry  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     19  1.1  cherry  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
     20  1.1  cherry  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     21  1.1  cherry  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     22  1.1  cherry  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     23  1.1  cherry  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     24  1.1  cherry  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     25  1.1  cherry  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     26  1.1  cherry  * SUCH DAMAGE.
     27  1.1  cherry  */
     28  1.1  cherry 
     29  1.1  cherry #include <sys/cdefs.h>
     30  1.2  cherry /* __FBSDID("$FreeBSD: src/sys/boot/efi/libefi/efi_console.c,v 1.5 2004/03/09 04:00:33 marcel Exp $"); */
     31  1.1  cherry 
     32  1.1  cherry #include <efi.h>
     33  1.1  cherry #include <efilib.h>
     34  1.1  cherry #include <lib/libsa/stand.h>
     35  1.1  cherry 
     36  1.1  cherry #include "bootstrap.h"
     37  1.1  cherry 
     38  1.1  cherry static SIMPLE_TEXT_OUTPUT_INTERFACE	*conout;
     39  1.1  cherry static SIMPLE_INPUT_INTERFACE		*conin;
     40  1.1  cherry 
     41  1.1  cherry static void
     42  1.1  cherry efi_cons_probe(struct console *cp)
     43  1.1  cherry {
     44  1.1  cherry 	conout = ST->ConOut;
     45  1.1  cherry 	conin = ST->ConIn;
     46  1.1  cherry 	cp->c_flags |= C_PRESENTIN | C_PRESENTOUT;
     47  1.1  cherry }
     48  1.1  cherry 
     49  1.1  cherry static int
     50  1.1  cherry efi_cons_init(int arg)
     51  1.1  cherry {
     52  1.1  cherry 	conout->SetAttribute(conout, EFI_TEXT_ATTR(EFI_LIGHTGRAY, EFI_BLACK));
     53  1.1  cherry 	return 0;
     54  1.1  cherry }
     55  1.1  cherry 
     56  1.1  cherry void
     57  1.1  cherry efi_cons_putchar(int c)
     58  1.1  cherry {
     59  1.1  cherry 	CHAR16 buf[2];
     60  1.1  cherry 
     61  1.1  cherry 	if (c == '\n')
     62  1.1  cherry 		efi_cons_putchar('\r');
     63  1.1  cherry 
     64  1.1  cherry 	buf[0] = c;
     65  1.1  cherry 	buf[1] = 0;
     66  1.1  cherry 
     67  1.1  cherry 	conout->OutputString(conout, buf);
     68  1.1  cherry }
     69  1.1  cherry 
     70  1.1  cherry int
     71  1.3  cegger efi_cons_getchar(void)
     72  1.1  cherry {
     73  1.1  cherry 	EFI_INPUT_KEY key;
     74  1.1  cherry 	EFI_STATUS status;
     75  1.1  cherry 	UINTN junk;
     76  1.1  cherry 
     77  1.1  cherry 	/* Try to read a key stroke. We wait for one if none is pending. */
     78  1.1  cherry 	status = conin->ReadKeyStroke(conin, &key);
     79  1.1  cherry 	if (status == EFI_NOT_READY) {
     80  1.1  cherry 		BS->WaitForEvent(1, &conin->WaitForKey, &junk);
     81  1.1  cherry 		status = conin->ReadKeyStroke(conin, &key);
     82  1.1  cherry 	}
     83  1.1  cherry 	return (key.UnicodeChar);
     84  1.1  cherry }
     85  1.1  cherry 
     86  1.1  cherry int
     87  1.3  cegger efi_cons_poll(void)
     88  1.1  cherry {
     89  1.1  cherry 	/* This can clear the signaled state. */
     90  1.1  cherry 	return (BS->CheckEvent(conin->WaitForKey) == EFI_SUCCESS);
     91  1.1  cherry }
     92  1.1  cherry 
     93  1.1  cherry struct console efi_console = {
     94  1.1  cherry 	"efi",
     95  1.1  cherry 	"EFI console",
     96  1.1  cherry 	0,
     97  1.1  cherry 	efi_cons_probe,
     98  1.1  cherry 	efi_cons_init,
     99  1.1  cherry 	efi_cons_putchar,
    100  1.1  cherry 	efi_cons_getchar,
    101  1.1  cherry 	efi_cons_poll
    102  1.1  cherry };
    103