2007-06-22 08:57:39 +02:00
|
|
|
/** @file
|
2008-12-16 08:01:01 +01:00
|
|
|
Mde UEFI library API implementation.
|
2007-06-22 08:57:39 +02:00
|
|
|
Print to StdErr or ConOut defined in EFI_SYSTEM_TABLE
|
|
|
|
|
2017-03-23 03:16:23 +01:00
|
|
|
Copyright (c) 2007 - 2017, Intel Corporation. All rights reserved.<BR>
|
2010-04-23 18:37:43 +02:00
|
|
|
This program and the accompanying materials
|
2007-06-22 08:57:39 +02:00
|
|
|
are licensed and made available under the terms and conditions of the BSD License
|
|
|
|
which accompanies this distribution. The full text of the license may be found at
|
2010-06-25 23:56:02 +02:00
|
|
|
http://opensource.org/licenses/bsd-license.php.
|
2007-06-22 08:57:39 +02:00
|
|
|
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
2007-06-30 01:22:13 +02:00
|
|
|
#include "UefiLibInternal.h"
|
2007-06-22 08:57:39 +02:00
|
|
|
|
2008-12-01 14:46:34 +01:00
|
|
|
GLOBAL_REMOVE_IF_UNREFERENCED EFI_GRAPHICS_OUTPUT_BLT_PIXEL mEfiColors[16] = {
|
2008-11-20 04:08:28 +01:00
|
|
|
{ 0x00, 0x00, 0x00, 0x00 },
|
|
|
|
{ 0x98, 0x00, 0x00, 0x00 },
|
|
|
|
{ 0x00, 0x98, 0x00, 0x00 },
|
|
|
|
{ 0x98, 0x98, 0x00, 0x00 },
|
|
|
|
{ 0x00, 0x00, 0x98, 0x00 },
|
|
|
|
{ 0x98, 0x00, 0x98, 0x00 },
|
|
|
|
{ 0x00, 0x98, 0x98, 0x00 },
|
|
|
|
{ 0x98, 0x98, 0x98, 0x00 },
|
|
|
|
{ 0x10, 0x10, 0x10, 0x00 },
|
|
|
|
{ 0xff, 0x10, 0x10, 0x00 },
|
|
|
|
{ 0x10, 0xff, 0x10, 0x00 },
|
|
|
|
{ 0xff, 0xff, 0x10, 0x00 },
|
|
|
|
{ 0x10, 0x10, 0xff, 0x00 },
|
|
|
|
{ 0xf0, 0x10, 0xff, 0x00 },
|
|
|
|
{ 0x10, 0xff, 0xff, 0x00 },
|
|
|
|
{ 0xff, 0xff, 0xff, 0x00 }
|
|
|
|
};
|
|
|
|
|
2007-06-22 08:57:39 +02:00
|
|
|
/**
|
|
|
|
Internal function which prints a formatted Unicode string to the console output device
|
|
|
|
specified by Console
|
|
|
|
|
|
|
|
This function prints a formatted Unicode string to the console output device
|
|
|
|
specified by Console and returns the number of Unicode characters that printed
|
|
|
|
to it. If the length of the formatted Unicode string is greater than PcdUefiLibMaxPrintBufferSize,
|
|
|
|
then only the first PcdUefiLibMaxPrintBufferSize characters are sent to Console.
|
2008-07-14 11:01:34 +02:00
|
|
|
If Format is NULL, then ASSERT().
|
|
|
|
If Format is not aligned on a 16-bit boundary, then ASSERT().
|
2007-06-22 08:57:39 +02:00
|
|
|
|
2010-06-30 02:13:25 +02:00
|
|
|
@param Format A Null-terminated Unicode format string.
|
2007-06-22 08:57:39 +02:00
|
|
|
@param Console The output console.
|
2010-06-30 02:13:25 +02:00
|
|
|
@param Marker A VA_LIST marker for the variable argument list.
|
2008-12-29 08:10:16 +01:00
|
|
|
|
2008-07-14 11:01:34 +02:00
|
|
|
@return The number of Unicode characters in the produced
|
2010-06-30 02:13:25 +02:00
|
|
|
output buffer, not including the Null-terminator.
|
2007-06-22 08:57:39 +02:00
|
|
|
**/
|
|
|
|
UINTN
|
|
|
|
InternalPrint (
|
|
|
|
IN CONST CHAR16 *Format,
|
|
|
|
IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL *Console,
|
|
|
|
IN VA_LIST Marker
|
|
|
|
)
|
|
|
|
{
|
2010-06-11 21:11:20 +02:00
|
|
|
EFI_STATUS Status;
|
|
|
|
UINTN Return;
|
|
|
|
CHAR16 *Buffer;
|
|
|
|
UINTN BufferSize;
|
2007-06-22 08:57:39 +02:00
|
|
|
|
|
|
|
ASSERT (Format != NULL);
|
2008-11-20 04:08:28 +01:00
|
|
|
ASSERT (((UINTN) Format & BIT0) == 0);
|
2010-06-11 21:11:20 +02:00
|
|
|
ASSERT (Console != NULL);
|
2007-06-22 08:57:39 +02:00
|
|
|
|
|
|
|
BufferSize = (PcdGet32 (PcdUefiLibMaxPrintBufferSize) + 1) * sizeof (CHAR16);
|
|
|
|
|
|
|
|
Buffer = (CHAR16 *) AllocatePool(BufferSize);
|
|
|
|
ASSERT (Buffer != NULL);
|
|
|
|
|
|
|
|
Return = UnicodeVSPrint (Buffer, BufferSize, Format, Marker);
|
|
|
|
|
2007-10-12 10:13:33 +02:00
|
|
|
if (Console != NULL && Return > 0) {
|
2007-06-22 08:57:39 +02:00
|
|
|
//
|
|
|
|
// To be extra safe make sure Console has been initialized
|
|
|
|
//
|
2010-06-11 21:11:20 +02:00
|
|
|
Status = Console->OutputString (Console, Buffer);
|
|
|
|
if (EFI_ERROR (Status)) {
|
|
|
|
Return = 0;
|
|
|
|
}
|
2007-06-22 08:57:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
FreePool (Buffer);
|
|
|
|
|
|
|
|
return Return;
|
|
|
|
}
|
|
|
|
|
2009-04-02 07:34:26 +02:00
|
|
|
/**
|
|
|
|
Prints a formatted Unicode string to the console output device specified by
|
2007-06-22 08:57:39 +02:00
|
|
|
ConOut defined in the EFI_SYSTEM_TABLE.
|
|
|
|
|
2009-04-02 07:34:26 +02:00
|
|
|
This function prints a formatted Unicode string to the console output device
|
|
|
|
specified by ConOut in EFI_SYSTEM_TABLE and returns the number of Unicode
|
|
|
|
characters that printed to ConOut. If the length of the formatted Unicode
|
|
|
|
string is greater than PcdUefiLibMaxPrintBufferSize, then only the first
|
2007-06-22 08:57:39 +02:00
|
|
|
PcdUefiLibMaxPrintBufferSize characters are sent to ConOut.
|
2008-07-14 11:01:34 +02:00
|
|
|
If Format is NULL, then ASSERT().
|
|
|
|
If Format is not aligned on a 16-bit boundary, then ASSERT().
|
2010-06-11 21:11:20 +02:00
|
|
|
If gST->ConOut is NULL, then ASSERT().
|
2007-06-22 08:57:39 +02:00
|
|
|
|
2010-06-30 02:13:25 +02:00
|
|
|
@param Format A Null-terminated Unicode format string.
|
|
|
|
@param ... A Variable argument list whose contents are accessed based
|
2008-11-19 04:29:46 +01:00
|
|
|
on the format string specified by Format.
|
2009-04-02 07:34:26 +02:00
|
|
|
|
2010-06-25 23:56:02 +02:00
|
|
|
@return The number of Unicode characters printed to ConOut.
|
2007-06-22 08:57:39 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
Print (
|
|
|
|
IN CONST CHAR16 *Format,
|
|
|
|
...
|
|
|
|
)
|
|
|
|
{
|
|
|
|
VA_LIST Marker;
|
|
|
|
UINTN Return;
|
|
|
|
|
|
|
|
VA_START (Marker, Format);
|
|
|
|
|
|
|
|
Return = InternalPrint (Format, gST->ConOut, Marker);
|
|
|
|
|
|
|
|
VA_END (Marker);
|
|
|
|
|
|
|
|
return Return;
|
|
|
|
}
|
|
|
|
|
2009-04-02 07:34:26 +02:00
|
|
|
/**
|
|
|
|
Prints a formatted Unicode string to the console output device specified by
|
2007-06-22 08:57:39 +02:00
|
|
|
StdErr defined in the EFI_SYSTEM_TABLE.
|
|
|
|
|
2009-04-02 07:34:26 +02:00
|
|
|
This function prints a formatted Unicode string to the console output device
|
|
|
|
specified by StdErr in EFI_SYSTEM_TABLE and returns the number of Unicode
|
|
|
|
characters that printed to StdErr. If the length of the formatted Unicode
|
|
|
|
string is greater than PcdUefiLibMaxPrintBufferSize, then only the first
|
2007-06-22 08:57:39 +02:00
|
|
|
PcdUefiLibMaxPrintBufferSize characters are sent to StdErr.
|
2008-07-14 11:01:34 +02:00
|
|
|
If Format is NULL, then ASSERT().
|
|
|
|
If Format is not aligned on a 16-bit boundary, then ASSERT().
|
2010-06-11 21:11:20 +02:00
|
|
|
If gST->StdErr is NULL, then ASSERT().
|
2007-06-22 08:57:39 +02:00
|
|
|
|
2010-06-30 02:13:25 +02:00
|
|
|
@param Format A Null-terminated Unicode format string.
|
2009-04-02 07:34:26 +02:00
|
|
|
@param ... Variable argument list whose contents are accessed based
|
2008-11-19 04:29:46 +01:00
|
|
|
on the format string specified by Format.
|
2009-04-02 07:34:26 +02:00
|
|
|
|
2010-06-25 23:56:02 +02:00
|
|
|
@return The number of Unicode characters printed to StdErr.
|
2007-06-22 08:57:39 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
ErrorPrint (
|
|
|
|
IN CONST CHAR16 *Format,
|
|
|
|
...
|
|
|
|
)
|
|
|
|
{
|
|
|
|
VA_LIST Marker;
|
|
|
|
UINTN Return;
|
|
|
|
|
|
|
|
VA_START (Marker, Format);
|
|
|
|
|
|
|
|
Return = InternalPrint( Format, gST->StdErr, Marker);
|
|
|
|
|
|
|
|
VA_END (Marker);
|
|
|
|
|
|
|
|
return Return;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
Internal function which prints a formatted ASCII string to the console output device
|
|
|
|
specified by Console
|
|
|
|
|
|
|
|
This function prints a formatted ASCII string to the console output device
|
|
|
|
specified by Console and returns the number of ASCII characters that printed
|
|
|
|
to it. If the length of the formatted ASCII string is greater than PcdUefiLibMaxPrintBufferSize,
|
|
|
|
then only the first PcdUefiLibMaxPrintBufferSize characters are sent to Console.
|
2008-07-14 11:01:34 +02:00
|
|
|
|
|
|
|
If Format is NULL, then ASSERT().
|
2007-06-22 08:57:39 +02:00
|
|
|
|
2010-06-30 02:13:25 +02:00
|
|
|
@param Format A Null-terminated ASCII format string.
|
2007-06-22 08:57:39 +02:00
|
|
|
@param Console The output console.
|
|
|
|
@param Marker VA_LIST marker for the variable argument list.
|
|
|
|
|
2008-07-14 11:01:34 +02:00
|
|
|
@return The number of Unicode characters in the produced
|
|
|
|
output buffer not including the Null-terminator.
|
2007-06-22 08:57:39 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
UINTN
|
|
|
|
AsciiInternalPrint (
|
|
|
|
IN CONST CHAR8 *Format,
|
|
|
|
IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL *Console,
|
|
|
|
IN VA_LIST Marker
|
|
|
|
)
|
|
|
|
{
|
2010-06-11 21:11:20 +02:00
|
|
|
EFI_STATUS Status;
|
|
|
|
UINTN Return;
|
|
|
|
CHAR16 *Buffer;
|
|
|
|
UINTN BufferSize;
|
2007-06-22 08:57:39 +02:00
|
|
|
|
|
|
|
ASSERT (Format != NULL);
|
2010-06-11 21:11:20 +02:00
|
|
|
ASSERT (Console != NULL);
|
2007-06-22 08:57:39 +02:00
|
|
|
|
|
|
|
BufferSize = (PcdGet32 (PcdUefiLibMaxPrintBufferSize) + 1) * sizeof (CHAR16);
|
|
|
|
|
|
|
|
Buffer = (CHAR16 *) AllocatePool(BufferSize);
|
|
|
|
ASSERT (Buffer != NULL);
|
|
|
|
|
|
|
|
Return = UnicodeVSPrintAsciiFormat (Buffer, BufferSize, Format, Marker);
|
|
|
|
|
|
|
|
if (Console != NULL) {
|
|
|
|
//
|
|
|
|
// To be extra safe make sure Console has been initialized
|
|
|
|
//
|
2010-06-11 21:11:20 +02:00
|
|
|
Status = Console->OutputString (Console, Buffer);
|
|
|
|
if (EFI_ERROR (Status)) {
|
|
|
|
Return = 0;
|
|
|
|
}
|
2007-06-22 08:57:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
FreePool (Buffer);
|
|
|
|
|
|
|
|
return Return;
|
|
|
|
}
|
|
|
|
|
2009-04-02 07:34:26 +02:00
|
|
|
/**
|
|
|
|
Prints a formatted ASCII string to the console output device specified by
|
2007-06-22 08:57:39 +02:00
|
|
|
ConOut defined in the EFI_SYSTEM_TABLE.
|
|
|
|
|
2009-04-02 07:34:26 +02:00
|
|
|
This function prints a formatted ASCII string to the console output device
|
|
|
|
specified by ConOut in EFI_SYSTEM_TABLE and returns the number of ASCII
|
|
|
|
characters that printed to ConOut. If the length of the formatted ASCII
|
|
|
|
string is greater than PcdUefiLibMaxPrintBufferSize, then only the first
|
2007-06-22 08:57:39 +02:00
|
|
|
PcdUefiLibMaxPrintBufferSize characters are sent to ConOut.
|
2008-07-14 11:01:34 +02:00
|
|
|
If Format is NULL, then ASSERT().
|
2010-06-11 21:11:20 +02:00
|
|
|
If gST->ConOut is NULL, then ASSERT().
|
2007-06-22 08:57:39 +02:00
|
|
|
|
2010-06-30 02:13:25 +02:00
|
|
|
@param Format A Null-terminated ASCII format string.
|
2009-04-02 07:34:26 +02:00
|
|
|
@param ... Variable argument list whose contents are accessed based
|
2008-11-19 04:29:46 +01:00
|
|
|
on the format string specified by Format.
|
2009-04-02 07:34:26 +02:00
|
|
|
|
2010-06-25 23:56:02 +02:00
|
|
|
@return The number of ASCII characters printed to ConOut.
|
2007-06-22 08:57:39 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
AsciiPrint (
|
|
|
|
IN CONST CHAR8 *Format,
|
|
|
|
...
|
|
|
|
)
|
|
|
|
{
|
|
|
|
VA_LIST Marker;
|
|
|
|
UINTN Return;
|
2008-09-16 04:12:35 +02:00
|
|
|
ASSERT (Format != NULL);
|
2008-12-29 08:10:16 +01:00
|
|
|
|
2007-06-22 08:57:39 +02:00
|
|
|
VA_START (Marker, Format);
|
|
|
|
|
|
|
|
Return = AsciiInternalPrint( Format, gST->ConOut, Marker);
|
|
|
|
|
|
|
|
VA_END (Marker);
|
|
|
|
|
|
|
|
return Return;
|
|
|
|
}
|
|
|
|
|
2009-04-02 07:34:26 +02:00
|
|
|
/**
|
|
|
|
Prints a formatted ASCII string to the console output device specified by
|
2007-06-22 08:57:39 +02:00
|
|
|
StdErr defined in the EFI_SYSTEM_TABLE.
|
|
|
|
|
2009-04-02 07:34:26 +02:00
|
|
|
This function prints a formatted ASCII string to the console output device
|
|
|
|
specified by StdErr in EFI_SYSTEM_TABLE and returns the number of ASCII
|
|
|
|
characters that printed to StdErr. If the length of the formatted ASCII
|
|
|
|
string is greater than PcdUefiLibMaxPrintBufferSize, then only the first
|
2007-06-22 08:57:39 +02:00
|
|
|
PcdUefiLibMaxPrintBufferSize characters are sent to StdErr.
|
2008-07-14 11:01:34 +02:00
|
|
|
If Format is NULL, then ASSERT().
|
2010-06-11 21:11:20 +02:00
|
|
|
If gST->StdErr is NULL, then ASSERT().
|
2007-06-22 08:57:39 +02:00
|
|
|
|
2010-06-30 02:13:25 +02:00
|
|
|
@param Format A Null-terminated ASCII format string.
|
2009-04-02 07:34:26 +02:00
|
|
|
@param ... Variable argument list whose contents are accessed based
|
2008-11-19 04:29:46 +01:00
|
|
|
on the format string specified by Format.
|
2009-04-02 07:34:26 +02:00
|
|
|
|
2010-06-25 23:56:02 +02:00
|
|
|
@return The number of ASCII characters printed to ConErr.
|
2007-06-22 08:57:39 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
AsciiErrorPrint (
|
|
|
|
IN CONST CHAR8 *Format,
|
|
|
|
...
|
|
|
|
)
|
|
|
|
{
|
|
|
|
VA_LIST Marker;
|
|
|
|
UINTN Return;
|
|
|
|
|
2008-09-16 04:12:35 +02:00
|
|
|
ASSERT (Format != NULL);
|
2008-12-29 08:10:16 +01:00
|
|
|
|
2007-06-22 08:57:39 +02:00
|
|
|
VA_START (Marker, Format);
|
|
|
|
|
|
|
|
Return = AsciiInternalPrint( Format, gST->StdErr, Marker);
|
|
|
|
|
|
|
|
VA_END (Marker);
|
|
|
|
|
|
|
|
return Return;
|
|
|
|
}
|
|
|
|
|
2008-11-20 04:08:28 +01:00
|
|
|
/**
|
2008-12-29 08:10:16 +01:00
|
|
|
Internal function to print a formatted Unicode string to a graphics console device specified by
|
2008-11-20 04:08:28 +01:00
|
|
|
ConsoleOutputHandle defined in the EFI_SYSTEM_TABLE at the given (X,Y) coordinates.
|
|
|
|
|
2008-12-29 08:10:16 +01:00
|
|
|
This function prints a formatted Unicode string to the graphics console device
|
|
|
|
specified by ConsoleOutputHandle in EFI_SYSTEM_TABLE and returns the number of
|
|
|
|
Unicode characters printed. The EFI_HII_FONT_PROTOCOL is used to convert the
|
|
|
|
string to a bitmap using the glyphs registered with the
|
2008-11-20 04:08:28 +01:00
|
|
|
HII database. No wrapping is performed, so any portions of the string the fall
|
|
|
|
outside the active display region will not be displayed.
|
|
|
|
|
2008-12-29 08:10:16 +01:00
|
|
|
If a graphics console device is not associated with the ConsoleOutputHandle
|
2008-11-20 04:08:28 +01:00
|
|
|
defined in the EFI_SYSTEM_TABLE then no string is printed, and 0 is returned.
|
2008-12-29 08:10:16 +01:00
|
|
|
If the EFI_HII_FONT_PROTOCOL is not present in the handle database, then no
|
2008-11-20 04:08:28 +01:00
|
|
|
string is printed, and 0 is returned.
|
|
|
|
|
2010-06-30 02:13:25 +02:00
|
|
|
@param PointX An X coordinate to print the string.
|
|
|
|
@param PointY A Y coordinate to print the string.
|
2009-04-15 16:31:45 +02:00
|
|
|
@param Foreground The foreground color of the string being printed. This is
|
2008-11-20 04:08:28 +01:00
|
|
|
an optional parameter that may be NULL. If it is NULL,
|
|
|
|
then the foreground color of the current ConOut device
|
|
|
|
in the EFI_SYSTEM_TABLE is used.
|
2009-01-08 09:28:31 +01:00
|
|
|
@param Background The background color of the string being printed. This is
|
2008-12-29 08:10:16 +01:00
|
|
|
an optional parameter that may be NULL. If it is NULL,
|
2008-11-20 04:08:28 +01:00
|
|
|
then the background color of the current ConOut device
|
|
|
|
in the EFI_SYSTEM_TABLE is used.
|
2010-06-30 02:13:25 +02:00
|
|
|
@param Buffer A Null-terminated Unicode formatted string.
|
2008-11-20 04:08:28 +01:00
|
|
|
@param PrintNum The number of Unicode formatted string to be printed.
|
|
|
|
|
2010-06-25 23:56:02 +02:00
|
|
|
@return The number of Unicode Characters printed. Zero means no any character
|
2008-11-20 04:08:28 +01:00
|
|
|
displayed successfully.
|
|
|
|
|
|
|
|
**/
|
|
|
|
UINTN
|
|
|
|
InternalPrintGraphic (
|
2009-04-15 16:31:45 +02:00
|
|
|
IN UINTN PointX,
|
|
|
|
IN UINTN PointY,
|
2008-11-20 04:08:28 +01:00
|
|
|
IN EFI_GRAPHICS_OUTPUT_BLT_PIXEL *Foreground,
|
|
|
|
IN EFI_GRAPHICS_OUTPUT_BLT_PIXEL *Background,
|
|
|
|
IN CHAR16 *Buffer,
|
|
|
|
IN UINTN PrintNum
|
|
|
|
)
|
|
|
|
{
|
|
|
|
EFI_STATUS Status;
|
|
|
|
UINT32 HorizontalResolution;
|
|
|
|
UINT32 VerticalResolution;
|
|
|
|
UINT32 ColorDepth;
|
|
|
|
UINT32 RefreshRate;
|
|
|
|
EFI_HII_FONT_PROTOCOL *HiiFont;
|
|
|
|
EFI_IMAGE_OUTPUT *Blt;
|
|
|
|
EFI_FONT_DISPLAY_INFO FontInfo;
|
|
|
|
EFI_HII_ROW_INFO *RowInfoArray;
|
|
|
|
UINTN RowInfoArraySize;
|
|
|
|
EFI_GRAPHICS_OUTPUT_PROTOCOL *GraphicsOutput;
|
|
|
|
EFI_UGA_DRAW_PROTOCOL *UgaDraw;
|
|
|
|
EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL *Sto;
|
|
|
|
EFI_HANDLE ConsoleHandle;
|
2009-06-04 15:50:14 +02:00
|
|
|
UINTN Width;
|
|
|
|
UINTN Height;
|
|
|
|
UINTN Delta;
|
2008-11-20 04:08:28 +01:00
|
|
|
|
|
|
|
HorizontalResolution = 0;
|
|
|
|
VerticalResolution = 0;
|
|
|
|
Blt = NULL;
|
2009-05-21 12:02:33 +02:00
|
|
|
RowInfoArray = NULL;
|
2008-11-20 04:08:28 +01:00
|
|
|
|
|
|
|
ConsoleHandle = gST->ConsoleOutHandle;
|
2010-06-11 21:11:20 +02:00
|
|
|
|
|
|
|
ASSERT( ConsoleHandle != NULL);
|
2008-11-20 04:08:28 +01:00
|
|
|
|
|
|
|
Status = gBS->HandleProtocol (
|
|
|
|
ConsoleHandle,
|
|
|
|
&gEfiGraphicsOutputProtocolGuid,
|
|
|
|
(VOID **) &GraphicsOutput
|
|
|
|
);
|
|
|
|
|
|
|
|
UgaDraw = NULL;
|
|
|
|
if (EFI_ERROR (Status) && FeaturePcdGet (PcdUgaConsumeSupport)) {
|
|
|
|
//
|
|
|
|
// If no GOP available, try to open UGA Draw protocol if supported.
|
|
|
|
//
|
|
|
|
GraphicsOutput = NULL;
|
|
|
|
|
|
|
|
Status = gBS->HandleProtocol (
|
|
|
|
ConsoleHandle,
|
|
|
|
&gEfiUgaDrawProtocolGuid,
|
|
|
|
(VOID **) &UgaDraw
|
|
|
|
);
|
|
|
|
}
|
|
|
|
if (EFI_ERROR (Status)) {
|
2009-05-21 12:02:33 +02:00
|
|
|
goto Error;
|
2008-11-20 04:08:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
Status = gBS->HandleProtocol (
|
|
|
|
ConsoleHandle,
|
|
|
|
&gEfiSimpleTextOutProtocolGuid,
|
|
|
|
(VOID **) &Sto
|
|
|
|
);
|
|
|
|
|
|
|
|
if (EFI_ERROR (Status)) {
|
2009-05-21 12:02:33 +02:00
|
|
|
goto Error;
|
2008-11-20 04:08:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (GraphicsOutput != NULL) {
|
|
|
|
HorizontalResolution = GraphicsOutput->Mode->Info->HorizontalResolution;
|
|
|
|
VerticalResolution = GraphicsOutput->Mode->Info->VerticalResolution;
|
2008-12-29 08:10:16 +01:00
|
|
|
} else if (UgaDraw != NULL && FeaturePcdGet (PcdUgaConsumeSupport)) {
|
2008-11-20 04:08:28 +01:00
|
|
|
UgaDraw->GetMode (UgaDraw, &HorizontalResolution, &VerticalResolution, &ColorDepth, &RefreshRate);
|
|
|
|
} else {
|
|
|
|
goto Error;
|
|
|
|
}
|
|
|
|
|
|
|
|
ASSERT ((HorizontalResolution != 0) && (VerticalResolution !=0));
|
|
|
|
|
|
|
|
Status = gBS->LocateProtocol (&gEfiHiiFontProtocolGuid, NULL, (VOID **) &HiiFont);
|
|
|
|
if (EFI_ERROR (Status)) {
|
|
|
|
goto Error;
|
|
|
|
}
|
|
|
|
|
|
|
|
Blt = (EFI_IMAGE_OUTPUT *) AllocateZeroPool (sizeof (EFI_IMAGE_OUTPUT));
|
|
|
|
ASSERT (Blt != NULL);
|
|
|
|
|
|
|
|
Blt->Width = (UINT16) (HorizontalResolution);
|
|
|
|
Blt->Height = (UINT16) (VerticalResolution);
|
|
|
|
|
|
|
|
ZeroMem (&FontInfo, sizeof (EFI_FONT_DISPLAY_INFO));
|
|
|
|
|
|
|
|
if (Foreground != NULL) {
|
|
|
|
CopyMem (&FontInfo.ForegroundColor, Foreground, sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL));
|
|
|
|
} else {
|
|
|
|
CopyMem (
|
|
|
|
&FontInfo.ForegroundColor,
|
|
|
|
&mEfiColors[Sto->Mode->Attribute & 0x0f],
|
|
|
|
sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
if (Background != NULL) {
|
|
|
|
CopyMem (&FontInfo.BackgroundColor, Background, sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL));
|
|
|
|
} else {
|
|
|
|
CopyMem (
|
|
|
|
&FontInfo.BackgroundColor,
|
|
|
|
&mEfiColors[Sto->Mode->Attribute >> 4],
|
|
|
|
sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (GraphicsOutput != NULL) {
|
|
|
|
Blt->Image.Screen = GraphicsOutput;
|
2008-12-29 08:10:16 +01:00
|
|
|
|
2008-11-20 04:08:28 +01:00
|
|
|
Status = HiiFont->StringToImage (
|
|
|
|
HiiFont,
|
2009-05-21 12:02:33 +02:00
|
|
|
EFI_HII_IGNORE_IF_NO_GLYPH | EFI_HII_OUT_FLAG_CLIP |
|
|
|
|
EFI_HII_OUT_FLAG_CLIP_CLEAN_X | EFI_HII_OUT_FLAG_CLIP_CLEAN_Y |
|
|
|
|
EFI_HII_IGNORE_LINE_BREAK | EFI_HII_DIRECT_TO_SCREEN,
|
2008-11-20 04:08:28 +01:00
|
|
|
Buffer,
|
|
|
|
&FontInfo,
|
|
|
|
&Blt,
|
2009-04-15 16:31:45 +02:00
|
|
|
PointX,
|
|
|
|
PointY,
|
2009-05-21 12:02:33 +02:00
|
|
|
&RowInfoArray,
|
|
|
|
&RowInfoArraySize,
|
2008-11-20 04:08:28 +01:00
|
|
|
NULL
|
|
|
|
);
|
2009-05-21 12:02:33 +02:00
|
|
|
if (EFI_ERROR (Status)) {
|
|
|
|
goto Error;
|
|
|
|
}
|
2008-11-20 04:08:28 +01:00
|
|
|
|
|
|
|
} else if (FeaturePcdGet (PcdUgaConsumeSupport)) {
|
|
|
|
ASSERT (UgaDraw!= NULL);
|
|
|
|
|
2017-03-23 03:16:23 +01:00
|
|
|
//
|
|
|
|
// Ensure Width * Height * sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL) doesn't overflow.
|
|
|
|
//
|
|
|
|
if (Blt->Width > DivU64x32 (MAX_UINTN, Blt->Height * sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL))) {
|
|
|
|
goto Error;
|
|
|
|
}
|
|
|
|
|
|
|
|
Blt->Image.Bitmap = AllocateZeroPool ((UINT32) Blt->Width * Blt->Height * sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL));
|
2008-11-20 04:08:28 +01:00
|
|
|
ASSERT (Blt->Image.Bitmap != NULL);
|
|
|
|
|
|
|
|
//
|
|
|
|
// StringToImage only support blt'ing image to device using GOP protocol. If GOP is not supported in this platform,
|
|
|
|
// we ask StringToImage to print the string to blt buffer, then blt to device using UgaDraw.
|
|
|
|
//
|
|
|
|
Status = HiiFont->StringToImage (
|
|
|
|
HiiFont,
|
2009-05-26 12:01:46 +02:00
|
|
|
EFI_HII_IGNORE_IF_NO_GLYPH | EFI_HII_OUT_FLAG_CLIP |
|
|
|
|
EFI_HII_OUT_FLAG_CLIP_CLEAN_X | EFI_HII_OUT_FLAG_CLIP_CLEAN_Y |
|
|
|
|
EFI_HII_IGNORE_LINE_BREAK,
|
2008-11-20 04:08:28 +01:00
|
|
|
Buffer,
|
|
|
|
&FontInfo,
|
|
|
|
&Blt,
|
2009-04-15 16:31:45 +02:00
|
|
|
PointX,
|
|
|
|
PointY,
|
2008-11-20 04:08:28 +01:00
|
|
|
&RowInfoArray,
|
|
|
|
&RowInfoArraySize,
|
|
|
|
NULL
|
|
|
|
);
|
|
|
|
|
|
|
|
if (!EFI_ERROR (Status)) {
|
|
|
|
ASSERT (RowInfoArray != NULL);
|
|
|
|
//
|
2009-05-26 12:04:43 +02:00
|
|
|
// Explicit Line break characters are ignored, so the updated parameter RowInfoArraySize by StringToImage will
|
2008-11-20 04:08:28 +01:00
|
|
|
// always be 1 or 0 (if there is no valid Unicode Char can be printed). ASSERT here to make sure.
|
|
|
|
//
|
|
|
|
ASSERT (RowInfoArraySize <= 1);
|
|
|
|
|
2009-06-04 15:50:14 +02:00
|
|
|
if (RowInfoArraySize != 0) {
|
|
|
|
Width = RowInfoArray[0].LineWidth;
|
|
|
|
Height = RowInfoArray[0].LineHeight;
|
|
|
|
Delta = Blt->Width * sizeof (EFI_GRAPHICS_OUTPUT_BLT_PIXEL);
|
|
|
|
} else {
|
|
|
|
Width = 0;
|
|
|
|
Height = 0;
|
|
|
|
Delta = 0;
|
|
|
|
}
|
2008-11-20 04:08:28 +01:00
|
|
|
Status = UgaDraw->Blt (
|
|
|
|
UgaDraw,
|
|
|
|
(EFI_UGA_PIXEL *) Blt->Image.Bitmap,
|
|
|
|
EfiUgaBltBufferToVideo,
|
2009-04-15 16:31:45 +02:00
|
|
|
PointX,
|
|
|
|
PointY,
|
|
|
|
PointX,
|
|
|
|
PointY,
|
2009-06-04 15:50:14 +02:00
|
|
|
Width,
|
|
|
|
Height,
|
|
|
|
Delta
|
2008-11-20 04:08:28 +01:00
|
|
|
);
|
2009-05-21 12:02:33 +02:00
|
|
|
} else {
|
|
|
|
goto Error;
|
2008-11-20 04:08:28 +01:00
|
|
|
}
|
|
|
|
FreePool (Blt->Image.Bitmap);
|
|
|
|
} else {
|
2009-05-21 12:02:33 +02:00
|
|
|
goto Error;
|
2008-11-20 04:08:28 +01:00
|
|
|
}
|
2009-05-21 12:02:33 +02:00
|
|
|
//
|
|
|
|
// Calculate the number of actual printed characters
|
|
|
|
//
|
2009-06-04 15:50:14 +02:00
|
|
|
if (RowInfoArraySize != 0) {
|
|
|
|
PrintNum = RowInfoArray[0].EndIndex - RowInfoArray[0].StartIndex + 1;
|
|
|
|
} else {
|
|
|
|
PrintNum = 0;
|
|
|
|
}
|
2008-11-20 04:08:28 +01:00
|
|
|
|
2009-05-21 12:02:33 +02:00
|
|
|
FreePool (RowInfoArray);
|
2008-11-20 04:08:28 +01:00
|
|
|
FreePool (Blt);
|
2009-05-21 12:02:33 +02:00
|
|
|
return PrintNum;
|
2008-11-20 04:08:28 +01:00
|
|
|
|
|
|
|
Error:
|
2009-05-21 12:02:33 +02:00
|
|
|
if (Blt != NULL) {
|
|
|
|
FreePool (Blt);
|
2008-11-20 04:08:28 +01:00
|
|
|
}
|
2009-05-21 12:02:33 +02:00
|
|
|
return 0;
|
2008-11-20 04:08:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2009-04-02 07:34:26 +02:00
|
|
|
Prints a formatted Unicode string to a graphics console device specified by
|
2008-11-20 04:08:28 +01:00
|
|
|
ConsoleOutputHandle defined in the EFI_SYSTEM_TABLE at the given (X,Y) coordinates.
|
|
|
|
|
2009-04-02 07:34:26 +02:00
|
|
|
This function prints a formatted Unicode string to the graphics console device
|
|
|
|
specified by ConsoleOutputHandle in EFI_SYSTEM_TABLE and returns the number of
|
2009-05-09 01:48:32 +02:00
|
|
|
Unicode characters displayed, not including partial characters that may be clipped
|
|
|
|
by the right edge of the display. If the length of the formatted Unicode string is
|
|
|
|
greater than PcdUefiLibMaxPrintBufferSize, then at most the first
|
2009-05-21 12:02:33 +02:00
|
|
|
PcdUefiLibMaxPrintBufferSize characters are printed.The EFI_HII_FONT_PROTOCOL
|
|
|
|
StringToImage() service is used to convert the string to a bitmap using the glyphs
|
|
|
|
registered with the HII database. No wrapping is performed, so any portions of the
|
|
|
|
string the fall outside the active display region will not be displayed. Please see
|
|
|
|
Section 27.2.6 of the UEFI Specification for a description of the supported string
|
|
|
|
format including the set of control codes supported by the StringToImage() service.
|
2008-11-20 04:08:28 +01:00
|
|
|
|
2009-04-02 07:34:26 +02:00
|
|
|
If a graphics console device is not associated with the ConsoleOutputHandle
|
2008-11-20 04:08:28 +01:00
|
|
|
defined in the EFI_SYSTEM_TABLE then no string is printed, and 0 is returned.
|
2009-04-02 07:34:26 +02:00
|
|
|
If the EFI_HII_FONT_PROTOCOL is not present in the handle database, then no
|
2008-11-20 04:08:28 +01:00
|
|
|
string is printed, and 0 is returned.
|
|
|
|
If Format is NULL, then ASSERT().
|
|
|
|
If Format is not aligned on a 16-bit boundary, then ASSERT().
|
2010-06-11 21:11:20 +02:00
|
|
|
If gST->ConsoleOutputHandle is NULL, then ASSERT().
|
2008-11-20 04:08:28 +01:00
|
|
|
|
2010-06-30 02:13:25 +02:00
|
|
|
@param PointX An X coordinate to print the string.
|
|
|
|
@param PointY A Y coordinate to print the string.
|
2009-04-02 07:34:26 +02:00
|
|
|
@param ForeGround The foreground color of the string being printed. This is
|
2008-11-20 04:08:28 +01:00
|
|
|
an optional parameter that may be NULL. If it is NULL,
|
|
|
|
then the foreground color of the current ConOut device
|
|
|
|
in the EFI_SYSTEM_TABLE is used.
|
|
|
|
@param BackGround The background color of the string being printed. This is
|
2009-04-02 07:34:26 +02:00
|
|
|
an optional parameter that may be NULL. If it is NULL,
|
2008-11-20 04:08:28 +01:00
|
|
|
then the background color of the current ConOut device
|
|
|
|
in the EFI_SYSTEM_TABLE is used.
|
2010-06-30 02:13:25 +02:00
|
|
|
@param Format A Null-terminated Unicode format string. See Print Library
|
2008-11-20 04:08:28 +01:00
|
|
|
for the supported format string syntax.
|
2010-06-30 02:13:25 +02:00
|
|
|
@param ... A Variable argument list whose contents are accessed based on
|
2009-04-02 07:34:26 +02:00
|
|
|
the format string specified by Format.
|
2008-11-20 04:08:28 +01:00
|
|
|
|
2008-11-25 08:38:54 +01:00
|
|
|
@return The number of Unicode characters printed.
|
2008-11-20 04:08:28 +01:00
|
|
|
|
|
|
|
**/
|
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
PrintXY (
|
2009-04-15 16:31:45 +02:00
|
|
|
IN UINTN PointX,
|
|
|
|
IN UINTN PointY,
|
2008-11-20 04:08:28 +01:00
|
|
|
IN EFI_GRAPHICS_OUTPUT_BLT_PIXEL *ForeGround, OPTIONAL
|
|
|
|
IN EFI_GRAPHICS_OUTPUT_BLT_PIXEL *BackGround, OPTIONAL
|
|
|
|
IN CONST CHAR16 *Format,
|
|
|
|
...
|
|
|
|
)
|
|
|
|
{
|
|
|
|
VA_LIST Marker;
|
|
|
|
CHAR16 *Buffer;
|
|
|
|
UINTN BufferSize;
|
|
|
|
UINTN PrintNum;
|
|
|
|
UINTN ReturnNum;
|
|
|
|
|
|
|
|
ASSERT (Format != NULL);
|
|
|
|
ASSERT (((UINTN) Format & BIT0) == 0);
|
|
|
|
|
|
|
|
VA_START (Marker, Format);
|
|
|
|
|
|
|
|
BufferSize = (PcdGet32 (PcdUefiLibMaxPrintBufferSize) + 1) * sizeof (CHAR16);
|
|
|
|
|
|
|
|
Buffer = (CHAR16 *) AllocatePool (BufferSize);
|
|
|
|
ASSERT (Buffer != NULL);
|
2008-12-29 08:10:16 +01:00
|
|
|
|
2008-11-20 04:08:28 +01:00
|
|
|
PrintNum = UnicodeVSPrint (Buffer, BufferSize, Format, Marker);
|
|
|
|
|
2012-02-01 07:06:08 +01:00
|
|
|
VA_END (Marker);
|
|
|
|
|
2009-04-15 16:31:45 +02:00
|
|
|
ReturnNum = InternalPrintGraphic (PointX, PointY, ForeGround, BackGround, Buffer, PrintNum);
|
2008-11-20 04:08:28 +01:00
|
|
|
|
|
|
|
FreePool (Buffer);
|
|
|
|
|
|
|
|
return ReturnNum;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2009-04-02 07:34:26 +02:00
|
|
|
Prints a formatted ASCII string to a graphics console device specified by
|
2008-11-20 04:08:28 +01:00
|
|
|
ConsoleOutputHandle defined in the EFI_SYSTEM_TABLE at the given (X,Y) coordinates.
|
|
|
|
|
2009-04-02 07:34:26 +02:00
|
|
|
This function prints a formatted ASCII string to the graphics console device
|
|
|
|
specified by ConsoleOutputHandle in EFI_SYSTEM_TABLE and returns the number of
|
2009-05-09 01:48:32 +02:00
|
|
|
ASCII characters displayed, not including partial characters that may be clipped
|
|
|
|
by the right edge of the display. If the length of the formatted ASCII string is
|
|
|
|
greater than PcdUefiLibMaxPrintBufferSize, then at most the first
|
2009-05-21 12:02:33 +02:00
|
|
|
PcdUefiLibMaxPrintBufferSize characters are printed.The EFI_HII_FONT_PROTOCOL
|
|
|
|
StringToImage() service is used to convert the string to a bitmap using the glyphs
|
|
|
|
registered with the HII database. No wrapping is performed, so any portions of the
|
|
|
|
string the fall outside the active display region will not be displayed. Please see
|
|
|
|
Section 27.2.6 of the UEFI Specification for a description of the supported string
|
|
|
|
format including the set of control codes supported by the StringToImage() service.
|
2008-11-20 04:08:28 +01:00
|
|
|
|
2009-04-02 07:34:26 +02:00
|
|
|
If a graphics console device is not associated with the ConsoleOutputHandle
|
2008-11-20 04:08:28 +01:00
|
|
|
defined in the EFI_SYSTEM_TABLE then no string is printed, and 0 is returned.
|
2009-04-02 07:34:26 +02:00
|
|
|
If the EFI_HII_FONT_PROTOCOL is not present in the handle database, then no
|
2008-11-20 04:08:28 +01:00
|
|
|
string is printed, and 0 is returned.
|
|
|
|
If Format is NULL, then ASSERT().
|
2010-06-11 21:11:20 +02:00
|
|
|
If gST->ConsoleOutputHandle is NULL, then ASSERT().
|
2008-11-20 04:08:28 +01:00
|
|
|
|
2010-06-30 02:13:25 +02:00
|
|
|
@param PointX An X coordinate to print the string.
|
|
|
|
@param PointY A Y coordinate to print the string.
|
2009-04-02 07:34:26 +02:00
|
|
|
@param ForeGround The foreground color of the string being printed. This is
|
2008-11-20 04:08:28 +01:00
|
|
|
an optional parameter that may be NULL. If it is NULL,
|
|
|
|
then the foreground color of the current ConOut device
|
|
|
|
in the EFI_SYSTEM_TABLE is used.
|
|
|
|
@param BackGround The background color of the string being printed. This is
|
2009-04-02 07:34:26 +02:00
|
|
|
an optional parameter that may be NULL. If it is NULL,
|
2008-11-20 04:08:28 +01:00
|
|
|
then the background color of the current ConOut device
|
|
|
|
in the EFI_SYSTEM_TABLE is used.
|
2010-06-30 02:13:25 +02:00
|
|
|
@param Format A Null-terminated ASCII format string. See Print Library
|
2008-11-20 04:08:28 +01:00
|
|
|
for the supported format string syntax.
|
2009-04-02 07:34:26 +02:00
|
|
|
@param ... Variable argument list whose contents are accessed based on
|
|
|
|
the format string specified by Format.
|
2008-11-20 04:08:28 +01:00
|
|
|
|
2008-11-25 08:38:54 +01:00
|
|
|
@return The number of ASCII characters printed.
|
2008-11-20 04:08:28 +01:00
|
|
|
|
|
|
|
**/
|
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
AsciiPrintXY (
|
2009-04-15 16:31:45 +02:00
|
|
|
IN UINTN PointX,
|
|
|
|
IN UINTN PointY,
|
2008-11-20 04:08:28 +01:00
|
|
|
IN EFI_GRAPHICS_OUTPUT_BLT_PIXEL *ForeGround, OPTIONAL
|
|
|
|
IN EFI_GRAPHICS_OUTPUT_BLT_PIXEL *BackGround, OPTIONAL
|
|
|
|
IN CONST CHAR8 *Format,
|
|
|
|
...
|
|
|
|
)
|
|
|
|
{
|
|
|
|
VA_LIST Marker;
|
|
|
|
CHAR16 *Buffer;
|
|
|
|
UINTN BufferSize;
|
|
|
|
UINTN PrintNum;
|
|
|
|
UINTN ReturnNum;
|
|
|
|
|
|
|
|
ASSERT (Format != NULL);
|
|
|
|
|
|
|
|
VA_START (Marker, Format);
|
|
|
|
|
|
|
|
BufferSize = (PcdGet32 (PcdUefiLibMaxPrintBufferSize) + 1) * sizeof (CHAR16);
|
|
|
|
|
|
|
|
Buffer = (CHAR16 *) AllocatePool (BufferSize);
|
|
|
|
ASSERT (Buffer != NULL);
|
2008-12-29 08:10:16 +01:00
|
|
|
|
2008-11-20 04:08:28 +01:00
|
|
|
PrintNum = UnicodeSPrintAsciiFormat (Buffer, BufferSize, Format, Marker);
|
|
|
|
|
2012-02-01 07:06:08 +01:00
|
|
|
VA_END (Marker);
|
|
|
|
|
2009-04-15 16:31:45 +02:00
|
|
|
ReturnNum = InternalPrintGraphic (PointX, PointY, ForeGround, BackGround, Buffer, PrintNum);
|
2008-11-20 04:08:28 +01:00
|
|
|
|
|
|
|
FreePool (Buffer);
|
2008-12-29 08:10:16 +01:00
|
|
|
|
2008-11-20 04:08:28 +01:00
|
|
|
return ReturnNum;
|
|
|
|
}
|
|
|
|
|
2011-08-03 01:33:06 +02:00
|
|
|
/**
|
|
|
|
Appends a formatted Unicode string to a Null-terminated Unicode string
|
|
|
|
|
|
|
|
This function appends a formatted Unicode string to the Null-terminated
|
|
|
|
Unicode string specified by String. String is optional and may be NULL.
|
|
|
|
Storage for the formatted Unicode string returned is allocated using
|
|
|
|
AllocatePool(). The pointer to the appended string is returned. The caller
|
|
|
|
is responsible for freeing the returned string.
|
|
|
|
|
|
|
|
If String is not NULL and not aligned on a 16-bit boundary, then ASSERT().
|
|
|
|
If FormatString is NULL, then ASSERT().
|
|
|
|
If FormatString is not aligned on a 16-bit boundary, then ASSERT().
|
|
|
|
|
|
|
|
@param[in] String A Null-terminated Unicode string.
|
|
|
|
@param[in] FormatString A Null-terminated Unicode format string.
|
|
|
|
@param[in] Marker VA_LIST marker for the variable argument list.
|
|
|
|
|
|
|
|
@retval NULL There was not enough available memory.
|
|
|
|
@return Null-terminated Unicode string is that is the formatted
|
|
|
|
string appended to String.
|
|
|
|
**/
|
|
|
|
CHAR16*
|
|
|
|
EFIAPI
|
|
|
|
CatVSPrint (
|
|
|
|
IN CHAR16 *String, OPTIONAL
|
|
|
|
IN CONST CHAR16 *FormatString,
|
|
|
|
IN VA_LIST Marker
|
|
|
|
)
|
|
|
|
{
|
|
|
|
UINTN CharactersRequired;
|
|
|
|
UINTN SizeRequired;
|
|
|
|
CHAR16 *BufferToReturn;
|
2012-02-22 03:39:57 +01:00
|
|
|
VA_LIST ExtraMarker;
|
2011-08-03 01:33:06 +02:00
|
|
|
|
2012-02-22 03:39:57 +01:00
|
|
|
VA_COPY (ExtraMarker, Marker);
|
|
|
|
CharactersRequired = SPrintLength(FormatString, ExtraMarker);
|
|
|
|
VA_END (ExtraMarker);
|
2011-08-03 01:33:06 +02:00
|
|
|
|
|
|
|
if (String != NULL) {
|
|
|
|
SizeRequired = StrSize(String) + (CharactersRequired * sizeof(CHAR16));
|
|
|
|
} else {
|
|
|
|
SizeRequired = sizeof(CHAR16) + (CharactersRequired * sizeof(CHAR16));
|
|
|
|
}
|
|
|
|
|
2015-08-05 04:55:40 +02:00
|
|
|
BufferToReturn = AllocatePool(SizeRequired);
|
2011-08-03 01:33:06 +02:00
|
|
|
|
|
|
|
if (BufferToReturn == NULL) {
|
|
|
|
return NULL;
|
2015-08-05 04:55:40 +02:00
|
|
|
} else {
|
|
|
|
BufferToReturn[0] = L'\0';
|
2011-08-03 01:33:06 +02:00
|
|
|
}
|
2015-08-05 04:55:40 +02:00
|
|
|
|
2015-07-06 08:34:47 +02:00
|
|
|
if (String != NULL) {
|
2015-08-05 04:55:40 +02:00
|
|
|
StrCpyS(BufferToReturn, SizeRequired / sizeof(CHAR16), String);
|
2015-07-06 08:34:47 +02:00
|
|
|
}
|
2011-08-03 01:33:06 +02:00
|
|
|
|
|
|
|
UnicodeVSPrint(BufferToReturn + StrLen(BufferToReturn), (CharactersRequired+1) * sizeof(CHAR16), FormatString, Marker);
|
|
|
|
|
|
|
|
ASSERT(StrSize(BufferToReturn)==SizeRequired);
|
|
|
|
|
|
|
|
return (BufferToReturn);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Appends a formatted Unicode string to a Null-terminated Unicode string
|
|
|
|
|
|
|
|
This function appends a formatted Unicode string to the Null-terminated
|
|
|
|
Unicode string specified by String. String is optional and may be NULL.
|
|
|
|
Storage for the formatted Unicode string returned is allocated using
|
|
|
|
AllocatePool(). The pointer to the appended string is returned. The caller
|
|
|
|
is responsible for freeing the returned string.
|
|
|
|
|
|
|
|
If String is not NULL and not aligned on a 16-bit boundary, then ASSERT().
|
|
|
|
If FormatString is NULL, then ASSERT().
|
|
|
|
If FormatString is not aligned on a 16-bit boundary, then ASSERT().
|
|
|
|
|
|
|
|
@param[in] String A Null-terminated Unicode string.
|
|
|
|
@param[in] FormatString A Null-terminated Unicode format string.
|
|
|
|
@param[in] ... The variable argument list whose contents are
|
|
|
|
accessed based on the format string specified by
|
|
|
|
FormatString.
|
|
|
|
|
|
|
|
@retval NULL There was not enough available memory.
|
|
|
|
@return Null-terminated Unicode string is that is the formatted
|
|
|
|
string appended to String.
|
|
|
|
**/
|
|
|
|
CHAR16 *
|
|
|
|
EFIAPI
|
|
|
|
CatSPrint (
|
|
|
|
IN CHAR16 *String, OPTIONAL
|
|
|
|
IN CONST CHAR16 *FormatString,
|
|
|
|
...
|
|
|
|
)
|
|
|
|
{
|
|
|
|
VA_LIST Marker;
|
2012-02-01 07:06:08 +01:00
|
|
|
CHAR16 *NewString;
|
|
|
|
|
2011-08-03 01:33:06 +02:00
|
|
|
VA_START (Marker, FormatString);
|
2012-02-01 07:06:08 +01:00
|
|
|
NewString = CatVSPrint(String, FormatString, Marker);
|
|
|
|
VA_END (Marker);
|
|
|
|
return NewString;
|
2011-08-03 01:33:06 +02:00
|
|
|
}
|
|
|
|
|