mirror of https://github.com/acidanthera/audk.git
PerformancePkg Dp_App: Remove TimerLib dependency
Current Dp_App implementation depends on TimerLib, as different platforms may implement and use their own TimerLib, it makes the dp application needs to be built by platform. The TimerLib dependency can be removed by using performance property configuration table to make Dp_App to be generic. Cc: Andrew Fish <afish@apple.com> Cc: Michael Kinney <michael.d.kinney@intel.com> Cc: Liming Gao <liming.gao@intel.com> Cc: Jiewen Yao <jiewen.yao@intel.com> Cc: Cinnamon Shia <cinnamon.shia@hpe.com> Cc: Jaben Carsey <jaben.carsey@intel.com> Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Star Zeng <star.zeng@intel.com> Reviewed-by: Andrew Fish <afish@apple.com> Reviewed-by: Jaben Carsey <jaben.carsey@intel.com> Reviewed-by: Jiewen Yao <jiewen.yao@intel.com>
This commit is contained in:
parent
cfb0aba793
commit
139351093d
|
@ -13,7 +13,7 @@
|
||||||
Dp uses this information to group records in different ways. It also uses
|
Dp uses this information to group records in different ways. It also uses
|
||||||
timer information to calculate elapsed time for each measurement.
|
timer information to calculate elapsed time for each measurement.
|
||||||
|
|
||||||
Copyright (c) 2009 - 2016, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2009 - 2017, Intel Corporation. All rights reserved.<BR>
|
||||||
(C) Copyright 2015-2016 Hewlett Packard Enterprise Development LP<BR>
|
(C) Copyright 2015-2016 Hewlett Packard Enterprise Development LP<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
|
||||||
|
@ -30,7 +30,6 @@
|
||||||
#include <Library/BaseLib.h>
|
#include <Library/BaseLib.h>
|
||||||
#include <Library/MemoryAllocationLib.h>
|
#include <Library/MemoryAllocationLib.h>
|
||||||
#include <Library/DebugLib.h>
|
#include <Library/DebugLib.h>
|
||||||
#include <Library/TimerLib.h>
|
|
||||||
#include <Library/UefiLib.h>
|
#include <Library/UefiLib.h>
|
||||||
#include <Library/UefiHiiServicesLib.h>
|
#include <Library/UefiHiiServicesLib.h>
|
||||||
#include <Library/HiiLib.h>
|
#include <Library/HiiLib.h>
|
||||||
|
@ -201,8 +200,7 @@ InitializeDp (
|
||||||
IN EFI_SYSTEM_TABLE *SystemTable
|
IN EFI_SYSTEM_TABLE *SystemTable
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
UINT64 Freq;
|
PERFORMANCE_PROPERTY *PerformanceProperty;
|
||||||
UINT64 Ticker;
|
|
||||||
UINT32 ListIndex;
|
UINT32 ListIndex;
|
||||||
|
|
||||||
LIST_ENTRY *ParamPackage;
|
LIST_ENTRY *ParamPackage;
|
||||||
|
@ -267,11 +265,6 @@ InitializeDp (
|
||||||
StringDpOptionLc = NULL;
|
StringDpOptionLc = NULL;
|
||||||
StringPtr = NULL;
|
StringPtr = NULL;
|
||||||
|
|
||||||
// Get DP's entry time as soon as possible.
|
|
||||||
// This is used as the Shell-Phase end time.
|
|
||||||
//
|
|
||||||
Ticker = GetPerformanceCounter ();
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Retrieve HII package list from ImageHandle
|
// Retrieve HII package list from ImageHandle
|
||||||
//
|
//
|
||||||
|
@ -406,10 +399,16 @@ InitializeDp (
|
||||||
// StartCount = Value loaded into the counter when it starts counting
|
// StartCount = Value loaded into the counter when it starts counting
|
||||||
// EndCount = Value counter counts to before it needs to be reset
|
// EndCount = Value counter counts to before it needs to be reset
|
||||||
//
|
//
|
||||||
Freq = GetPerformanceCounterProperties (&TimerInfo.StartCount, &TimerInfo.EndCount);
|
Status = EfiGetSystemConfigurationTable (&gPerformanceProtocolGuid, &PerformanceProperty);
|
||||||
|
if (EFI_ERROR (Status)) {
|
||||||
|
PrintToken (STRING_TOKEN (STR_PERF_PROPERTY_NOT_FOUND));
|
||||||
|
goto Done;
|
||||||
|
}
|
||||||
|
|
||||||
// Convert the Frequency from Hz to KHz
|
// Convert the Frequency from Hz to KHz
|
||||||
TimerInfo.Frequency = (UINT32)DivU64x32 (Freq, 1000);
|
TimerInfo.Frequency = (UINT32)DivU64x32 (PerformanceProperty->Frequency, 1000);
|
||||||
|
TimerInfo.StartCount = PerformanceProperty->TimerStartValue;
|
||||||
|
TimerInfo.EndCount = PerformanceProperty->TimerEndValue;
|
||||||
|
|
||||||
// Determine in which direction the performance counter counts.
|
// Determine in which direction the performance counter counts.
|
||||||
TimerInfo.CountUp = (BOOLEAN) (TimerInfo.EndCount >= TimerInfo.StartCount);
|
TimerInfo.CountUp = (BOOLEAN) (TimerInfo.EndCount >= TimerInfo.StartCount);
|
||||||
|
@ -487,7 +486,7 @@ InitializeDp (
|
||||||
else {
|
else {
|
||||||
//------------- Begin Cooked Mode Processing
|
//------------- Begin Cooked Mode Processing
|
||||||
if (TraceMode) {
|
if (TraceMode) {
|
||||||
ProcessPhases ( Ticker );
|
ProcessPhases ();
|
||||||
if ( ! SummaryMode) {
|
if ( ! SummaryMode) {
|
||||||
Status = ProcessHandles ( ExcludeMode);
|
Status = ProcessHandles ( ExcludeMode);
|
||||||
if (Status == EFI_ABORTED) {
|
if (Status == EFI_ABORTED) {
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
## @file
|
## @file
|
||||||
# Display Performance Application, Module information file.
|
# Display Performance Application, Module information file.
|
||||||
#
|
#
|
||||||
# Copyright (c) 2009 - 2016, Intel Corporation. All rights reserved.<BR>
|
# Copyright (c) 2009 - 2017, 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
|
||||||
|
@ -56,7 +56,6 @@
|
||||||
MemoryAllocationLib
|
MemoryAllocationLib
|
||||||
DebugLib
|
DebugLib
|
||||||
UefiBootServicesTableLib
|
UefiBootServicesTableLib
|
||||||
TimerLib
|
|
||||||
PeCoffGetEntryPointLib
|
PeCoffGetEntryPointLib
|
||||||
PerformanceLib
|
PerformanceLib
|
||||||
PrintLib
|
PrintLib
|
||||||
|
@ -67,6 +66,9 @@
|
||||||
DevicePathLib
|
DevicePathLib
|
||||||
DxeServicesLib
|
DxeServicesLib
|
||||||
|
|
||||||
|
[Guids]
|
||||||
|
gPerformanceProtocolGuid ## CONSUMES ## SystemTable
|
||||||
|
|
||||||
[Protocols]
|
[Protocols]
|
||||||
gEfiLoadedImageProtocolGuid ## CONSUMES
|
gEfiLoadedImageProtocolGuid ## CONSUMES
|
||||||
gEfiHiiPackageListProtocolGuid ## CONSUMES
|
gEfiHiiPackageListProtocolGuid ## CONSUMES
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
Dp application. In addition to global data, function declarations for
|
Dp application. In addition to global data, function declarations for
|
||||||
DpUtilities.c, DpTrace.c, and DpProfile.c are included here.
|
DpUtilities.c, DpTrace.c, and DpProfile.c are included here.
|
||||||
|
|
||||||
Copyright (c) 2009 - 2014, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2009 - 2017, Intel Corporation. All rights reserved.<BR>
|
||||||
(C) Copyright 2015-2016 Hewlett Packard Enterprise Development LP<BR>
|
(C) Copyright 2015-2016 Hewlett Packard Enterprise Development LP<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
|
||||||
|
@ -254,12 +254,10 @@ DumpRawTrace(
|
||||||
/**
|
/**
|
||||||
Gather and print Major Phase metrics.
|
Gather and print Major Phase metrics.
|
||||||
|
|
||||||
@param[in] Ticker The timer value for the END of Shell phase
|
|
||||||
|
|
||||||
**/
|
**/
|
||||||
VOID
|
VOID
|
||||||
ProcessPhases(
|
ProcessPhases(
|
||||||
IN UINT64 Ticker
|
VOID
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
Measured Profiling reporting for the Dp utility.
|
Measured Profiling reporting for the Dp utility.
|
||||||
|
|
||||||
Copyright (c) 2009 - 2010, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2009 - 2017, 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
|
||||||
|
@ -16,7 +16,6 @@
|
||||||
#include <Library/MemoryAllocationLib.h>
|
#include <Library/MemoryAllocationLib.h>
|
||||||
#include <Library/DebugLib.h>
|
#include <Library/DebugLib.h>
|
||||||
#include <Library/UefiBootServicesTableLib.h>
|
#include <Library/UefiBootServicesTableLib.h>
|
||||||
#include <Library/TimerLib.h>
|
|
||||||
#include <Library/PeCoffGetEntryPointLib.h>
|
#include <Library/PeCoffGetEntryPointLib.h>
|
||||||
#include <Library/PerformanceLib.h>
|
#include <Library/PerformanceLib.h>
|
||||||
#include <Library/PrintLib.h>
|
#include <Library/PrintLib.h>
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
// *++
|
// *++
|
||||||
//
|
//
|
||||||
// Copyright (c) 2009 - 2016, Intel Corporation. All rights reserved.<BR>
|
// Copyright (c) 2009 - 2017, Intel Corporation. All rights reserved.<BR>
|
||||||
// (C) Copyright 2015 Hewlett Packard Enterprise Development LP<BR>
|
// (C) Copyright 2015 Hewlett Packard Enterprise Development LP<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
|
||||||
|
@ -137,6 +137,8 @@
|
||||||
#language fr-FR "Localiser Toute erreur de Poignées - %r\n"
|
#language fr-FR "Localiser Toute erreur de Poignées - %r\n"
|
||||||
#string STR_DP_ERROR_NAME #language en-US "Unknown Driver Name"
|
#string STR_DP_ERROR_NAME #language en-US "Unknown Driver Name"
|
||||||
#language fr-FR "Unknown Driver Name"
|
#language fr-FR "Unknown Driver Name"
|
||||||
|
#string STR_PERF_PROPERTY_NOT_FOUND #language en-US "Performance property not found\n"
|
||||||
|
#language fr-FR "Performance property not found\n"
|
||||||
#string STR_DP_BUILD_REVISION #language en-US "\nDP Build Version: %d.%d\n"
|
#string STR_DP_BUILD_REVISION #language en-US "\nDP Build Version: %d.%d\n"
|
||||||
#language fr-FR "\nDP Construit la Version: %d,%d\n"
|
#language fr-FR "\nDP Construit la Version: %d,%d\n"
|
||||||
#string STR_DP_KHZ #language en-US "System Performance Timer Frequency: %,8d (KHz)\n"
|
#string STR_DP_KHZ #language en-US "System Performance Timer Frequency: %,8d (KHz)\n"
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
Trace reporting for the Dp utility.
|
Trace reporting for the Dp utility.
|
||||||
|
|
||||||
Copyright (c) 2009 - 2016, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2009 - 2017, Intel Corporation. All rights reserved.<BR>
|
||||||
(C) Copyright 2015-2016 Hewlett Packard Enterprise Development LP<BR>
|
(C) Copyright 2015-2016 Hewlett Packard Enterprise Development LP<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
|
||||||
|
@ -17,7 +17,6 @@
|
||||||
#include <Library/MemoryAllocationLib.h>
|
#include <Library/MemoryAllocationLib.h>
|
||||||
#include <Library/DebugLib.h>
|
#include <Library/DebugLib.h>
|
||||||
#include <Library/UefiBootServicesTableLib.h>
|
#include <Library/UefiBootServicesTableLib.h>
|
||||||
#include <Library/TimerLib.h>
|
|
||||||
#include <Library/PeCoffGetEntryPointLib.h>
|
#include <Library/PeCoffGetEntryPointLib.h>
|
||||||
#include <Library/PerformanceLib.h>
|
#include <Library/PerformanceLib.h>
|
||||||
#include <Library/PrintLib.h>
|
#include <Library/PrintLib.h>
|
||||||
|
@ -385,12 +384,10 @@ DumpRawTrace(
|
||||||
/**
|
/**
|
||||||
Gather and print Major Phase metrics.
|
Gather and print Major Phase metrics.
|
||||||
|
|
||||||
@param[in] Ticker The timer value for the END of Shell phase
|
|
||||||
|
|
||||||
**/
|
**/
|
||||||
VOID
|
VOID
|
||||||
ProcessPhases(
|
ProcessPhases(
|
||||||
IN UINT64 Ticker
|
VOID
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
MEASUREMENT_RECORD Measurement;
|
MEASUREMENT_RECORD Measurement;
|
||||||
|
@ -399,7 +396,6 @@ ProcessPhases(
|
||||||
UINT64 PeiTime;
|
UINT64 PeiTime;
|
||||||
UINT64 DxeTime;
|
UINT64 DxeTime;
|
||||||
UINT64 BdsTime;
|
UINT64 BdsTime;
|
||||||
UINT64 ShellTime;
|
|
||||||
UINT64 ElapsedTime;
|
UINT64 ElapsedTime;
|
||||||
UINT64 Duration;
|
UINT64 Duration;
|
||||||
UINT64 Total;
|
UINT64 Total;
|
||||||
|
@ -412,7 +408,6 @@ ProcessPhases(
|
||||||
PeiTime = 0;
|
PeiTime = 0;
|
||||||
DxeTime = 0;
|
DxeTime = 0;
|
||||||
BdsTime = 0;
|
BdsTime = 0;
|
||||||
ShellTime = 0;
|
|
||||||
//
|
//
|
||||||
// Get Execution Phase Statistics
|
// Get Execution Phase Statistics
|
||||||
//
|
//
|
||||||
|
@ -433,9 +428,6 @@ ProcessPhases(
|
||||||
&Measurement.EndTimeStamp,
|
&Measurement.EndTimeStamp,
|
||||||
&Measurement.Identifier)) != 0)
|
&Measurement.Identifier)) != 0)
|
||||||
{
|
{
|
||||||
if (AsciiStrnCmp (Measurement.Token, ALit_SHELL, PERF_TOKEN_LENGTH) == 0) {
|
|
||||||
Measurement.EndTimeStamp = Ticker;
|
|
||||||
}
|
|
||||||
if (Measurement.EndTimeStamp == 0) { // Skip "incomplete" records
|
if (Measurement.EndTimeStamp == 0) { // Skip "incomplete" records
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -453,8 +445,6 @@ ProcessPhases(
|
||||||
DxeTime = Duration;
|
DxeTime = Duration;
|
||||||
} else if (AsciiStrnCmp (Measurement.Token, ALit_BDS, PERF_TOKEN_LENGTH) == 0) {
|
} else if (AsciiStrnCmp (Measurement.Token, ALit_BDS, PERF_TOKEN_LENGTH) == 0) {
|
||||||
BdsTime = Duration;
|
BdsTime = Duration;
|
||||||
} else if (AsciiStrnCmp (Measurement.Token, ALit_SHELL, PERF_TOKEN_LENGTH) == 0) {
|
|
||||||
ShellTime = Duration;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -509,17 +499,6 @@ ProcessPhases(
|
||||||
PrintToken (STRING_TOKEN (STR_DP_PHASE_BDSTO), ALit_BdsTO, ElapsedTime);
|
PrintToken (STRING_TOKEN (STR_DP_PHASE_BDSTO), ALit_BdsTO, ElapsedTime);
|
||||||
}
|
}
|
||||||
|
|
||||||
// print SHELL phase duration time
|
|
||||||
//
|
|
||||||
if (ShellTime > 0) {
|
|
||||||
ElapsedTime = DivU64x32 (
|
|
||||||
ShellTime,
|
|
||||||
(UINT32)TimerInfo.Frequency
|
|
||||||
);
|
|
||||||
Total += ElapsedTime;
|
|
||||||
PrintToken (STRING_TOKEN (STR_DP_PHASE_DURATION), ALit_SHELL, ElapsedTime);
|
|
||||||
}
|
|
||||||
|
|
||||||
PrintToken (STRING_TOKEN (STR_DP_TOTAL_DURATION), Total);
|
PrintToken (STRING_TOKEN (STR_DP_TOTAL_DURATION), Total);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
Utility functions used by the Dp application.
|
Utility functions used by the Dp application.
|
||||||
|
|
||||||
Copyright (c) 2009 - 2016, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2009 - 2017, Intel Corporation. All rights reserved.<BR>
|
||||||
(C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR>
|
(C) Copyright 2016 Hewlett Packard Enterprise Development LP<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
|
||||||
|
@ -17,7 +17,6 @@
|
||||||
#include <Library/MemoryAllocationLib.h>
|
#include <Library/MemoryAllocationLib.h>
|
||||||
#include <Library/DebugLib.h>
|
#include <Library/DebugLib.h>
|
||||||
#include <Library/UefiBootServicesTableLib.h>
|
#include <Library/UefiBootServicesTableLib.h>
|
||||||
#include <Library/TimerLib.h>
|
|
||||||
#include <Library/PeCoffGetEntryPointLib.h>
|
#include <Library/PeCoffGetEntryPointLib.h>
|
||||||
#include <Library/PrintLib.h>
|
#include <Library/PrintLib.h>
|
||||||
#include <Library/HiiLib.h>
|
#include <Library/HiiLib.h>
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
Definitions of ASCII string literals used by DP.
|
Definitions of ASCII string literals used by DP.
|
||||||
|
|
||||||
Copyright (c) 2009 - 2010, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2009 - 2017, 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
|
||||||
|
@ -16,7 +16,6 @@
|
||||||
CHAR8 const ALit_TimerLibError[] = "Timer library instance error!\n";
|
CHAR8 const ALit_TimerLibError[] = "Timer library instance error!\n";
|
||||||
CHAR8 const ALit_SEC[] = SEC_TOK;
|
CHAR8 const ALit_SEC[] = SEC_TOK;
|
||||||
CHAR8 const ALit_DXE[] = DXE_TOK;
|
CHAR8 const ALit_DXE[] = DXE_TOK;
|
||||||
CHAR8 const ALit_SHELL[] = SHELL_TOK;
|
|
||||||
CHAR8 const ALit_PEI[] = PEI_TOK;
|
CHAR8 const ALit_PEI[] = PEI_TOK;
|
||||||
CHAR8 const ALit_BDS[] = BDS_TOK;
|
CHAR8 const ALit_BDS[] = BDS_TOK;
|
||||||
CHAR8 const ALit_BdsTO[] = "BdsTimeOut";
|
CHAR8 const ALit_BdsTO[] = "BdsTimeOut";
|
||||||
|
|
Loading…
Reference in New Issue