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