Function description in baselib.h is not clear. change it to comply with Doxgen format.

git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@5862 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
eric_tian 2008-09-09 06:22:30 +00:00
parent c0a23f8c37
commit 1106ffe1c0
3 changed files with 191 additions and 195 deletions

View File

@ -15,16 +15,14 @@
#ifndef __BASE_LIB__
#define __BASE_LIB__
//
// Definitions for architecture specific types
// These include SPIN_LOCK and BASE_LIBRARY_JUMP_BUFFER
//
///
/// SPIN_LOCK
/// Definitions for SPIN_LOCK
///
typedef volatile UINTN SPIN_LOCK;
//
// Definitions for architecture specific types
//
#if defined (MDE_CPU_IA32)
///
/// IA32 context buffer used by SetJump() and LongJump()
@ -272,7 +270,7 @@ StrSize (
@param SecondString Pointer to a Null-terminated Unicode string.
@retval 0 FirstString is identical to SecondString.
@retval !=0 FirstString is not identical to SecondString.
@return others FirstString is not identical to SecondString.
**/
INTN
@ -310,7 +308,7 @@ StrCmp (
@param Length Maximum number of Unicode characters to compare.
@retval 0 FirstString is identical to SecondString.
@retval !=0 FirstString is not identical to SecondString.
@return others FirstString is not identical to SecondString.
**/
INTN
@ -430,7 +428,7 @@ StrnCat (
@param SearchString Pointer to a Null-terminated Unicode string to search for.
@retval NULL If the SearchString does not appear in String.
@retval !NULL If there is a match.
@return others If there is a match.
**/
CHAR16 *
@ -627,7 +625,7 @@ NibbleToHexChar (
/**
Convert binary buffer to a Unicode String in a specified sequence.
This function converts bytes in the binary Buffer Buf to a Unicode String Str.
This function converts bytes in the memory block pointed by Buffer to a Unicode String Str.
Each byte will be represented by two Unicode characters. For example, byte 0xA1 will
be converted into two Unicode character L'A' and L'1'. In the output String, the Unicode Character
for the Most Significant Nibble will be put before the Unicode Character for the Least Significant
@ -716,6 +714,10 @@ HexStringToBuf (
If Digit is NULL, then ASSERT.
@param Digit The output hexadecimal digit.
@param Char The input Unicode character.
@retval TRUE Char is in the range of Hexadecimal number. Digit is updated
to the byte value of the number.
@retval FALSE Char is not in the range of Hexadecimal number. Digit is keep
@ -902,7 +904,7 @@ AsciiStrSize (
@param SecondString Pointer to a Null-terminated ASCII string.
@retval 0 FirstString is identical to SecondString.
@retval !=0 FirstString is not identical to SecondString.
@return others FirstString is not identical to SecondString.
**/
INTN
@ -938,7 +940,7 @@ AsciiStrCmp (
@retval 0 FirstString is identical to SecondString using case insensitive
comparisons.
@retval !=0 FirstString is not identical to SecondString using case
@return others FirstString is not identical to SecondString using case
insensitive comparisons.
**/
@ -975,7 +977,7 @@ AsciiStriCmp (
@param Length Maximum number of ASCII characters for compare.
@retval 0 FirstString is identical to SecondString.
@retval !=0 FirstString is not identical to SecondString.
@return others FirstString is not identical to SecondString.
**/
INTN
@ -1085,7 +1087,7 @@ AsciiStrnCat (
@param SearchString Pointer to a Null-terminated ASCII string to search for.
@retval NULL If the SearchString does not appear in String.
@retval !NULL If there is a match.
@return others If there is a match.
**/
CHAR8 *
@ -3296,7 +3298,6 @@ CalculateSum8 (
If Buffer is NULL, then ASSERT().
If Length is greater than (MAX_ADDRESS - Buffer + 1), then ASSERT().
@param Buffer Pointer to the buffer to carry out the checksum operation.
@param Length The size, in bytes, of Buffer.
@ -3476,9 +3477,9 @@ CalculateCheckSum64 (
);
//
// Base Library CPU Functions
//
///
/// Base Library CPU Functions
///
typedef
VOID
(EFIAPI *SWITCH_STACK_ENTRY_POINT)(
@ -4915,12 +4916,10 @@ AsmSwitchStackAndBackingStore (
IN VOID *NewBsp
);
//
// Bugbug: This call should be removed after
// the PalCall Instance issue has been fixed.
//
/**
@todo This call should be removed after the PalCall
Instance issue has been fixed.
Performs a PAL call using static calling convention.
An internal function to perform a PAL call using static calling convention.
@ -4946,124 +4945,122 @@ PalCallStatic (
#elif defined (MDE_CPU_IA32) || defined (MDE_CPU_X64)
//
// IA32 and X64 Specific Functions
//
//
// Byte packed structure for 16-bit Real Mode EFLAGS
//
///
/// IA32 and X64 Specific Functions
/// Byte packed structure for 16-bit Real Mode EFLAGS
///
typedef union {
struct {
UINT32 CF:1; // Carry Flag
UINT32 Reserved_0:1; // Reserved
UINT32 PF:1; // Parity Flag
UINT32 Reserved_1:1; // Reserved
UINT32 AF:1; // Auxiliary Carry Flag
UINT32 Reserved_2:1; // Reserved
UINT32 ZF:1; // Zero Flag
UINT32 SF:1; // Sign Flag
UINT32 TF:1; // Trap Flag
UINT32 IF:1; // Interrupt Enable Flag
UINT32 DF:1; // Direction Flag
UINT32 OF:1; // Overflow Flag
UINT32 IOPL:2; // I/O Privilege Level
UINT32 NT:1; // Nested Task
UINT32 Reserved_3:1; // Reserved
UINT32 CF:1; /// Carry Flag
UINT32 Reserved_0:1; /// Reserved
UINT32 PF:1; /// Parity Flag
UINT32 Reserved_1:1; /// Reserved
UINT32 AF:1; /// Auxiliary Carry Flag
UINT32 Reserved_2:1; /// Reserved
UINT32 ZF:1; /// Zero Flag
UINT32 SF:1; /// Sign Flag
UINT32 TF:1; /// Trap Flag
UINT32 IF:1; /// Interrupt Enable Flag
UINT32 DF:1; /// Direction Flag
UINT32 OF:1; /// Overflow Flag
UINT32 IOPL:2; /// I/O Privilege Level
UINT32 NT:1; /// Nested Task
UINT32 Reserved_3:1; /// Reserved
} Bits;
UINT16 Uint16;
} IA32_FLAGS16;
//
// Byte packed structure for EFLAGS/RFLAGS
// 32-bits on IA-32
// 64-bits on X64. The upper 32-bits on X64 are reserved
//
///
/// Byte packed structure for EFLAGS/RFLAGS
/// 32-bits on IA-32
/// 64-bits on X64. The upper 32-bits on X64 are reserved
///
typedef union {
struct {
UINT32 CF:1; // Carry Flag
UINT32 Reserved_0:1; // Reserved
UINT32 PF:1; // Parity Flag
UINT32 Reserved_1:1; // Reserved
UINT32 AF:1; // Auxiliary Carry Flag
UINT32 Reserved_2:1; // Reserved
UINT32 ZF:1; // Zero Flag
UINT32 SF:1; // Sign Flag
UINT32 TF:1; // Trap Flag
UINT32 IF:1; // Interrupt Enable Flag
UINT32 DF:1; // Direction Flag
UINT32 OF:1; // Overflow Flag
UINT32 IOPL:2; // I/O Privilege Level
UINT32 NT:1; // Nested Task
UINT32 Reserved_3:1; // Reserved
UINT32 RF:1; // Resume Flag
UINT32 VM:1; // Virtual 8086 Mode
UINT32 AC:1; // Alignment Check
UINT32 VIF:1; // Virtual Interrupt Flag
UINT32 VIP:1; // Virtual Interrupt Pending
UINT32 ID:1; // ID Flag
UINT32 Reserved_4:10; // Reserved
UINT32 CF:1; /// Carry Flag
UINT32 Reserved_0:1; /// Reserved
UINT32 PF:1; /// Parity Flag
UINT32 Reserved_1:1; /// Reserved
UINT32 AF:1; /// Auxiliary Carry Flag
UINT32 Reserved_2:1; /// Reserved
UINT32 ZF:1; /// Zero Flag
UINT32 SF:1; /// Sign Flag
UINT32 TF:1; /// Trap Flag
UINT32 IF:1; /// Interrupt Enable Flag
UINT32 DF:1; /// Direction Flag
UINT32 OF:1; /// Overflow Flag
UINT32 IOPL:2; /// I/O Privilege Level
UINT32 NT:1; /// Nested Task
UINT32 Reserved_3:1; /// Reserved
UINT32 RF:1; /// Resume Flag
UINT32 VM:1; /// Virtual 8086 Mode
UINT32 AC:1; /// Alignment Check
UINT32 VIF:1; /// Virtual Interrupt Flag
UINT32 VIP:1; /// Virtual Interrupt Pending
UINT32 ID:1; /// ID Flag
UINT32 Reserved_4:10; /// Reserved
} Bits;
UINTN UintN;
} IA32_EFLAGS32;
//
// Byte packed structure for Control Register 0 (CR0)
// 32-bits on IA-32
// 64-bits on X64. The upper 32-bits on X64 are reserved
//
///
/// Byte packed structure for Control Register 0 (CR0)
/// 32-bits on IA-32
/// 64-bits on X64. The upper 32-bits on X64 are reserved
///
typedef union {
struct {
UINT32 PE:1; // Protection Enable
UINT32 MP:1; // Monitor Coprocessor
UINT32 EM:1; // Emulation
UINT32 TS:1; // Task Switched
UINT32 ET:1; // Extension Type
UINT32 NE:1; // Numeric Error
UINT32 Reserved_0:10; // Reserved
UINT32 WP:1; // Write Protect
UINT32 Reserved_1:1; // Reserved
UINT32 AM:1; // Alignment Mask
UINT32 Reserved_2:10; // Reserved
UINT32 NW:1; // Mot Write-through
UINT32 CD:1; // Cache Disable
UINT32 PG:1; // Paging
UINT32 PE:1; /// Protection Enable
UINT32 MP:1; /// Monitor Coprocessor
UINT32 EM:1; /// Emulation
UINT32 TS:1; /// Task Switched
UINT32 ET:1; /// Extension Type
UINT32 NE:1; /// Numeric Error
UINT32 Reserved_0:10; /// Reserved
UINT32 WP:1; /// Write Protect
UINT32 Reserved_1:1; /// Reserved
UINT32 AM:1; /// Alignment Mask
UINT32 Reserved_2:10; /// Reserved
UINT32 NW:1; /// Mot Write-through
UINT32 CD:1; /// Cache Disable
UINT32 PG:1; /// Paging
} Bits;
UINTN UintN;
} IA32_CR0;
//
// Byte packed structure for Control Register 4 (CR4)
// 32-bits on IA-32
// 64-bits on X64. The upper 32-bits on X64 are reserved
//
///
/// Byte packed structure for Control Register 4 (CR4)
/// 32-bits on IA-32
/// 64-bits on X64. The upper 32-bits on X64 are reserved
///
typedef union {
struct {
UINT32 VME:1; // Virtual-8086 Mode Extensions
UINT32 PVI:1; // Protected-Mode Virtual Interrupts
UINT32 TSD:1; // Time Stamp Disable
UINT32 DE:1; // Debugging Extensions
UINT32 PSE:1; // Page Size Extensions
UINT32 PAE:1; // Physical Address Extension
UINT32 MCE:1; // Machine Check Enable
UINT32 PGE:1; // Page Global Enable
UINT32 PCE:1; // Performance Monitoring Counter
// Enable
UINT32 OSFXSR:1; // Operating System Support for
// FXSAVE and FXRSTOR instructions
UINT32 OSXMMEXCPT:1; // Operating System Support for
// Unmasked SIMD Floating Point
// Exceptions
UINT32 Reserved_0:2; // Reserved
UINT32 VMXE:1; // VMX Enable
UINT32 Reserved_1:18; // Reseved
UINT32 VME:1; /// Virtual-8086 Mode Extensions
UINT32 PVI:1; /// Protected-Mode Virtual Interrupts
UINT32 TSD:1; /// Time Stamp Disable
UINT32 DE:1; /// Debugging Extensions
UINT32 PSE:1; /// Page Size Extensions
UINT32 PAE:1; /// Physical Address Extension
UINT32 MCE:1; /// Machine Check Enable
UINT32 PGE:1; /// Page Global Enable
UINT32 PCE:1; /// Performance Monitoring Counter
/// Enable
UINT32 OSFXSR:1; /// Operating System Support for
/// FXSAVE and FXRSTOR instructions
UINT32 OSXMMEXCPT:1; /// Operating System Support for
/// Unmasked SIMD Floating Point
/// Exceptions
UINT32 Reserved_0:2; /// Reserved
UINT32 VMXE:1; /// VMX Enable
UINT32 Reserved_1:18; /// Reseved
} Bits;
UINTN UintN;
} IA32_CR4;
//
// Byte packed structure for an IDTR, GDTR, LDTR descriptor
/// @bug How to make this structure byte-packed in a compiler independent way?
//
///
/// Byte packed structure for an IDTR, GDTR, LDTR descriptor
/// @todo How to make this structure byte-packed in a compiler independent way?
///
#pragma pack (1)
typedef struct {
UINT16 Limit;
@ -5077,30 +5074,30 @@ typedef struct {
#define IA32_IDT_GATE_TYPE_INTERRUPT_32 0x8E
#define IA32_IDT_GATE_TYPE_TRAP_32 0x8F
//
// Byte packed structure for an Interrupt Gate Descriptor
//
///
/// Byte packed structure for an Interrupt Gate Descriptor
///
typedef union {
struct {
UINT32 OffsetLow:16; // Offset bits 15..0
UINT32 Selector:16; // Selector
UINT32 Reserved_0:8; // Reserved
UINT32 GateType:8; // Gate Type. See #defines above
UINT32 OffsetHigh:16; // Offset bits 31..16
UINT32 OffsetLow:16; /// Offset bits 15..0
UINT32 Selector:16; /// Selector
UINT32 Reserved_0:8; /// Reserved
UINT32 GateType:8; /// Gate Type. See #defines above
UINT32 OffsetHigh:16; /// Offset bits 31..16
} Bits;
UINT64 Uint64;
} IA32_IDT_GATE_DESCRIPTOR;
//
// Byte packed structure for an FP/SSE/SSE2 context
//
///
/// Byte packed structure for an FP/SSE/SSE2 context
///
typedef struct {
UINT8 Buffer[512];
} IA32_FX_BUFFER;
//
// Structures for the 16-bit real mode thunks
//
///
/// Structures for the 16-bit real mode thunks
///
typedef struct {
UINT32 Reserved1;
UINT32 Reserved2;
@ -5164,9 +5161,9 @@ typedef union {
IA32_BYTE_REGS H;
} IA32_REGISTER_SET;
//
// Byte packed structure for an 16-bit real mode thunks
//
///
/// Byte packed structure for an 16-bit real mode thunks
///
typedef struct {
IA32_REGISTER_SET *RealModeState;
VOID *RealModeBuffer;
@ -7221,10 +7218,6 @@ AsmPrepareAndThunk16 (
IN OUT THUNK_CONTEXT *ThunkContext
);
#else
#endif
#endif

View File

@ -70,7 +70,6 @@ CalculateSum8 (
If Buffer is NULL, then ASSERT().
If Length is greater than (MAX_ADDRESS - Buffer + 1), then ASSERT().
@param Buffer Pointer to the buffer to carry out the checksum operation.
@param Length The size, in bytes, of Buffer.

View File

@ -230,7 +230,7 @@ StrSize (
@param SecondString Pointer to a Null-terminated Unicode string.
@retval 0 FirstString is identical to SecondString.
@retval !=0 FirstString is not identical to SecondString.
@return others FirstString is not identical to SecondString.
**/
INTN
@ -280,7 +280,7 @@ StrCmp (
@param Length Maximum number of Unicode characters to compare.
@retval 0 FirstString is identical to SecondString.
@retval !=0 FirstString is not identical to SecondString.
@return others FirstString is not identical to SecondString.
**/
INTN
@ -438,7 +438,7 @@ StrnCat (
@param SearchString Pointer to a Null-terminated Unicode string to search for.
@retval NULL If the SearchString does not appear in String.
@retval !NULL If there is a match.
@return others If there is a match.
**/
CHAR16 *
@ -1266,7 +1266,7 @@ AsciiStrSize (
@param SecondString Pointer to a Null-terminated ASCII string.
@retval 0 FirstString is identical to SecondString.
@retval !=0 FirstString is not identical to SecondString.
@return others FirstString is not identical to SecondString.
**/
INTN
@ -1364,7 +1364,7 @@ InternalAsciiHexCharToUintn (
@retval 0 FirstString is identical to SecondString using case insensitive
comparisons.
@retval !=0 FirstString is not identical to SecondString using case
@return others FirstString is not identical to SecondString using case
insensitive comparisons.
**/
@ -1421,7 +1421,7 @@ AsciiStriCmp (
@param Length Maximum number of ASCII characters to compare.
@retval 0 FirstString is identical to SecondString.
@retval !=0 FirstString is not identical to SecondString.
@return others FirstString is not identical to SecondString.
**/
INTN
@ -1568,7 +1568,7 @@ AsciiStrnCat (
@param SearchString Pointer to a Null-terminated ASCII string to search for.
@retval NULL If the SearchString does not appear in String.
@retval !NULL If there is a match.
@return others If there is a match.
**/
CHAR8 *
@ -2103,7 +2103,7 @@ NibbleToHexChar (
/**
Convert binary buffer to a Unicode String in a specified sequence.
This function converts bytes in the binary Buffer Buf to a Unicode String Str.
This function converts bytes in the memory block pointed by Buffer to a Unicode String Str.
Each byte will be represented by two Unicode characters. For example, byte 0xA1 will
be converted into two Unicode character L'A' and L'1'. In the output String, the Unicode Character
for the Most Significant Nibble will be put before the Unicode Character for the Least Significant
@ -2279,6 +2279,10 @@ HexStringToBuf (
If Digit is NULL, then ASSERT.
@param Digit The output hexadecimal digit.
@param Char The input Unicode character.
@retval TRUE Char is in the range of Hexadecimal number. Digit is updated
to the byte value of the number.
@retval FALSE Char is not in the range of Hexadecimal number. Digit is keep