MdeModulePkg:Add definitions for new Performance infrastructure
V3: Add "FPDT_" prefix for related definitions. Cc: Liming Gao <liming.gao@intel.com> Cc: Star Zeng <star.zeng@intel.com> Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Liming Gao <liming.gao@intel.com> Signed-off-by: Dandan Bi <dandan.bi@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com>
This commit is contained in:
291
MdeModulePkg/Include/Guid/ExtendedFirmwarePerformance.h
Normal file
291
MdeModulePkg/Include/Guid/ExtendedFirmwarePerformance.h
Normal file
@ -0,0 +1,291 @@
|
|||||||
|
/** @file
|
||||||
|
This file defines edk2 extended firmware performance records.
|
||||||
|
These records will be added into ACPI FPDT Firmware Basic Boot Performance Table.
|
||||||
|
|
||||||
|
Copyright (c) 2018, 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 that 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 __EXTENDED_FIRMWARE_PERFORMANCE_H__
|
||||||
|
#define __EXTENDED_FIRMWARE_PERFORMANCE_H__
|
||||||
|
|
||||||
|
#include <IndustryStandard/Acpi.h>
|
||||||
|
|
||||||
|
//
|
||||||
|
// Known performance tokens
|
||||||
|
//
|
||||||
|
#define SEC_TOK "SEC" ///< SEC Phase
|
||||||
|
#define DXE_TOK "DXE" ///< DXE Phase
|
||||||
|
#define PEI_TOK "PEI" ///< PEI Phase
|
||||||
|
#define BDS_TOK "BDS" ///< BDS Phase
|
||||||
|
#define DRIVERBINDING_START_TOK "DB:Start:" ///< Driver Binding Start() function call
|
||||||
|
#define DRIVERBINDING_SUPPORT_TOK "DB:Support:" ///< Driver Binding Support() function call
|
||||||
|
#define DRIVERBINDING_STOP_TOK "DB:Stop:" ///< Driver Binding Stop() function call
|
||||||
|
#define LOAD_IMAGE_TOK "LoadImage:" ///< Load a dispatched module
|
||||||
|
#define START_IMAGE_TOK "StartImage:" ///< Dispatched Modules Entry Point execution
|
||||||
|
#define PEIM_TOK "PEIM" ///< PEIM Modules Entry Point execution
|
||||||
|
|
||||||
|
//
|
||||||
|
// Public Progress Identifiers for Event Records to map the above known token
|
||||||
|
//
|
||||||
|
#define MODULE_START_ID 0x01
|
||||||
|
#define MODULE_END_ID 0x02
|
||||||
|
#define MODULE_LOADIMAGE_START_ID 0x03
|
||||||
|
#define MODULE_LOADIMAGE_END_ID 0x04
|
||||||
|
#define MODULE_DB_START_ID 0x05
|
||||||
|
#define MODULE_DB_END_ID 0x06
|
||||||
|
#define MODULE_DB_SUPPORT_START_ID 0x07
|
||||||
|
#define MODULE_DB_SUPPORT_END_ID 0x08
|
||||||
|
#define MODULE_DB_STOP_START_ID 0x09
|
||||||
|
#define MODULE_DB_STOP_END_ID 0x0A
|
||||||
|
|
||||||
|
#define PERF_EVENTSIGNAL_START_ID 0x10
|
||||||
|
#define PERF_EVENTSIGNAL_END_ID 0x11
|
||||||
|
#define PERF_CALLBACK_START_ID 0x20
|
||||||
|
#define PERF_CALLBACK_END_ID 0x21
|
||||||
|
#define PERF_FUNCTION_START_ID 0x30
|
||||||
|
#define PERF_FUNCTION_END_ID 0x31
|
||||||
|
#define PERF_INMODULE_START_ID 0x40
|
||||||
|
#define PERF_INMODULE_END_ID 0x41
|
||||||
|
#define PERF_CROSSMODULE_START_ID 0x50
|
||||||
|
#define PERF_CROSSMODULE_END_ID 0x51
|
||||||
|
|
||||||
|
//
|
||||||
|
// Misc defines
|
||||||
|
//
|
||||||
|
#define FPDT_RECORD_REVISION_1 (0x01)
|
||||||
|
|
||||||
|
//
|
||||||
|
// Length field in EFI_ACPI_5_0_FPDT_PERFORMANCE_RECORD_HEADER is a UINT8, thus:
|
||||||
|
//
|
||||||
|
#define FPDT_MAX_PERF_RECORD_SIZE (MAX_UINT8)
|
||||||
|
|
||||||
|
//
|
||||||
|
// FPDT Record Types
|
||||||
|
//
|
||||||
|
#define FPDT_GUID_EVENT_TYPE 0x1010
|
||||||
|
#define FPDT_DYNAMIC_STRING_EVENT_TYPE 0x1011
|
||||||
|
#define FPDT_DUAL_GUID_STRING_EVENT_TYPE 0x1012
|
||||||
|
#define FPDT_GUID_QWORD_EVENT_TYPE 0x1013
|
||||||
|
#define FPDT_GUID_QWORD_STRING_EVENT_TYPE 0x1014
|
||||||
|
|
||||||
|
//
|
||||||
|
// EDKII extended Fpdt record structures
|
||||||
|
//
|
||||||
|
#define FPDT_STRING_EVENT_RECORD_NAME_LENGTH 24
|
||||||
|
|
||||||
|
#pragma pack(1)
|
||||||
|
//
|
||||||
|
// FPDT Boot Performance Guid Event Record Structure
|
||||||
|
//
|
||||||
|
typedef struct {
|
||||||
|
EFI_ACPI_5_0_FPDT_PERFORMANCE_RECORD_HEADER Header;
|
||||||
|
///
|
||||||
|
/// ProgressID < 0x10 are reserved for core performance entries.
|
||||||
|
/// Start measurement point shall have lowered one nibble set to zero and
|
||||||
|
/// corresponding end points shall have lowered one nibble set to non-zero value;
|
||||||
|
/// keeping other nibbles same as start point.
|
||||||
|
///
|
||||||
|
UINT16 ProgressID;
|
||||||
|
///
|
||||||
|
/// APIC ID for the processor in the system used as a timestamp clock source.
|
||||||
|
/// If only one timestamp clock source is used, this field is Reserved and populated as 0.
|
||||||
|
///
|
||||||
|
UINT32 ApicID;
|
||||||
|
///
|
||||||
|
/// 64-bit value (nanosecond) describing elapsed time since the most recent deassertion of processor reset.
|
||||||
|
///
|
||||||
|
UINT64 Timestamp;
|
||||||
|
///
|
||||||
|
/// If ProgressID < 0x10, GUID of the referenced module; otherwise, GUID of the module logging the event.
|
||||||
|
///
|
||||||
|
EFI_GUID Guid;
|
||||||
|
} FPDT_GUID_EVENT_RECORD;
|
||||||
|
|
||||||
|
//
|
||||||
|
// FPDT Boot Performance Dynamic String Event Record Structure
|
||||||
|
//
|
||||||
|
typedef struct {
|
||||||
|
EFI_ACPI_5_0_FPDT_PERFORMANCE_RECORD_HEADER Header;
|
||||||
|
///
|
||||||
|
/// ProgressID < 0x10 are reserved for core performance entries.
|
||||||
|
/// Start measurement point shall have lowered one nibble set to zero and
|
||||||
|
/// corresponding end points shall have lowered one nibble set to non-zero value;
|
||||||
|
/// keeping other nibbles same as start point.
|
||||||
|
///
|
||||||
|
UINT16 ProgressID;
|
||||||
|
///
|
||||||
|
/// APIC ID for the processor in the system used as a timestamp clock source.
|
||||||
|
/// If only one timestamp clock source is used, this field is Reserved and populated as 0.
|
||||||
|
///
|
||||||
|
UINT32 ApicID;
|
||||||
|
///
|
||||||
|
/// 64-bit value (nanosecond) describing elapsed time since the most recent deassertion of processor reset.
|
||||||
|
///
|
||||||
|
UINT64 Timestamp;
|
||||||
|
///
|
||||||
|
/// If ProgressID < 0x10, GUID of the referenced module; otherwise, GUID of the module logging the event.
|
||||||
|
///
|
||||||
|
EFI_GUID Guid;
|
||||||
|
///
|
||||||
|
/// ASCII string describing the module. Padding supplied at the end if necessary with null characters (0x00).
|
||||||
|
/// It may be module name, function name, or token name.
|
||||||
|
///
|
||||||
|
CHAR8 String[0];
|
||||||
|
} FPDT_DYNAMIC_STRING_EVENT_RECORD;
|
||||||
|
|
||||||
|
//
|
||||||
|
// FPDT Boot Performance Dual GUID String Event Record Structure
|
||||||
|
//
|
||||||
|
typedef struct {
|
||||||
|
EFI_ACPI_5_0_FPDT_PERFORMANCE_RECORD_HEADER Header;
|
||||||
|
///
|
||||||
|
/// ProgressID < 0x10 are reserved for core performance entries.
|
||||||
|
/// Start measurement point shall have lowered one nibble set to zero and
|
||||||
|
/// corresponding end points shall have lowered one nibble set to non-zero value;
|
||||||
|
/// keeping other nibbles same as start point.
|
||||||
|
///
|
||||||
|
UINT16 ProgressID;
|
||||||
|
///
|
||||||
|
/// APIC ID for the processor in the system used as a timestamp clock source.
|
||||||
|
/// If only one timestamp clock source is used, this field is Reserved and populated as 0.
|
||||||
|
///
|
||||||
|
UINT32 ApicID;
|
||||||
|
///
|
||||||
|
/// 64-bit value (nanosecond) describing elapsed time since the most recent deassertion of processor reset.
|
||||||
|
///
|
||||||
|
UINT64 Timestamp;
|
||||||
|
///
|
||||||
|
/// GUID of the module logging the event.
|
||||||
|
///
|
||||||
|
EFI_GUID Guid1;
|
||||||
|
///
|
||||||
|
/// Event or Ppi or Protocol GUID for Callback.
|
||||||
|
///
|
||||||
|
EFI_GUID Guid2;
|
||||||
|
///
|
||||||
|
/// ASCII string describing the module. Padding supplied at the end if necessary with null characters (0x00).
|
||||||
|
/// It is the function name.
|
||||||
|
///
|
||||||
|
CHAR8 String[0];
|
||||||
|
} FPDT_DUAL_GUID_STRING_EVENT_RECORD;
|
||||||
|
|
||||||
|
//
|
||||||
|
// FPDT Boot Performance GUID Qword Event Record Structure
|
||||||
|
//
|
||||||
|
typedef struct {
|
||||||
|
EFI_ACPI_5_0_FPDT_PERFORMANCE_RECORD_HEADER Header;
|
||||||
|
///
|
||||||
|
/// ProgressID < 0x10 are reserved for core performance entries.
|
||||||
|
/// Start measurement point shall have lowered one nibble set to zero and
|
||||||
|
/// corresponding end points shall have lowered one nibble set to non-zero value;
|
||||||
|
/// keeping other nibbles same as start point.
|
||||||
|
///
|
||||||
|
UINT16 ProgressID;
|
||||||
|
///
|
||||||
|
/// APIC ID for the processor in the system used as a timestamp clock source.
|
||||||
|
/// If only one timestamp clock source is used, this field is Reserved and populated as 0.
|
||||||
|
///
|
||||||
|
UINT32 ApicID;
|
||||||
|
///
|
||||||
|
/// 64-bit value (nanosecond) describing elapsed time since the most recent deassertion of processor reset.
|
||||||
|
///
|
||||||
|
UINT64 Timestamp;
|
||||||
|
///
|
||||||
|
/// GUID of the module logging the event
|
||||||
|
///
|
||||||
|
EFI_GUID Guid;
|
||||||
|
///
|
||||||
|
/// Qword of misc data, meaning depends on the ProgressId
|
||||||
|
///
|
||||||
|
UINT64 Qword;
|
||||||
|
} FPDT_GUID_QWORD_EVENT_RECORD;
|
||||||
|
|
||||||
|
//
|
||||||
|
// FPDT Boot Performance GUID Qword String Event Record Structure
|
||||||
|
//
|
||||||
|
typedef struct {
|
||||||
|
EFI_ACPI_5_0_FPDT_PERFORMANCE_RECORD_HEADER Header;
|
||||||
|
///
|
||||||
|
/// ProgressID < 0x10 are reserved for core performance entries.
|
||||||
|
/// Start measurement point shall have lowered one nibble set to zero and
|
||||||
|
/// corresponding end points shall have lowered one nibble set to non-zero value;
|
||||||
|
/// keeping other nibbles same as start point.
|
||||||
|
///
|
||||||
|
UINT16 ProgressID;
|
||||||
|
///
|
||||||
|
/// APIC ID for the processor in the system used as a timestamp clock source.
|
||||||
|
/// If only one timestamp clock source is used, this field is Reserved and populated as 0.
|
||||||
|
///
|
||||||
|
UINT32 ApicID;
|
||||||
|
///
|
||||||
|
/// 64-bit value (nanosecond) describing elapsed time since the most recent deassertion of processor reset.
|
||||||
|
///
|
||||||
|
UINT64 Timestamp;
|
||||||
|
///
|
||||||
|
/// GUID of the module logging the event
|
||||||
|
///
|
||||||
|
EFI_GUID Guid;
|
||||||
|
///
|
||||||
|
/// Qword of misc data, meaning depends on the ProgressId
|
||||||
|
///
|
||||||
|
UINT64 Qword;
|
||||||
|
///
|
||||||
|
/// ASCII string describing the module. Padding supplied at the end if necessary with null characters (0x00).
|
||||||
|
///
|
||||||
|
CHAR8 String[0];
|
||||||
|
} FPDT_GUID_QWORD_STRING_EVENT_RECORD;
|
||||||
|
|
||||||
|
#pragma pack()
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
UINT16 ProgressID;
|
||||||
|
UINT16 Type;
|
||||||
|
UINT8 RecordSize;
|
||||||
|
} FPDT_BASIC_RECORD_INFO;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Union of all FPDT records
|
||||||
|
//
|
||||||
|
typedef union {
|
||||||
|
EFI_ACPI_5_0_FPDT_PERFORMANCE_RECORD_HEADER RecordHeader;
|
||||||
|
FPDT_GUID_EVENT_RECORD GuidEvent;
|
||||||
|
FPDT_DYNAMIC_STRING_EVENT_RECORD DynamicStringEvent;
|
||||||
|
FPDT_DUAL_GUID_STRING_EVENT_RECORD DualGuidStringEvent;
|
||||||
|
FPDT_GUID_QWORD_EVENT_RECORD GuidQwordEvent;
|
||||||
|
FPDT_GUID_QWORD_STRING_EVENT_RECORD GuidQwordStringEvent;
|
||||||
|
} FPDT_RECORD;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Union of all pointers to FPDT records
|
||||||
|
//
|
||||||
|
typedef union {
|
||||||
|
EFI_ACPI_5_0_FPDT_PERFORMANCE_RECORD_HEADER *RecordHeader;
|
||||||
|
FPDT_GUID_EVENT_RECORD *GuidEvent;
|
||||||
|
FPDT_DYNAMIC_STRING_EVENT_RECORD *DynamicStringEvent;
|
||||||
|
FPDT_DUAL_GUID_STRING_EVENT_RECORD *DualGuidStringEvent;
|
||||||
|
FPDT_GUID_QWORD_EVENT_RECORD *GuidQwordEvent;
|
||||||
|
FPDT_GUID_QWORD_STRING_EVENT_RECORD *GuidQwordStringEvent;
|
||||||
|
} FPDT_RECORD_PTR;
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Hob:
|
||||||
|
/// GUID - gEdkiiFpdtExtendedFirmwarePerformanceGuid;
|
||||||
|
/// Data - FPDT_PEI_EXT_PERF_HEADER + one or more FPDT records
|
||||||
|
///
|
||||||
|
typedef struct {
|
||||||
|
UINT32 SizeOfAllEntries;
|
||||||
|
UINT32 LoadImageCount;
|
||||||
|
UINT32 HobIsFull;
|
||||||
|
} FPDT_PEI_EXT_PERF_HEADER;
|
||||||
|
|
||||||
|
extern EFI_GUID gEdkiiFpdtExtendedFirmwarePerformanceGuid;
|
||||||
|
|
||||||
|
#endif
|
@ -1,7 +1,7 @@
|
|||||||
/** @file
|
/** @file
|
||||||
ACPI Firmware Performance Data Table (FPDT) implementation specific definitions.
|
ACPI Firmware Performance Data Table (FPDT) implementation specific definitions.
|
||||||
|
|
||||||
Copyright (c) 2011 - 2016, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2011 - 2018, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
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
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
@ -94,6 +94,17 @@ typedef struct {
|
|||||||
//
|
//
|
||||||
} BOOT_PERFORMANCE_TABLE;
|
} BOOT_PERFORMANCE_TABLE;
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Boot performance table for the performance record in SMM phase.
|
||||||
|
///
|
||||||
|
///
|
||||||
|
typedef struct {
|
||||||
|
EFI_ACPI_5_0_FPDT_PERFORMANCE_TABLE_HEADER Header; ///< Common ACPI table header.
|
||||||
|
//
|
||||||
|
// one or more boot performance records.
|
||||||
|
//
|
||||||
|
} SMM_BOOT_PERFORMANCE_TABLE;
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Performance data pointed by Performance Pointer Record.
|
/// Performance data pointed by Performance Pointer Record.
|
||||||
///
|
///
|
||||||
|
@ -392,6 +392,9 @@
|
|||||||
## Include/Guid/PlatformHasAcpi.h
|
## Include/Guid/PlatformHasAcpi.h
|
||||||
gEdkiiPlatformHasAcpiGuid = { 0xf0966b41, 0xc23f, 0x41b9, { 0x96, 0x04, 0x0f, 0xf7, 0xe1, 0x11, 0x96, 0x5a } }
|
gEdkiiPlatformHasAcpiGuid = { 0xf0966b41, 0xc23f, 0x41b9, { 0x96, 0x04, 0x0f, 0xf7, 0xe1, 0x11, 0x96, 0x5a } }
|
||||||
|
|
||||||
|
## Include/Guid/ExtendedFirmwarePerformance.h
|
||||||
|
gEdkiiFpdtExtendedFirmwarePerformanceGuid = { 0x3b387bfd, 0x7abc, 0x4cf2, { 0xa0, 0xca, 0xb6, 0xa1, 0x6c, 0x1b, 0x1b, 0x25 } }
|
||||||
|
|
||||||
## Include/Guid/EndofS3Resume.h
|
## Include/Guid/EndofS3Resume.h
|
||||||
gEdkiiEndOfS3ResumeGuid = { 0x96f5296d, 0x05f7, 0x4f3c, {0x84, 0x67, 0xe4, 0x56, 0x89, 0x0e, 0x0c, 0xb5 } }
|
gEdkiiEndOfS3ResumeGuid = { 0x96f5296d, 0x05f7, 0x4f3c, {0x84, 0x67, 0xe4, 0x56, 0x89, 0x0e, 0x0c, 0xb5 } }
|
||||||
|
|
||||||
@ -1409,6 +1412,12 @@
|
|||||||
# @Prompt CapsuleMax value in capsule report variable.
|
# @Prompt CapsuleMax value in capsule report variable.
|
||||||
gEfiMdeModulePkgTokenSpaceGuid.PcdCapsuleMax|0xFFFF|UINT16|0x00000107
|
gEfiMdeModulePkgTokenSpaceGuid.PcdCapsuleMax|0xFFFF|UINT16|0x00000107
|
||||||
|
|
||||||
|
## Control which FPDT record format will be used to store the performance entry.
|
||||||
|
# On TRUE, the string FPDT record will be used to store every performance entry.
|
||||||
|
# On FALSE, the different FPDT record will be used to store the different performance entries.
|
||||||
|
# @Prompt String FPDT Record Enable Only
|
||||||
|
gEfiMdeModulePkgTokenSpaceGuid.PcdEdkiiFpdtStringRecordEnableOnly|FALSE|BOOLEAN|0x00000109
|
||||||
|
|
||||||
[PcdsPatchableInModule, PcdsDynamic, PcdsDynamicEx]
|
[PcdsPatchableInModule, PcdsDynamic, PcdsDynamicEx]
|
||||||
## This PCD defines the Console output row. The default value is 25 according to UEFI spec.
|
## This PCD defines the Console output row. The default value is 25 according to UEFI spec.
|
||||||
# This PCD could be set to 0 then console output would be at max column and max row.
|
# This PCD could be set to 0 then console output would be at max column and max row.
|
||||||
@ -1708,7 +1717,7 @@
|
|||||||
## This PCD specifies the additional pad size in FPDT Basic Boot Performance Table for
|
## This PCD specifies the additional pad size in FPDT Basic Boot Performance Table for
|
||||||
# the extension FPDT boot records received after ReadyToBoot and before ExitBootService.
|
# the extension FPDT boot records received after ReadyToBoot and before ExitBootService.
|
||||||
# @Prompt Pad size for extension FPDT boot records.
|
# @Prompt Pad size for extension FPDT boot records.
|
||||||
gEfiMdeModulePkgTokenSpaceGuid.PcdExtFpdtBootRecordPadSize|0x0|UINT32|0x0001005F
|
gEfiMdeModulePkgTokenSpaceGuid.PcdExtFpdtBootRecordPadSize|0x20000|UINT32|0x0001005F
|
||||||
|
|
||||||
## Indicates if ConIn device are connected on demand.<BR><BR>
|
## Indicates if ConIn device are connected on demand.<BR><BR>
|
||||||
# TRUE - ConIn device are not connected during BDS and ReadKeyStroke/ReadKeyStrokeEx produced
|
# TRUE - ConIn device are not connected during BDS and ReadKeyStroke/ReadKeyStrokeEx produced
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
// It also provides the definitions(including PPIs/PROTOCOLs/GUIDs and library classes)
|
// It also provides the definitions(including PPIs/PROTOCOLs/GUIDs and library classes)
|
||||||
// and libraries instances, which are used for those modules.
|
// and libraries instances, which are used for those modules.
|
||||||
//
|
//
|
||||||
// Copyright (c) 2007 - 2016, Intel Corporation. All rights reserved.<BR>
|
// Copyright (c) 2007 - 2018, Intel Corporation. All rights reserved.<BR>
|
||||||
//
|
//
|
||||||
// This program and the accompanying materials are licensed and made available under
|
// This program and the accompanying materials are licensed and made available under
|
||||||
// the terms and conditions of the BSD License that accompanies this distribution.
|
// the terms and conditions of the BSD License that accompanies this distribution.
|
||||||
@ -1232,3 +1232,9 @@
|
|||||||
#string STR_gEfiMdeModulePkgTokenSpaceGuid_PcdNvStoreDefaultValueBuffer_PROMPT #language en-US "NV Storage Default Value Buffer"
|
#string STR_gEfiMdeModulePkgTokenSpaceGuid_PcdNvStoreDefaultValueBuffer_PROMPT #language en-US "NV Storage Default Value Buffer"
|
||||||
|
|
||||||
#string STR_gEfiMdeModulePkgTokenSpaceGuid_PcdNvStoreDefaultValueBuffer_HELP #language en-US "This dynamic PCD holds the DynamicHii PCD value. Its value is the auto generated.\n"
|
#string STR_gEfiMdeModulePkgTokenSpaceGuid_PcdNvStoreDefaultValueBuffer_HELP #language en-US "This dynamic PCD holds the DynamicHii PCD value. Its value is the auto generated.\n"
|
||||||
|
|
||||||
|
#string STR_gEfiMdeModulePkgTokenSpaceGuid_PcdEdkiiFpdtStringRecordEnableOnly_PROMPT #language en-US "String FPDT Record Enable Only"
|
||||||
|
|
||||||
|
#string STR_gEfiMdeModulePkgTokenSpaceGuid_PcdEdkiiFpdtStringRecordEnableOnly_HELP #language en-US "Control which FPDT record format will be used to store the performance entry.\n"
|
||||||
|
"On TRUE, the string FPDT record will be used to store every performance entry.\n"
|
||||||
|
"On FALSE, the different FPDT record will be used to store the different performance entries."
|
||||||
|
Reference in New Issue
Block a user