2 Implementation for EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL protocol.
4 Copyright (c) 2006 - 2010, Intel Corporation. All rights reserved.<BR>
5 This program and the accompanying materials
6 are licensed and made available under the terms and conditions of the BSD License
7 which accompanies this distribution. The full text of the license may be found at
8 http://opensource.org/licenses/bsd-license.php
10 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
11 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
18 // This list is used to define the valid extend chars.
19 // It also provides a mapping from Unicode to PCANSI or
20 // ASCII. The ASCII mapping we just made up.
23 UNICODE_TO_CHAR UnicodeToPcAnsiOrAscii
[] = {
24 { BOXDRAW_HORIZONTAL
, 0xc4, L
'-' },
25 { BOXDRAW_VERTICAL
, 0xb3, L
'|' },
26 { BOXDRAW_DOWN_RIGHT
, 0xda, L
'/' },
27 { BOXDRAW_DOWN_LEFT
, 0xbf, L
'\\' },
28 { BOXDRAW_UP_RIGHT
, 0xc0, L
'\\' },
29 { BOXDRAW_UP_LEFT
, 0xd9, L
'/' },
30 { BOXDRAW_VERTICAL_RIGHT
, 0xc3, L
'|' },
31 { BOXDRAW_VERTICAL_LEFT
, 0xb4, L
'|' },
32 { BOXDRAW_DOWN_HORIZONTAL
, 0xc2, L
'+' },
33 { BOXDRAW_UP_HORIZONTAL
, 0xc1, L
'+' },
34 { BOXDRAW_VERTICAL_HORIZONTAL
, 0xc5, L
'+' },
35 { BOXDRAW_DOUBLE_HORIZONTAL
, 0xcd, L
'-' },
36 { BOXDRAW_DOUBLE_VERTICAL
, 0xba, L
'|' },
37 { BOXDRAW_DOWN_RIGHT_DOUBLE
, 0xd5, L
'/' },
38 { BOXDRAW_DOWN_DOUBLE_RIGHT
, 0xd6, L
'/' },
39 { BOXDRAW_DOUBLE_DOWN_RIGHT
, 0xc9, L
'/' },
40 { BOXDRAW_DOWN_LEFT_DOUBLE
, 0xb8, L
'\\' },
41 { BOXDRAW_DOWN_DOUBLE_LEFT
, 0xb7, L
'\\' },
42 { BOXDRAW_DOUBLE_DOWN_LEFT
, 0xbb, L
'\\' },
43 { BOXDRAW_UP_RIGHT_DOUBLE
, 0xd4, L
'\\' },
44 { BOXDRAW_UP_DOUBLE_RIGHT
, 0xd3, L
'\\' },
45 { BOXDRAW_DOUBLE_UP_RIGHT
, 0xc8, L
'\\' },
46 { BOXDRAW_UP_LEFT_DOUBLE
, 0xbe, L
'/' },
47 { BOXDRAW_UP_DOUBLE_LEFT
, 0xbd, L
'/' },
48 { BOXDRAW_DOUBLE_UP_LEFT
, 0xbc, L
'/' },
49 { BOXDRAW_VERTICAL_RIGHT_DOUBLE
, 0xc6, L
'|' },
50 { BOXDRAW_VERTICAL_DOUBLE_RIGHT
, 0xc7, L
'|' },
51 { BOXDRAW_DOUBLE_VERTICAL_RIGHT
, 0xcc, L
'|' },
52 { BOXDRAW_VERTICAL_LEFT_DOUBLE
, 0xb5, L
'|' },
53 { BOXDRAW_VERTICAL_DOUBLE_LEFT
, 0xb6, L
'|' },
54 { BOXDRAW_DOUBLE_VERTICAL_LEFT
, 0xb9, L
'|' },
55 { BOXDRAW_DOWN_HORIZONTAL_DOUBLE
, 0xd1, L
'+' },
56 { BOXDRAW_DOWN_DOUBLE_HORIZONTAL
, 0xd2, L
'+' },
57 { BOXDRAW_DOUBLE_DOWN_HORIZONTAL
, 0xcb, L
'+' },
58 { BOXDRAW_UP_HORIZONTAL_DOUBLE
, 0xcf, L
'+' },
59 { BOXDRAW_UP_DOUBLE_HORIZONTAL
, 0xd0, L
'+' },
60 { BOXDRAW_DOUBLE_UP_HORIZONTAL
, 0xca, L
'+' },
61 { BOXDRAW_VERTICAL_HORIZONTAL_DOUBLE
, 0xd8, L
'+' },
62 { BOXDRAW_VERTICAL_DOUBLE_HORIZONTAL
, 0xd7, L
'+' },
63 { BOXDRAW_DOUBLE_VERTICAL_HORIZONTAL
, 0xce, L
'+' },
65 { BLOCKELEMENT_FULL_BLOCK
, 0xdb, L
'*' },
66 { BLOCKELEMENT_LIGHT_SHADE
, 0xb0, L
'+' },
68 { GEOMETRICSHAPE_UP_TRIANGLE
, 0x1e, L
'^' },
69 { GEOMETRICSHAPE_RIGHT_TRIANGLE
, 0x10, L
'>' },
70 { GEOMETRICSHAPE_DOWN_TRIANGLE
, 0x1f, L
'v' },
71 { GEOMETRICSHAPE_LEFT_TRIANGLE
, 0x11, L
'<' },
73 { ARROW_LEFT
, 0x3c, L
'<' },
74 { ARROW_UP
, 0x18, L
'^' },
75 { ARROW_RIGHT
, 0x3e, L
'>' },
76 { ARROW_DOWN
, 0x19, L
'v' },
78 { 0x0000, 0x00, L
'\0' }
81 CHAR16 mSetModeString
[] = { ESC
, '[', '=', '3', 'h', 0 };
82 CHAR16 mSetAttributeString
[] = { ESC
, '[', '0', 'm', ESC
, '[', '4', '0', 'm', ESC
, '[', '4', '0', 'm', 0 };
83 CHAR16 mClearScreenString
[] = { ESC
, '[', '2', 'J', 0 };
84 CHAR16 mSetCursorPositionString
[] = { ESC
, '[', '0', '0', ';', '0', '0', 'H', 0 };
87 // Body of the ConOut functions
91 Implements EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL.Reset().
93 If ExtendeVerification is TRUE, then perform dependent serial device reset,
94 and set display mode to mode 0.
95 If ExtendedVerification is FALSE, only set display mode to mode 0.
97 @param This Indicates the calling context.
98 @param ExtendedVerification Indicates that the driver may perform a more
99 exhaustive verification operation of the device
102 @retval EFI_SUCCESS The reset operation succeeds.
103 @retval EFI_DEVICE_ERROR The terminal is not functioning correctly or the serial port reset fails.
108 TerminalConOutReset (
109 IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL
*This
,
110 IN BOOLEAN ExtendedVerification
114 TERMINAL_DEV
*TerminalDevice
;
116 TerminalDevice
= TERMINAL_CON_OUT_DEV_FROM_THIS (This
);
119 // Perform a more exhaustive reset by resetting the serial port.
121 if (ExtendedVerification
) {
123 // Report progress code here
125 REPORT_STATUS_CODE_WITH_DEVICE_PATH (
127 (EFI_PERIPHERAL_REMOTE_CONSOLE
| EFI_P_PC_RESET
),
128 TerminalDevice
->DevicePath
131 Status
= TerminalDevice
->SerialIo
->Reset (TerminalDevice
->SerialIo
);
132 if (EFI_ERROR (Status
)) {
134 // Report error code here
136 REPORT_STATUS_CODE_WITH_DEVICE_PATH (
137 EFI_ERROR_CODE
| EFI_ERROR_MINOR
,
138 (EFI_PERIPHERAL_REMOTE_CONSOLE
| EFI_P_EC_CONTROLLER_ERROR
),
139 TerminalDevice
->DevicePath
146 This
->SetAttribute (This
, EFI_TEXT_ATTR (This
->Mode
->Attribute
& 0x0F, EFI_BLACK
));
148 Status
= This
->SetMode (This
, 0);
155 Implements EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL.OutputString().
157 The Unicode string will be converted to terminal expressible data stream
158 and send to terminal via serial port.
160 @param This Indicates the calling context.
161 @param WString The Null-terminated Unicode string to be displayed
162 on the terminal screen.
164 @retval EFI_SUCCESS The string is output successfully.
165 @retval EFI_DEVICE_ERROR The serial port fails to send the string out.
166 @retval EFI_WARN_UNKNOWN_GLYPH Indicates that some of the characters in the Unicode string could not
167 be rendered and are skipped.
168 @retval EFI_UNSUPPORTED If current display mode is out of range.
173 TerminalConOutOutputString (
174 IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL
*This
,
178 TERMINAL_DEV
*TerminalDevice
;
179 EFI_SIMPLE_TEXT_OUTPUT_MODE
*Mode
;
189 // flag used to indicate whether condition happens which will cause
190 // return EFI_WARN_UNKNOWN_GLYPH
199 // get Terminal device data structure pointer.
201 TerminalDevice
= TERMINAL_CON_OUT_DEV_FROM_THIS (This
);
204 // Get current display mode
208 if (Mode
->Mode
>= Mode
->MaxMode
) {
209 return EFI_UNSUPPORTED
;
219 for (; *WString
!= CHAR_NULL
; WString
++) {
221 switch (TerminalDevice
->TerminalType
) {
228 if (!TerminalIsValidTextGraphics (*WString
, &GraphicChar
, &AsciiChar
)) {
230 // If it's not a graphic character convert Unicode to ASCII.
232 GraphicChar
= (CHAR8
) *WString
;
234 if (!(TerminalIsValidAscii (GraphicChar
) || TerminalIsValidEfiCntlChar (GraphicChar
))) {
236 // when this driver use the OutputString to output control string,
237 // TerminalDevice->OutputEscChar is set to let the Esc char
238 // to be output to the terminal emulation software.
240 if ((GraphicChar
== 27) && TerminalDevice
->OutputEscChar
) {
248 AsciiChar
= GraphicChar
;
252 if (TerminalDevice
->TerminalType
!= PCANSITYPE
) {
253 GraphicChar
= AsciiChar
;
258 Status
= TerminalDevice
->SerialIo
->Write (
259 TerminalDevice
->SerialIo
,
264 if (EFI_ERROR (Status
)) {
271 UnicodeToUtf8 (*WString
, &Utf8Char
, &ValidBytes
);
273 Status
= TerminalDevice
->SerialIo
->Write (
274 TerminalDevice
->SerialIo
,
278 if (EFI_ERROR (Status
)) {
284 // Update cursor position.
289 if (Mode
->CursorColumn
> 0) {
290 Mode
->CursorColumn
--;
295 if (Mode
->CursorRow
< (INT32
) (MaxRow
- 1)) {
300 case CHAR_CARRIAGE_RETURN
:
301 Mode
->CursorColumn
= 0;
305 if (Mode
->CursorColumn
< (INT32
) (MaxColumn
- 1)) {
307 Mode
->CursorColumn
++;
311 Mode
->CursorColumn
= 0;
312 if (Mode
->CursorRow
< (INT32
) (MaxRow
- 1)) {
324 return EFI_WARN_UNKNOWN_GLYPH
;
330 REPORT_STATUS_CODE_WITH_DEVICE_PATH (
331 EFI_ERROR_CODE
| EFI_ERROR_MINOR
,
332 (EFI_PERIPHERAL_REMOTE_CONSOLE
| EFI_P_EC_OUTPUT_ERROR
),
333 TerminalDevice
->DevicePath
336 return EFI_DEVICE_ERROR
;
341 Implements EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL.TestString().
343 If one of the characters in the *Wstring is
344 neither valid Unicode drawing characters,
345 not ASCII code, then this function will return
348 @param This Indicates the calling context.
349 @param WString The Null-terminated Unicode string to be tested.
351 @retval EFI_SUCCESS The terminal is capable of rendering the output string.
352 @retval EFI_UNSUPPORTED Some of the characters in the Unicode string cannot be rendered.
357 TerminalConOutTestString (
358 IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL
*This
,
362 TERMINAL_DEV
*TerminalDevice
;
366 // get Terminal device data structure pointer.
368 TerminalDevice
= TERMINAL_CON_OUT_DEV_FROM_THIS (This
);
370 switch (TerminalDevice
->TerminalType
) {
376 Status
= AnsiTestString (TerminalDevice
, WString
);
380 Status
= VTUTF8TestString (TerminalDevice
, WString
);
384 Status
= EFI_UNSUPPORTED
;
393 Implements EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL.QueryMode().
395 It returns information for an available text mode
396 that the terminal supports.
398 @param This Indicates the calling context.
399 @param ModeNumber The mode number to return information on.
400 @param Columns The returned columns of the requested mode.
401 @param Rows The returned rows of the requested mode.
403 @retval EFI_SUCCESS The requested mode information is returned.
404 @retval EFI_UNSUPPORTED The mode number is not valid.
409 TerminalConOutQueryMode (
410 IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL
*This
,
416 TERMINAL_DEV
*TerminalDevice
;
418 if (ModeNumber
>= (UINTN
) This
->Mode
->MaxMode
) {
419 return EFI_UNSUPPORTED
;
423 // Get Terminal device data structure pointer.
425 TerminalDevice
= TERMINAL_CON_OUT_DEV_FROM_THIS (This
);
426 *Columns
= TerminalDevice
->TerminalConsoleModeData
[ModeNumber
].Columns
;
427 *Rows
= TerminalDevice
->TerminalConsoleModeData
[ModeNumber
].Rows
;
434 Implements EFI_SIMPLE_TEXT_OUT.SetMode().
436 Set the terminal to a specified display mode.
437 In this driver, we only support mode 0.
439 @param This Indicates the calling context.
440 @param ModeNumber The text mode to set.
442 @retval EFI_SUCCESS The requested text mode is set.
443 @retval EFI_DEVICE_ERROR The requested text mode cannot be set
444 because of serial device error.
445 @retval EFI_UNSUPPORTED The text mode number is not valid.
450 TerminalConOutSetMode (
451 IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL
*This
,
456 TERMINAL_DEV
*TerminalDevice
;
459 // get Terminal device data structure pointer.
461 TerminalDevice
= TERMINAL_CON_OUT_DEV_FROM_THIS (This
);
463 if (ModeNumber
>= (UINTN
) This
->Mode
->MaxMode
) {
464 return EFI_UNSUPPORTED
;
468 // Set the current mode
470 This
->Mode
->Mode
= (INT32
) ModeNumber
;
472 This
->ClearScreen (This
);
474 TerminalDevice
->OutputEscChar
= TRUE
;
475 Status
= This
->OutputString (This
, mSetModeString
);
476 TerminalDevice
->OutputEscChar
= FALSE
;
478 if (EFI_ERROR (Status
)) {
479 return EFI_DEVICE_ERROR
;
482 This
->Mode
->Mode
= (INT32
) ModeNumber
;
484 Status
= This
->ClearScreen (This
);
485 if (EFI_ERROR (Status
)) {
486 return EFI_DEVICE_ERROR
;
495 Implements EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL.SetAttribute().
497 @param This Indicates the calling context.
498 @param Attribute The attribute to set. Only bit0..6 are valid, all other bits
499 are undefined and must be zero.
501 @retval EFI_SUCCESS The requested attribute is set.
502 @retval EFI_DEVICE_ERROR The requested attribute cannot be set due to serial port error.
503 @retval EFI_UNSUPPORTED The attribute requested is not defined by EFI spec.
508 TerminalConOutSetAttribute (
509 IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL
*This
,
513 UINT8 ForegroundControl
;
514 UINT8 BackgroundControl
;
519 TERMINAL_DEV
*TerminalDevice
;
525 // get Terminal device data structure pointer.
527 TerminalDevice
= TERMINAL_CON_OUT_DEV_FROM_THIS (This
);
530 // only the bit0..6 of the Attribute is valid
532 if ((Attribute
| 0x7f) != 0x7f) {
533 return EFI_UNSUPPORTED
;
537 // Skip outputting the command string for the same attribute
538 // It improves the terminal performance significantly
540 if (This
->Mode
->Attribute
== (INT32
) Attribute
) {
545 // convert Attribute value to terminal emulator
546 // understandable foreground color
548 switch (Attribute
& 0x07) {
551 ForegroundControl
= 30;
555 ForegroundControl
= 34;
559 ForegroundControl
= 32;
563 ForegroundControl
= 36;
567 ForegroundControl
= 31;
571 ForegroundControl
= 35;
575 ForegroundControl
= 33;
581 ForegroundControl
= 37;
586 // bit4 of the Attribute indicates bright control
587 // of terminal emulator.
589 BrightControl
= (UINT8
) ((Attribute
>> 3) & 1);
592 // convert Attribute value to terminal emulator
593 // understandable background color.
595 switch ((Attribute
>> 4) & 0x07) {
598 BackgroundControl
= 40;
602 BackgroundControl
= 44;
606 BackgroundControl
= 42;
610 BackgroundControl
= 46;
614 BackgroundControl
= 41;
618 BackgroundControl
= 45;
622 BackgroundControl
= 43;
628 BackgroundControl
= 47;
632 // terminal emulator's control sequence to set attributes
634 mSetAttributeString
[BRIGHT_CONTROL_OFFSET
] = (CHAR16
) ('0' + BrightControl
);
635 mSetAttributeString
[FOREGROUND_CONTROL_OFFSET
+ 0] = (CHAR16
) ('0' + (ForegroundControl
/ 10));
636 mSetAttributeString
[FOREGROUND_CONTROL_OFFSET
+ 1] = (CHAR16
) ('0' + (ForegroundControl
% 10));
637 mSetAttributeString
[BACKGROUND_CONTROL_OFFSET
+ 0] = (CHAR16
) ('0' + (BackgroundControl
/ 10));
638 mSetAttributeString
[BACKGROUND_CONTROL_OFFSET
+ 1] = (CHAR16
) ('0' + (BackgroundControl
% 10));
641 // save current column and row
642 // for future scrolling back use.
644 SavedColumn
= This
->Mode
->CursorColumn
;
645 SavedRow
= This
->Mode
->CursorRow
;
647 TerminalDevice
->OutputEscChar
= TRUE
;
648 Status
= This
->OutputString (This
, mSetAttributeString
);
649 TerminalDevice
->OutputEscChar
= FALSE
;
651 if (EFI_ERROR (Status
)) {
652 return EFI_DEVICE_ERROR
;
655 // scroll back to saved cursor position.
657 This
->Mode
->CursorColumn
= SavedColumn
;
658 This
->Mode
->CursorRow
= SavedRow
;
660 This
->Mode
->Attribute
= (INT32
) Attribute
;
668 Implements EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL.ClearScreen().
669 It clears the ANSI terminal's display to the
670 currently selected background color.
672 @param This Indicates the calling context.
674 @retval EFI_SUCCESS The operation completed successfully.
675 @retval EFI_DEVICE_ERROR The terminal screen cannot be cleared due to serial port error.
676 @retval EFI_UNSUPPORTED The terminal is not in a valid display mode.
681 TerminalConOutClearScreen (
682 IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL
*This
686 TERMINAL_DEV
*TerminalDevice
;
688 TerminalDevice
= TERMINAL_CON_OUT_DEV_FROM_THIS (This
);
691 // control sequence for clear screen request
693 TerminalDevice
->OutputEscChar
= TRUE
;
694 Status
= This
->OutputString (This
, mClearScreenString
);
695 TerminalDevice
->OutputEscChar
= FALSE
;
697 if (EFI_ERROR (Status
)) {
698 return EFI_DEVICE_ERROR
;
701 Status
= This
->SetCursorPosition (This
, 0, 0);
708 Implements EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL.SetCursorPosition().
710 @param This Indicates the calling context.
711 @param Column The row to set cursor to.
712 @param Row The column to set cursor to.
714 @retval EFI_SUCCESS The operation completed successfully.
715 @retval EFI_DEVICE_ERROR The request fails due to serial port error.
716 @retval EFI_UNSUPPORTED The terminal is not in a valid text mode, or the cursor position
717 is invalid for current mode.
722 TerminalConOutSetCursorPosition (
723 IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL
*This
,
728 EFI_SIMPLE_TEXT_OUTPUT_MODE
*Mode
;
732 TERMINAL_DEV
*TerminalDevice
;
734 TerminalDevice
= TERMINAL_CON_OUT_DEV_FROM_THIS (This
);
742 // get geometry of current mode
744 Status
= This
->QueryMode (
750 if (EFI_ERROR (Status
)) {
751 return EFI_UNSUPPORTED
;
754 if (Column
>= MaxColumn
|| Row
>= MaxRow
) {
755 return EFI_UNSUPPORTED
;
758 // control sequence to move the cursor
760 mSetCursorPositionString
[ROW_OFFSET
+ 0] = (CHAR16
) ('0' + ((Row
+ 1) / 10));
761 mSetCursorPositionString
[ROW_OFFSET
+ 1] = (CHAR16
) ('0' + ((Row
+ 1) % 10));
762 mSetCursorPositionString
[COLUMN_OFFSET
+ 0] = (CHAR16
) ('0' + ((Column
+ 1) / 10));
763 mSetCursorPositionString
[COLUMN_OFFSET
+ 1] = (CHAR16
) ('0' + ((Column
+ 1) % 10));
765 TerminalDevice
->OutputEscChar
= TRUE
;
766 Status
= This
->OutputString (This
, mSetCursorPositionString
);
767 TerminalDevice
->OutputEscChar
= FALSE
;
769 if (EFI_ERROR (Status
)) {
770 return EFI_DEVICE_ERROR
;
773 // update current cursor position
774 // in the Mode data structure.
776 Mode
->CursorColumn
= (INT32
) Column
;
777 Mode
->CursorRow
= (INT32
) Row
;
784 Implements SIMPLE_TEXT_OUTPUT.EnableCursor().
786 In this driver, the cursor cannot be hidden.
788 @param This Indicates the calling context.
789 @param Visible If TRUE, the cursor is set to be visible,
790 If FALSE, the cursor is set to be invisible.
792 @retval EFI_SUCCESS The request is valid.
793 @retval EFI_UNSUPPORTED The terminal does not support cursor hidden.
798 TerminalConOutEnableCursor (
799 IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL
*This
,
804 return EFI_UNSUPPORTED
;
812 Detects if a Unicode char is for Box Drawing text graphics.
814 @param Graphic Unicode char to test.
815 @param PcAnsi Optional pointer to return PCANSI equivalent of
817 @param Ascii Optional pointer to return ASCII equivalent of
820 @retval TRUE If Graphic is a supported Unicode Box Drawing character.
824 TerminalIsValidTextGraphics (
826 OUT CHAR8
*PcAnsi
, OPTIONAL
827 OUT CHAR8
*Ascii OPTIONAL
830 UNICODE_TO_CHAR
*Table
;
832 if ((((Graphic
& 0xff00) != 0x2500) && ((Graphic
& 0xff00) != 0x2100))) {
834 // Unicode drawing code charts are all in the 0x25xx range,
840 for (Table
= UnicodeToPcAnsiOrAscii
; Table
->Unicode
!= 0x0000; Table
++) {
841 if (Graphic
== Table
->Unicode
) {
842 if (PcAnsi
!= NULL
) {
843 *PcAnsi
= Table
->PcAnsi
;
847 *Ascii
= Table
->Ascii
;
858 Detects if a valid ASCII char.
860 @param Ascii An ASCII character.
862 @retval TRUE If it is a valid ASCII character.
863 @retval FALSE If it is not a valid ASCII character.
867 TerminalIsValidAscii (
872 // valid ascii code lies in the extent of 0x20 ~ 0x7f
874 if ((Ascii
>= 0x20) && (Ascii
<= 0x7f)) {
882 Detects if a valid EFI control character.
884 @param CharC An input EFI Control character.
886 @retval TRUE If it is a valid EFI control character.
887 @retval FALSE If it is not a valid EFI control character.
891 TerminalIsValidEfiCntlChar (
896 // only support four control characters.
898 if (CharC
== CHAR_NULL
||
899 CharC
== CHAR_BACKSPACE
||
900 CharC
== CHAR_LINEFEED
||
901 CharC
== CHAR_CARRIAGE_RETURN
||