2016-11-29 04:01:00 +01:00
|
|
|
/** @file
|
2016-11-16 14:24:09 +01:00
|
|
|
|
2016-12-08 03:21:16 +01:00
|
|
|
Copyright (c) 2007, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:05:13 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2016-11-16 14:24:09 +01:00
|
|
|
|
|
|
|
|
2016-11-29 04:01:00 +01:00
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
|
|
|
|
#ifndef _EFI_EDB_SUPPORT_H_
|
|
|
|
#define _EFI_EDB_SUPPORT_H_
|
|
|
|
|
|
|
|
#include <Uefi.h>
|
|
|
|
|
|
|
|
#define EFI_DEBUG_PROMPT_STRING L"EDB > "
|
|
|
|
#define EFI_DEBUG_PROMPT_COLUMN 5
|
|
|
|
#define EFI_DEBUG_INPUS_BUFFER_SIZE 64
|
|
|
|
|
|
|
|
#define EFI_DEBUGGER_LINE_NUMBER_IN_PAGE 0x10
|
|
|
|
|
2021-12-05 23:54:02 +01:00
|
|
|
#define EFI_DEBUG_MAX_PRINT_BUFFER (80 * 4)
|
2016-11-16 14:24:09 +01:00
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Convert hex string to uint.
|
|
|
|
|
|
|
|
@param Str - The string
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
Xtoi (
|
2016-12-01 09:22:49 +01:00
|
|
|
CHAR16 *Str
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Convert hex string to uint.
|
|
|
|
|
|
|
|
@param Str - The string
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
UINT64
|
|
|
|
EFIAPI
|
|
|
|
LXtoi (
|
2016-12-01 09:22:49 +01:00
|
|
|
CHAR16 *Str
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Convert hex string to uint.
|
|
|
|
|
|
|
|
@param Str - The string
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
Atoi (
|
2016-12-01 09:22:49 +01:00
|
|
|
CHAR16 *Str
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Convert hex string to uint.
|
|
|
|
|
|
|
|
@param Str - The string
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
AsciiXtoi (
|
2016-12-01 09:22:49 +01:00
|
|
|
CHAR8 *Str
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Convert hex string to uint.
|
|
|
|
|
|
|
|
@param Str - The string
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
AsciiAtoi (
|
2016-12-01 09:22:49 +01:00
|
|
|
CHAR8 *Str
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
Compare the Unicode and Ascii string pointed by String to the string pointed by String2.
|
|
|
|
|
|
|
|
@param String - Unicode String to process
|
|
|
|
|
|
|
|
@param String2 - Ascii string to process
|
|
|
|
|
|
|
|
@return Return a positive integer if String is lexicall greater than String2; Zero if
|
|
|
|
the two strings are identical; and a negative interger if String is lexically
|
|
|
|
less than String2.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
INTN
|
|
|
|
EFIAPI
|
|
|
|
StrCmpUnicodeAndAscii (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR16 *String,
|
|
|
|
IN CHAR8 *String2
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Compare the Unicode string pointed by String to the string pointed by String2.
|
|
|
|
|
|
|
|
@param String - Unicode String to process
|
|
|
|
@param String2 - Unicode string to process
|
|
|
|
|
|
|
|
@return Return a positive integer if String is lexically greater than String2; Zero if
|
|
|
|
the two strings are identical; and a negative integer if String is lexically
|
|
|
|
less than String2.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
INTN
|
|
|
|
EFIAPI
|
|
|
|
StriCmp (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR16 *String,
|
|
|
|
IN CHAR16 *String2
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Compare the Unicode and Ascii string pointed by String to the string pointed by String2.
|
|
|
|
|
|
|
|
@param String - Unicode String to process
|
|
|
|
@param String2 - Ascii string to process
|
|
|
|
|
|
|
|
@return Return a positive integer if String is lexically greater than String2; Zero if
|
|
|
|
the two strings are identical; and a negative integer if String is lexically
|
|
|
|
less than String2.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
INTN
|
|
|
|
EFIAPI
|
|
|
|
StriCmpUnicodeAndAscii (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR16 *String,
|
|
|
|
IN CHAR8 *String2
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Verify if the string is end with the sub string.
|
|
|
|
|
|
|
|
@param Str - The string where to search the sub string
|
|
|
|
@param SubStr - The substring.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
BOOLEAN
|
|
|
|
EFIAPI
|
|
|
|
StrEndWith (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR16 *Str,
|
|
|
|
IN CHAR16 *SubStr
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
Duplicate a string.
|
|
|
|
|
|
|
|
@param Src The string to be duplicated.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
CHAR16 *
|
|
|
|
EFIAPI
|
|
|
|
StrDuplicate (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR16 *Src
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Find the next token after one or more specified characters.
|
|
|
|
|
|
|
|
@param String Point to the string where to find the substring.
|
|
|
|
@param CharSet Point to the string to be found.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
CHAR16 *
|
|
|
|
EFIAPI
|
|
|
|
StrGetNewTokenLine (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR16 *String,
|
|
|
|
IN CHAR16 *CharSet
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Find the next token after one or more specified characters.
|
|
|
|
|
|
|
|
@param CharSet Point to the string to be found.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
CHAR16 *
|
|
|
|
EFIAPI
|
|
|
|
StrGetNextTokenLine (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR16 *CharSet
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Find the next token after one specificed characters.
|
|
|
|
|
|
|
|
@param String Point to the string where to find the substring.
|
|
|
|
@param CharSet Point to the string to be found.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
CHAR16 *
|
|
|
|
EFIAPI
|
|
|
|
StrGetNewTokenField (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR16 *String,
|
|
|
|
IN CHAR16 *CharSet
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Find the next token after one specificed characters.
|
|
|
|
|
|
|
|
@param CharSet Point to the string to be found.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
CHAR16 *
|
|
|
|
EFIAPI
|
|
|
|
StrGetNextTokenField (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR16 *CharSet
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Patch a character to the end of a string.
|
|
|
|
|
|
|
|
@param Buffer The string to be patched.
|
|
|
|
@param Patch The patch character.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
PatchForStrTokenAfter (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR16 *Buffer,
|
|
|
|
IN CHAR16 Patch
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
Patch a character at the beginning of a string.
|
|
|
|
|
|
|
|
@param Buffer The string to be patched.
|
|
|
|
@param Patch The patch character.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
PatchForStrTokenBefore (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR16 *Buffer,
|
|
|
|
IN CHAR16 Patch
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Find the next token after one or more specified characters.
|
|
|
|
|
|
|
|
@param String Point to the string where to find the substring.
|
|
|
|
@param CharSet Point to the string to be found.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
CHAR8 *
|
|
|
|
EFIAPI
|
|
|
|
AsciiStrGetNewTokenLine (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR8 *String,
|
|
|
|
IN CHAR8 *CharSet
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Find the next token after one or more specified characters.
|
|
|
|
|
|
|
|
@param CharSet Point to the string to be found.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
CHAR8 *
|
|
|
|
EFIAPI
|
|
|
|
AsciiStrGetNextTokenLine (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR8 *CharSet
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Find the next token after one specificed characters.
|
|
|
|
|
|
|
|
@param String Point to the string where to find the substring.
|
|
|
|
@param CharSet Point to the string to be found.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
CHAR8 *
|
|
|
|
EFIAPI
|
|
|
|
AsciiStrGetNewTokenField (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR8 *String,
|
|
|
|
IN CHAR8 *CharSet
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Find the next token after one specificed characters.
|
|
|
|
|
|
|
|
@param CharSet Point to the string to be found.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
CHAR8 *
|
|
|
|
EFIAPI
|
|
|
|
AsciiStrGetNextTokenField (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR8 *CharSet
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Patch a character to the end of a string.
|
|
|
|
|
|
|
|
@param Buffer The string to be patched.
|
|
|
|
@param Patch The patch character.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
PatchForAsciiStrTokenAfter (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR8 *Buffer,
|
|
|
|
IN CHAR8 Patch
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
Patch a character at the beginning of a string.
|
|
|
|
|
|
|
|
@param Buffer The string to be patched.
|
|
|
|
@param Patch The patch character.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
PatchForAsciiStrTokenBefore (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR8 *Buffer,
|
|
|
|
IN CHAR8 Patch
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-11-29 04:01:00 +01:00
|
|
|
/**
|
2016-12-05 04:33:52 +01:00
|
|
|
|
|
|
|
Shell Library.
|
|
|
|
Get user input.
|
|
|
|
|
|
|
|
@param Prompt The prompt string.
|
|
|
|
@param InStr Point to the input string.
|
|
|
|
@param StrLen The max length of string user can input.
|
|
|
|
|
2016-11-29 04:01:00 +01:00
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
Input (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN CHAR16 *Prompt OPTIONAL,
|
|
|
|
OUT CHAR16 *InStr,
|
|
|
|
IN UINTN StrLen
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
SetPageBreak.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
BOOLEAN
|
|
|
|
EFIAPI
|
|
|
|
SetPageBreak (
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
Print a Unicode string to the output device.
|
|
|
|
|
|
|
|
@param Format A Null-terminated Unicode format string.
|
|
|
|
@param ... The variable argument list that contains pointers to Null-
|
|
|
|
terminated Unicode strings to be printed
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
EDBPrint (
|
|
|
|
IN CONST CHAR16 *Format,
|
|
|
|
...
|
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
Print a Unicode string to the output buffer.
|
|
|
|
|
|
|
|
@param Buffer A pointer to the output buffer for the produced Null-terminated
|
|
|
|
Unicode string.
|
|
|
|
@param BufferSize The size, in bytes, of the output buffer specified by StartOfBuffer.
|
|
|
|
@param Format A Null-terminated Unicode format string.
|
|
|
|
@param ... The variable argument list that contains pointers to Null-
|
|
|
|
terminated Unicode strings to be printed
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
EDBSPrint (
|
|
|
|
OUT CHAR16 *Buffer,
|
|
|
|
IN INTN BufferSize,
|
|
|
|
IN CONST CHAR16 *Format,
|
|
|
|
...
|
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
Print a Unicode string to the output buffer with specified offset..
|
|
|
|
|
|
|
|
@param Buffer A pointer to the output buffer for the produced Null-terminated
|
|
|
|
Unicode string.
|
|
|
|
@param BufferSize The size, in bytes, of the output buffer specified by StartOfBuffer.
|
|
|
|
@param Offset The offset of the buffer.
|
|
|
|
@param Format A Null-terminated Unicode format string.
|
|
|
|
@param ... The variable argument list that contains pointers to Null-
|
|
|
|
terminated Unicode strings to be printed
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
UINTN
|
|
|
|
EFIAPI
|
|
|
|
EDBSPrintWithOffset (
|
|
|
|
OUT CHAR16 *Buffer,
|
|
|
|
IN INTN BufferSize,
|
|
|
|
IN UINTN Offset,
|
|
|
|
IN CONST CHAR16 *Format,
|
|
|
|
...
|
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Read a file.
|
|
|
|
If ScanFs is FLASE, it will use DebuggerPrivate->Vol as default Fs.
|
|
|
|
If ScanFs is TRUE, it will scan all FS and check the file.
|
|
|
|
If there is only one file match the name, it will be read.
|
|
|
|
If there is more than one file match the name, it will return Error.
|
|
|
|
|
|
|
|
@param DebuggerPrivate - EBC Debugger private data structure
|
|
|
|
@param FileName - The file to be read.
|
|
|
|
@param BufferSize - The file buffer size
|
|
|
|
@param Buffer - The file buffer
|
|
|
|
@param ScanFs - Need Scan all FS
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS - read file successfully
|
|
|
|
@retval EFI_NOT_FOUND - file not found
|
|
|
|
@retval EFI_NO_MAPPING - there is duplicated files found
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
ReadFileToBuffer (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN EFI_DEBUGGER_PRIVATE_DATA *DebuggerPrivate,
|
|
|
|
IN CHAR16 *FileName,
|
|
|
|
OUT UINTN *BufferSize,
|
|
|
|
OUT VOID **Buffer,
|
|
|
|
IN BOOLEAN ScanFs
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
2016-12-05 04:33:52 +01:00
|
|
|
/**
|
|
|
|
|
|
|
|
Get file name under this dir with index
|
|
|
|
|
|
|
|
@param DebuggerPrivate - EBC Debugger private data structure
|
|
|
|
@param DirName - The dir to be read.
|
|
|
|
@param FileName - The file name pattern under this dir
|
|
|
|
@param Index - The file index under this dir
|
|
|
|
|
|
|
|
@return File Name which match the pattern and index.
|
|
|
|
|
|
|
|
**/
|
2016-11-16 14:24:09 +01:00
|
|
|
CHAR16 *
|
|
|
|
EFIAPI
|
|
|
|
GetFileNameUnderDir (
|
2021-12-05 23:54:02 +01:00
|
|
|
IN EFI_DEBUGGER_PRIVATE_DATA *DebuggerPrivate,
|
|
|
|
IN CHAR16 *DirName,
|
|
|
|
IN CHAR16 *FileName,
|
|
|
|
IN OUT UINTN *Index
|
2016-11-16 14:24:09 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
#endif
|