2008-04-18 05:09:54 +02:00
|
|
|
/*++
|
|
|
|
|
2010-10-20 11:38:35 +02:00
|
|
|
Copyright (c) 2006 - 2010, Intel Corporation. All rights reserved.<BR>
|
2010-04-28 14:39:50 +02:00
|
|
|
This program and the accompanying materials
|
2008-04-18 05:09:54 +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
|
|
|
|
http://opensource.org/licenses/bsd-license.php
|
|
|
|
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
|
|
|
|
Module Name:
|
|
|
|
Debug.c
|
|
|
|
|
|
|
|
Abstract:
|
|
|
|
|
|
|
|
Revision History:
|
|
|
|
|
|
|
|
--*/
|
|
|
|
#include "EfiLdr.h"
|
|
|
|
#include "Debug.h"
|
2010-10-16 20:51:09 +02:00
|
|
|
#include <Library/SerialPortLib.h>
|
2008-04-18 05:09:54 +02:00
|
|
|
|
|
|
|
UINT8 *mCursor;
|
|
|
|
UINT8 mHeaderIndex = 10;
|
|
|
|
|
|
|
|
VOID
|
|
|
|
PrintHeader (
|
|
|
|
CHAR8 Char
|
|
|
|
)
|
|
|
|
{
|
|
|
|
*(UINT8 *)(UINTN)(0x000b8000 + mHeaderIndex) = Char;
|
|
|
|
mHeaderIndex += 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
VOID
|
|
|
|
ClearScreen (
|
|
|
|
VOID
|
|
|
|
)
|
|
|
|
{
|
|
|
|
UINT32 Index;
|
|
|
|
|
|
|
|
mCursor = (UINT8 *)(UINTN)(0x000b8000 + 160);
|
|
|
|
for (Index = 0; Index < 80 * 49; Index++) {
|
|
|
|
*mCursor = ' ';
|
|
|
|
mCursor += 2;
|
|
|
|
}
|
|
|
|
mCursor = (UINT8 *)(UINTN)(0x000b8000 + 160);
|
|
|
|
}
|
|
|
|
|
2010-10-16 20:51:09 +02:00
|
|
|
|
|
|
|
VOID
|
|
|
|
PrintU32Base10 (
|
|
|
|
UINT32 Value
|
2008-04-18 05:09:54 +02:00
|
|
|
)
|
|
|
|
{
|
2010-10-16 20:51:09 +02:00
|
|
|
UINT32 Index;
|
|
|
|
CHAR8 Char;
|
|
|
|
CHAR8 String[11];
|
|
|
|
UINTN StringPos;
|
|
|
|
UINT32 B10Div;
|
|
|
|
|
|
|
|
B10Div = 1000000000;
|
|
|
|
for (Index = 0, StringPos = 0; Index < 10; Index++) {
|
2010-10-20 11:38:35 +02:00
|
|
|
Char = (UINT8) (((Value / B10Div) % 10) + '0');
|
2010-10-16 20:51:09 +02:00
|
|
|
if ((StringPos > 0) || (Char != '0')) {
|
|
|
|
String[StringPos] = Char;
|
|
|
|
StringPos++;
|
|
|
|
}
|
|
|
|
B10Div = B10Div / 10;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (StringPos == 0) {
|
|
|
|
String[0] = '0';
|
|
|
|
StringPos++;
|
|
|
|
}
|
|
|
|
|
|
|
|
String[StringPos] = '\0';
|
|
|
|
|
|
|
|
PrintString (String);
|
2008-04-18 05:09:54 +02:00
|
|
|
}
|
|
|
|
|
2010-10-16 20:51:09 +02:00
|
|
|
|
2008-04-18 05:09:54 +02:00
|
|
|
VOID
|
|
|
|
PrintValue (
|
|
|
|
UINT32 Value
|
|
|
|
)
|
|
|
|
{
|
|
|
|
UINT32 Index;
|
2010-10-16 20:51:09 +02:00
|
|
|
CHAR8 Char;
|
|
|
|
CHAR8 String[9];
|
2008-04-18 05:09:54 +02:00
|
|
|
|
|
|
|
for (Index = 0; Index < 8; Index++) {
|
2008-11-26 18:59:34 +01:00
|
|
|
Char = (UINT8)(((Value >> ((7 - Index) * 4)) & 0x0f) + '0');
|
2008-04-18 05:09:54 +02:00
|
|
|
if (Char > '9') {
|
2008-11-26 18:59:34 +01:00
|
|
|
Char = (UINT8) (Char - '0' - 10 + 'A');
|
2008-04-18 05:09:54 +02:00
|
|
|
}
|
2010-10-16 20:51:09 +02:00
|
|
|
String[Index] = Char;
|
2008-04-18 05:09:54 +02:00
|
|
|
}
|
2010-10-16 20:51:09 +02:00
|
|
|
|
|
|
|
String[sizeof (String) - 1] = '\0';
|
|
|
|
|
|
|
|
PrintString (String);
|
|
|
|
}
|
|
|
|
|
|
|
|
VOID
|
|
|
|
PrintValue64 (
|
|
|
|
UINT64 Value
|
|
|
|
)
|
|
|
|
{
|
|
|
|
PrintValue ((UINT32) RShiftU64 (Value, 32));
|
|
|
|
PrintValue ((UINT32) Value);
|
2008-04-18 05:09:54 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
VOID
|
|
|
|
PrintString (
|
2008-11-26 18:59:34 +01:00
|
|
|
CHAR8 *String
|
2008-04-18 05:09:54 +02:00
|
|
|
)
|
|
|
|
{
|
|
|
|
UINT32 Index;
|
|
|
|
|
|
|
|
for (Index = 0; String[Index] != 0; Index++) {
|
|
|
|
if (String[Index] == '\n') {
|
|
|
|
mCursor = (UINT8 *)(UINTN)(0xb8000 + (((((UINTN)mCursor - 0xb8000) + 160) / 160) * 160));
|
|
|
|
} else {
|
|
|
|
*mCursor = String[Index];
|
|
|
|
mCursor += 2;
|
|
|
|
}
|
|
|
|
}
|
2010-10-16 20:51:09 +02:00
|
|
|
|
|
|
|
//
|
|
|
|
// All information also output to serial port.
|
|
|
|
//
|
|
|
|
SerialPortWrite ((UINT8*) String, Index);
|
2008-04-18 05:09:54 +02:00
|
|
|
}
|
|
|
|
|