Add CONSTRUCTOR to BaseDebugLibSerialPort to call SerialPortInitialize() in the SerialPortLib to make sure the serial port hardware is in the proper state for use.

git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@11183 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
mdkinney 2010-12-18 00:24:34 +00:00
parent b35a5f731c
commit ccc96db96e
2 changed files with 25 additions and 4 deletions

View File

@ -21,6 +21,7 @@
MODULE_TYPE = BASE
VERSION_STRING = 1.0
LIBRARY_CLASS = DebugLib
CONSTRUCTOR = BaseDebugLibSerialPortConstructor
#
# VALID_ARCHITECTURES = IA32 X64 IPF EBC

View File

@ -1,8 +1,13 @@
/** @file
Base Debug library instance base on Serial Port library.
It uses PrintLib to send debug messages to serial port device.
NOTE: If the Serial Port library enables hardware flow control, then a call
to DebugPrint() or DebugAssert() may hang if writes to the serial port are
being blocked. This may occur if a key(s) are pressed in a terminal emulator
used to monitor the DEBUG() and ASSERT() messages.
Copyright (c) 2006 - 2008, Intel Corporation. All rights reserved.<BR>
Copyright (c) 2006 - 2010, Intel Corporation. All rights reserved.<BR>
This program and the accompanying materials
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
@ -26,6 +31,21 @@
//
#define MAX_DEBUG_MESSAGE_LENGTH 0x100
/**
The constructor function initialize the Serial Port Library
@retval EFI_SUCCESS The constructor always returns RETURN_SUCCESS.
**/
RETURN_STATUS
EFIAPI
BaseDebugLibSerialPortConstructor (
VOID
)
{
return SerialPortInitialize ();
}
/**
Prints a debug message to the debug output device if the specified error level is enabled.
@ -60,7 +80,7 @@ DebugPrint (
//
// Check driver debug mask value and global mask
//
if ((ErrorLevel & PcdGet32(PcdDebugPrintErrorLevel)) == 0) {
if ((ErrorLevel & PcdGet32 (PcdDebugPrintErrorLevel)) == 0) {
return;
}
@ -74,7 +94,7 @@ DebugPrint (
//
// Send the print string to a Serial Port
//
SerialPortWrite ((UINT8 *) Buffer, AsciiStrLen(Buffer));
SerialPortWrite ((UINT8 *)Buffer, AsciiStrLen (Buffer));
}
@ -117,7 +137,7 @@ DebugAssert (
//
// Send the print string to the Console Output device
//
SerialPortWrite ((UINT8 *) Buffer, AsciiStrLen(Buffer));
SerialPortWrite ((UINT8 *)Buffer, AsciiStrLen (Buffer));
//
// Generate a Breakpoint, DeadLoop, or NOP based on PCD settings