Home | History | Annotate | Line # | Download | only in libefi
      1  1.4  kiyohara /*	$NetBSD: efi_console.c,v 1.4 2009/07/20 04:59:03 kiyohara 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.4  kiyohara #include <lib/libsa/loadfile.h>
     36  1.1    cherry 
     37  1.1    cherry #include "bootstrap.h"
     38  1.1    cherry 
     39  1.1    cherry static SIMPLE_TEXT_OUTPUT_INTERFACE	*conout;
     40  1.1    cherry static SIMPLE_INPUT_INTERFACE		*conin;
     41  1.1    cherry 
     42  1.1    cherry static void
     43  1.1    cherry efi_cons_probe(struct console *cp)
     44  1.1    cherry {
     45  1.1    cherry 	conout = ST->ConOut;
     46  1.1    cherry 	conin = ST->ConIn;
     47  1.1    cherry 	cp->c_flags |= C_PRESENTIN | C_PRESENTOUT;
     48  1.1    cherry }
     49  1.1    cherry 
     50  1.1    cherry static int
     51  1.1    cherry efi_cons_init(int arg)
     52  1.1    cherry {
     53  1.1    cherry 	conout->SetAttribute(conout, EFI_TEXT_ATTR(EFI_LIGHTGRAY, EFI_BLACK));
     54  1.1    cherry 	return 0;
     55  1.1    cherry }
     56  1.1    cherry 
     57  1.1    cherry void
     58  1.1    cherry efi_cons_putchar(int c)
     59  1.1    cherry {
     60  1.1    cherry 	CHAR16 buf[2];
     61  1.1    cherry 
     62  1.1    cherry 	if (c == '\n')
     63  1.1    cherry 		efi_cons_putchar('\r');
     64  1.1    cherry 
     65  1.1    cherry 	buf[0] = c;
     66  1.1    cherry 	buf[1] = 0;
     67  1.1    cherry 
     68  1.1    cherry 	conout->OutputString(conout, buf);
     69  1.1    cherry }
     70  1.1    cherry 
     71  1.1    cherry int
     72  1.3    cegger efi_cons_getchar(void)
     73  1.1    cherry {
     74  1.1    cherry 	EFI_INPUT_KEY key;
     75  1.1    cherry 	EFI_STATUS status;
     76  1.1    cherry 	UINTN junk;
     77  1.1    cherry 
     78  1.1    cherry 	/* Try to read a key stroke. We wait for one if none is pending. */
     79  1.1    cherry 	status = conin->ReadKeyStroke(conin, &key);
     80  1.1    cherry 	if (status == EFI_NOT_READY) {
     81  1.1    cherry 		BS->WaitForEvent(1, &conin->WaitForKey, &junk);
     82  1.1    cherry 		status = conin->ReadKeyStroke(conin, &key);
     83  1.1    cherry 	}
     84  1.1    cherry 	return (key.UnicodeChar);
     85  1.1    cherry }
     86  1.1    cherry 
     87  1.1    cherry int
     88  1.3    cegger efi_cons_poll(void)
     89  1.1    cherry {
     90  1.1    cherry 	/* This can clear the signaled state. */
     91  1.1    cherry 	return (BS->CheckEvent(conin->WaitForKey) == EFI_SUCCESS);
     92  1.1    cherry }
     93  1.1    cherry 
     94  1.1    cherry struct console efi_console = {
     95  1.1    cherry 	"efi",
     96  1.1    cherry 	"EFI console",
     97  1.1    cherry 	0,
     98  1.1    cherry 	efi_cons_probe,
     99  1.1    cherry 	efi_cons_init,
    100  1.1    cherry 	efi_cons_putchar,
    101  1.1    cherry 	efi_cons_getchar,
    102  1.1    cherry 	efi_cons_poll
    103  1.1    cherry };
    104