mirror of
				https://git.proxmox.com/git/mirror_edk2
				synced 2025-11-04 09:12:31 +00:00 
			
		
		
		
	Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Dandan Bi <dandan.bi@intel.com>
		
			
				
	
	
		
			484 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			484 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/** @file
 | 
						|
 | 
						|
Copyright (c) 2007, 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
 | 
						|
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.
 | 
						|
 | 
						|
 | 
						|
**/
 | 
						|
 | 
						|
#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
 | 
						|
 | 
						|
#define EFI_DEBUG_MAX_PRINT_BUFFER   (80 * 4)
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  Convert hex string to uint.
 | 
						|
 | 
						|
  @param  Str  -  The string
 | 
						|
 | 
						|
**/
 | 
						|
UINTN
 | 
						|
EFIAPI
 | 
						|
Xtoi (
 | 
						|
  CHAR16  *Str
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  Convert hex string to uint.
 | 
						|
 | 
						|
  @param  Str  -  The string
 | 
						|
 | 
						|
**/
 | 
						|
UINT64
 | 
						|
EFIAPI
 | 
						|
LXtoi (
 | 
						|
  CHAR16  *Str
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  Convert hex string to uint.
 | 
						|
 | 
						|
  @param Str  -  The string
 | 
						|
 | 
						|
**/
 | 
						|
UINTN
 | 
						|
EFIAPI
 | 
						|
Atoi (
 | 
						|
  CHAR16  *Str
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  Convert hex string to uint.
 | 
						|
 | 
						|
  @param  Str  -  The string
 | 
						|
 | 
						|
**/
 | 
						|
UINTN
 | 
						|
EFIAPI
 | 
						|
AsciiXtoi (
 | 
						|
  CHAR8  *Str
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  Convert hex string to uint.
 | 
						|
 | 
						|
  @param Str  -  The string
 | 
						|
 | 
						|
**/
 | 
						|
UINTN
 | 
						|
EFIAPI
 | 
						|
AsciiAtoi (
 | 
						|
  CHAR8  *Str
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  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.
 | 
						|
 | 
						|
**/
 | 
						|
INTN
 | 
						|
EFIAPI
 | 
						|
StrCmpUnicodeAndAscii (
 | 
						|
  IN CHAR16   *String,
 | 
						|
  IN CHAR8    *String2
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  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.
 | 
						|
 | 
						|
**/
 | 
						|
INTN
 | 
						|
EFIAPI
 | 
						|
StriCmp (
 | 
						|
  IN CHAR16   *String,
 | 
						|
  IN CHAR16   *String2
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  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.
 | 
						|
 | 
						|
**/
 | 
						|
INTN
 | 
						|
EFIAPI
 | 
						|
StriCmpUnicodeAndAscii (
 | 
						|
  IN CHAR16   *String,
 | 
						|
  IN CHAR8    *String2
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  Verify if the string is end with the sub string.
 | 
						|
 | 
						|
  @param  Str - The string where to search the sub string
 | 
						|
  @param  SubStr - The substring.
 | 
						|
 | 
						|
**/
 | 
						|
BOOLEAN
 | 
						|
EFIAPI
 | 
						|
StrEndWith (
 | 
						|
  IN CHAR16                       *Str,
 | 
						|
  IN CHAR16                       *SubStr
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  Duplicate a string.
 | 
						|
 | 
						|
  @param  Src  The string to be duplicated.
 | 
						|
 | 
						|
**/
 | 
						|
CHAR16 *
 | 
						|
EFIAPI
 | 
						|
StrDuplicate (
 | 
						|
  IN CHAR16   *Src
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  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.
 | 
						|
 | 
						|
**/
 | 
						|
CHAR16 *
 | 
						|
EFIAPI
 | 
						|
StrGetNewTokenLine (
 | 
						|
  IN CHAR16                       *String,
 | 
						|
  IN CHAR16                       *CharSet
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  Find the next token after one or more specified characters.
 | 
						|
 | 
						|
  @param  CharSet   Point to the string to be found.
 | 
						|
 | 
						|
**/
 | 
						|
CHAR16 *
 | 
						|
EFIAPI
 | 
						|
StrGetNextTokenLine (
 | 
						|
  IN CHAR16                       *CharSet
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  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.
 | 
						|
 | 
						|
**/
 | 
						|
CHAR16 *
 | 
						|
EFIAPI
 | 
						|
StrGetNewTokenField (
 | 
						|
  IN CHAR16                       *String,
 | 
						|
  IN CHAR16                       *CharSet
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  Find the next token after one specificed characters.
 | 
						|
 | 
						|
  @param  CharSet   Point to the string to be found.
 | 
						|
 | 
						|
**/
 | 
						|
CHAR16 *
 | 
						|
EFIAPI
 | 
						|
StrGetNextTokenField (
 | 
						|
  IN CHAR16                       *CharSet
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  Patch a character to the end of a string.
 | 
						|
 | 
						|
  @param  Buffer   The string to be patched.
 | 
						|
  @param  Patch    The patch character.
 | 
						|
 | 
						|
**/
 | 
						|
VOID
 | 
						|
EFIAPI
 | 
						|
PatchForStrTokenAfter (
 | 
						|
  IN CHAR16    *Buffer,
 | 
						|
  IN CHAR16    Patch
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  Patch a character at the beginning of a string.
 | 
						|
 | 
						|
  @param  Buffer   The string to be patched.
 | 
						|
  @param  Patch    The patch character.
 | 
						|
 | 
						|
**/
 | 
						|
VOID
 | 
						|
EFIAPI
 | 
						|
PatchForStrTokenBefore (
 | 
						|
  IN CHAR16    *Buffer,
 | 
						|
  IN CHAR16    Patch
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  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.
 | 
						|
 | 
						|
**/
 | 
						|
CHAR8 *
 | 
						|
EFIAPI
 | 
						|
AsciiStrGetNewTokenLine (
 | 
						|
  IN CHAR8                       *String,
 | 
						|
  IN CHAR8                       *CharSet
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  Find the next token after one or more specified characters.
 | 
						|
 | 
						|
  @param  CharSet   Point to the string to be found.
 | 
						|
 | 
						|
**/
 | 
						|
CHAR8 *
 | 
						|
EFIAPI
 | 
						|
AsciiStrGetNextTokenLine (
 | 
						|
  IN CHAR8                       *CharSet
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  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.
 | 
						|
 | 
						|
**/
 | 
						|
CHAR8 *
 | 
						|
EFIAPI
 | 
						|
AsciiStrGetNewTokenField (
 | 
						|
  IN CHAR8                       *String,
 | 
						|
  IN CHAR8                       *CharSet
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  Find the next token after one specificed characters.
 | 
						|
 | 
						|
  @param  CharSet   Point to the string to be found.
 | 
						|
 | 
						|
**/
 | 
						|
CHAR8 *
 | 
						|
EFIAPI
 | 
						|
AsciiStrGetNextTokenField (
 | 
						|
  IN CHAR8                       *CharSet
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  Patch a character to the end of a string.
 | 
						|
 | 
						|
  @param  Buffer   The string to be patched.
 | 
						|
  @param  Patch    The patch character.
 | 
						|
 | 
						|
**/
 | 
						|
VOID
 | 
						|
EFIAPI
 | 
						|
PatchForAsciiStrTokenAfter (
 | 
						|
  IN CHAR8    *Buffer,
 | 
						|
  IN CHAR8    Patch
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  Patch a character at the beginning of a string.
 | 
						|
 | 
						|
  @param  Buffer   The string to be patched.
 | 
						|
  @param  Patch    The patch character.
 | 
						|
 | 
						|
**/
 | 
						|
VOID
 | 
						|
EFIAPI
 | 
						|
PatchForAsciiStrTokenBefore (
 | 
						|
  IN CHAR8    *Buffer,
 | 
						|
  IN CHAR8    Patch
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  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.
 | 
						|
 | 
						|
**/
 | 
						|
VOID
 | 
						|
EFIAPI
 | 
						|
Input (
 | 
						|
  IN CHAR16    *Prompt OPTIONAL,
 | 
						|
  OUT CHAR16   *InStr,
 | 
						|
  IN UINTN     StrLen
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  SetPageBreak.
 | 
						|
 | 
						|
**/
 | 
						|
BOOLEAN
 | 
						|
EFIAPI
 | 
						|
SetPageBreak (
 | 
						|
  VOID
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  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
 | 
						|
 | 
						|
**/
 | 
						|
UINTN
 | 
						|
EFIAPI
 | 
						|
EDBPrint (
 | 
						|
  IN CONST CHAR16  *Format,
 | 
						|
  ...
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  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
 | 
						|
 | 
						|
**/
 | 
						|
UINTN
 | 
						|
EFIAPI
 | 
						|
EDBSPrint (
 | 
						|
  OUT CHAR16        *Buffer,
 | 
						|
  IN  INTN          BufferSize,
 | 
						|
  IN  CONST CHAR16  *Format,
 | 
						|
  ...
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
  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
 | 
						|
 | 
						|
**/
 | 
						|
UINTN
 | 
						|
EFIAPI
 | 
						|
EDBSPrintWithOffset (
 | 
						|
  OUT CHAR16        *Buffer,
 | 
						|
  IN  INTN          BufferSize,
 | 
						|
  IN  UINTN         Offset,
 | 
						|
  IN  CONST CHAR16  *Format,
 | 
						|
  ...
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  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
 | 
						|
 | 
						|
**/
 | 
						|
EFI_STATUS
 | 
						|
EFIAPI
 | 
						|
ReadFileToBuffer (
 | 
						|
  IN  EFI_DEBUGGER_PRIVATE_DATA   *DebuggerPrivate,
 | 
						|
  IN  CHAR16                      *FileName,
 | 
						|
  OUT UINTN                       *BufferSize,
 | 
						|
  OUT VOID                        **Buffer,
 | 
						|
  IN  BOOLEAN                     ScanFs
 | 
						|
  );
 | 
						|
 | 
						|
/**
 | 
						|
 | 
						|
  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.
 | 
						|
 | 
						|
**/
 | 
						|
CHAR16 *
 | 
						|
EFIAPI
 | 
						|
GetFileNameUnderDir (
 | 
						|
  IN  EFI_DEBUGGER_PRIVATE_DATA   *DebuggerPrivate,
 | 
						|
  IN  CHAR16                      *DirName,
 | 
						|
  IN  CHAR16                      *FileName,
 | 
						|
  IN OUT UINTN                    *Index
 | 
						|
  );
 | 
						|
 | 
						|
#endif
 |