Dp uses this information to group records in different ways. It also uses\r
timer information to calculate elapsed time for each measurement.\r
\r
- Copyright (c) 2009 - 2011, Intel Corporation. All rights reserved.<BR>\r
+ Copyright (c) 2009 - 2012, Intel Corporation. All rights reserved.<BR>\r
This program and the accompanying materials\r
are licensed and made available under the terms and conditions of the BSD License\r
which accompanies this distribution. The full text of the license may be found at\r
CHAR16 mGaugeString[DP_GAUGE_STRING_LENGTH + 1];\r
CHAR16 mUnicodeToken[DXE_PERFORMANCE_STRING_SIZE];\r
UINT64 mInterestThreshold;\r
+BOOLEAN mShowId = FALSE;\r
\r
PERF_SUMMARY_DATA SummaryData = { 0 }; ///< Create the SummaryData structure and init. to ZERO.\r
\r
{STRING_TOKEN (STR_DP_OPTION_UT), TypeFlag}, // -T Dump Trace Data\r
#endif\r
{STRING_TOKEN (STR_DP_OPTION_LX), TypeFlag}, // -x eXclude Cumulative Items\r
+ {STRING_TOKEN (STR_DP_OPTION_LI), TypeFlag}, // -i Display Identifier\r
{STRING_TOKEN (STR_DP_OPTION_LN), TypeValue}, // -n # Number of records to display for A and R\r
{STRING_TOKEN (STR_DP_OPTION_LT), TypeValue} // -t # Threshold of interest\r
};\r
#endif // PROFILING_IMPLEMENTED\r
PrintToken (STRING_TOKEN (STR_DP_HELP_THRESHOLD));\r
PrintToken (STRING_TOKEN (STR_DP_HELP_COUNT));\r
+ PrintToken (STRING_TOKEN (STR_DP_HELP_ID));\r
PrintToken (STRING_TOKEN (STR_DP_HELP_HELP));\r
Print(L"\n");\r
}\r
EFI_STRING StringDpOptionLx;\r
EFI_STRING StringDpOptionLn;\r
EFI_STRING StringDpOptionLt;\r
+ EFI_STRING StringDpOptionLi;\r
\r
SummaryMode = FALSE;\r
VerboseMode = FALSE;\r
StringDpOptionLx = NULL;\r
StringDpOptionLn = NULL;\r
StringDpOptionLt = NULL;\r
+ StringDpOptionLi = NULL;\r
StringPtr = NULL;\r
\r
// Get DP's entry time as soon as possible.\r
StringDpOptionLx = HiiGetString (gHiiHandle, STRING_TOKEN (STR_DP_OPTION_LX), NULL);\r
StringDpOptionLn = HiiGetString (gHiiHandle, STRING_TOKEN (STR_DP_OPTION_LN), NULL);\r
StringDpOptionLt = HiiGetString (gHiiHandle, STRING_TOKEN (STR_DP_OPTION_LT), NULL);\r
+ StringDpOptionLi = HiiGetString (gHiiHandle, STRING_TOKEN (STR_DP_OPTION_LI), NULL);\r
\r
// Boolean Options\r
// \r
ProfileMode = ShellCommandLineGetFlag (ParamPackage, StringDpOptionUp);\r
#endif // PROFILING_IMPLEMENTED\r
ExcludeMode = ShellCommandLineGetFlag (ParamPackage, StringDpOptionLx);\r
+ mShowId = ShellCommandLineGetFlag (ParamPackage, StringDpOptionLi);\r
\r
// Options with Values\r
CmdLineArg = ShellCommandLineGetValue (ParamPackage, StringDpOptionLn);\r
SafeFreePool (StringDpOptionLx);\r
SafeFreePool (StringDpOptionLn);\r
SafeFreePool (StringDpOptionLt);\r
+ SafeFreePool (StringDpOptionLi);\r
SafeFreePool (StringPtr);\r
SafeFreePool (mPrintTokenBuffer);\r
\r
/** @file\r
Trace reporting for the Dp utility.\r
\r
- Copyright (c) 2009 - 2011, Intel Corporation. All rights reserved.<BR>\r
+ Copyright (c) 2009 - 2012, Intel Corporation. All rights reserved.<BR>\r
This program and the accompanying materials\r
are licensed and made available under the terms and conditions of the BSD License\r
which accompanies this distribution. The full text of the license may be found at\r
INTN TIndex;\r
\r
LogEntryKey = 0;\r
- while ((LogEntryKey = GetPerformanceMeasurement (\r
+ while ((LogEntryKey = GetPerformanceMeasurementEx (\r
LogEntryKey,\r
&Measurement.Handle,\r
&Measurement.Token,\r
&Measurement.Module,\r
&Measurement.StartTimeStamp,\r
- &Measurement.EndTimeStamp)) != 0)\r
+ &Measurement.EndTimeStamp,\r
+ &Measurement.Identifier)) != 0)\r
{\r
++SummaryData.NumTrace; // Count the number of TRACE Measurement records\r
if (Measurement.EndTimeStamp == 0) {\r
// Display only records with Elapsed times >= mInterestThreshold\r
// Display driver names in Module field for records with Handles.\r
//\r
- PrintToken (STRING_TOKEN (STR_DP_ALL_HEADR) );\r
- PrintToken (STRING_TOKEN (STR_DP_DASHES) );\r
+ if (mShowId) {\r
+ PrintToken (STRING_TOKEN (STR_DP_ALL_HEADR2) );\r
+ PrintToken (STRING_TOKEN (STR_DP_ALL_DASHES2) );\r
+ } else {\r
+ PrintToken (STRING_TOKEN (STR_DP_ALL_HEADR) );\r
+ PrintToken (STRING_TOKEN (STR_DP_DASHES) );\r
+ }\r
\r
LogEntryKey = 0;\r
Count = 0;\r
Index = 0;\r
while ( WITHIN_LIMIT(Count, Limit) &&\r
- ((LogEntryKey = GetPerformanceMeasurement (\r
+ ((LogEntryKey = GetPerformanceMeasurementEx (\r
LogEntryKey,\r
&Measurement.Handle,\r
&Measurement.Token,\r
&Measurement.Module,\r
&Measurement.StartTimeStamp,\r
- &Measurement.EndTimeStamp)) != 0)\r
+ &Measurement.EndTimeStamp,\r
+ &Measurement.Identifier)) != 0)\r
)\r
{\r
++Index; // Count every record. First record is 1.\r
ElapsedTime = 0;\r
- if (IncFlag != NULL) {\r
- FreePool ((void *)IncFlag);\r
- }\r
+ SafeFreePool ((VOID *) IncFlag);\r
if (Measurement.EndTimeStamp != 0) {\r
Duration = GetDuration (&Measurement);\r
ElapsedTime = DurationInMicroSeconds ( Duration );\r
mGaugeString[DP_GAUGE_STRING_LENGTH] = 0;\r
mUnicodeToken[13] = 0;\r
\r
- PrintToken( STRING_TOKEN (STR_DP_ALL_VARS),\r
- Index, // 1 based, Which measurement record is being printed\r
- IncFlag,\r
- Measurement.Handle,\r
- mGaugeString,\r
- mUnicodeToken,\r
- ElapsedTime\r
- );\r
+ if (mShowId) {\r
+ PrintToken( STRING_TOKEN (STR_DP_ALL_VARS2),\r
+ Index, // 1 based, Which measurement record is being printed\r
+ IncFlag,\r
+ Measurement.Handle,\r
+ mGaugeString,\r
+ mUnicodeToken,\r
+ ElapsedTime,\r
+ Measurement.Identifier\r
+ );\r
+ } else {\r
+ PrintToken( STRING_TOKEN (STR_DP_ALL_VARS),\r
+ Index, // 1 based, Which measurement record is being printed\r
+ IncFlag,\r
+ Measurement.Handle,\r
+ mGaugeString,\r
+ mUnicodeToken,\r
+ ElapsedTime\r
+ );\r
+ }\r
}\r
}\r
if (HandleBuffer != &TempHandle) {\r
FreePool (HandleBuffer);\r
}\r
- FreePool ((void *)IncFlag);\r
+ SafeFreePool ((VOID *) IncFlag);\r
}\r
\r
/** \r
FreePool (StringPtr);\r
FreePool (StringPtrUnknown);\r
\r
- PrintToken (STRING_TOKEN (STR_DP_RAW_HEADR) );\r
- PrintToken (STRING_TOKEN (STR_DP_RAW_DASHES) );\r
+ if (mShowId) {\r
+ PrintToken (STRING_TOKEN (STR_DP_RAW_HEADR2) );\r
+ PrintToken (STRING_TOKEN (STR_DP_RAW_DASHES2) );\r
+ } else {\r
+ PrintToken (STRING_TOKEN (STR_DP_RAW_HEADR) );\r
+ PrintToken (STRING_TOKEN (STR_DP_RAW_DASHES) );\r
+ }\r
\r
LogEntryKey = 0;\r
Count = 0;\r
Index = 0;\r
while ( WITHIN_LIMIT(Count, Limit) &&\r
- ((LogEntryKey = GetPerformanceMeasurement (\r
+ ((LogEntryKey = GetPerformanceMeasurementEx (\r
LogEntryKey,\r
&Measurement.Handle,\r
&Measurement.Token,\r
&Measurement.Module,\r
&Measurement.StartTimeStamp,\r
- &Measurement.EndTimeStamp)) != 0)\r
+ &Measurement.EndTimeStamp,\r
+ &Measurement.Identifier)) != 0)\r
)\r
{\r
++Index; // Count every record. First record is 1.\r
continue;\r
}\r
++Count; // Count the number of records printed\r
- PrintToken (STRING_TOKEN (STR_DP_RAW_VARS),\r
- Index, // 1 based, Which measurement record is being printed\r
- Measurement.Handle,\r
- Measurement.StartTimeStamp,\r
- Measurement.EndTimeStamp,\r
- Measurement.Token,\r
- Measurement.Module\r
- );\r
+\r
+ if (mShowId) {\r
+ PrintToken (STRING_TOKEN (STR_DP_RAW_VARS2),\r
+ Index, // 1 based, Which measurement record is being printed\r
+ Measurement.Handle,\r
+ Measurement.StartTimeStamp,\r
+ Measurement.EndTimeStamp,\r
+ Measurement.Token,\r
+ Measurement.Module,\r
+ Measurement.Identifier\r
+ );\r
+ } else {\r
+ PrintToken (STRING_TOKEN (STR_DP_RAW_VARS),\r
+ Index, // 1 based, Which measurement record is being printed\r
+ Measurement.Handle,\r
+ Measurement.StartTimeStamp,\r
+ Measurement.EndTimeStamp,\r
+ Measurement.Token,\r
+ Measurement.Module\r
+ );\r
+ }\r
}\r
}\r
\r
FreePool (StringPtrUnknown);\r
\r
LogEntryKey = 0;\r
- while ((LogEntryKey = GetPerformanceMeasurement (\r
+ while ((LogEntryKey = GetPerformanceMeasurementEx (\r
LogEntryKey,\r
&Measurement.Handle,\r
&Measurement.Token,\r
&Measurement.Module,\r
&Measurement.StartTimeStamp,\r
- &Measurement.EndTimeStamp)) != 0)\r
+ &Measurement.EndTimeStamp,\r
+ &Measurement.Identifier)) != 0)\r
{\r
if (AsciiStrnCmp (Measurement.Token, ALit_SHELL, PERF_TOKEN_LENGTH) == 0) {\r
Measurement.EndTimeStamp = Ticker;\r
Print (L"There are %,d Handles defined.\n", (Size / sizeof(HandleBuffer[0])));\r
#endif\r
\r
- PrintToken (STRING_TOKEN (STR_DP_HANDLE_SECTION) );\r
+ if (mShowId) {\r
+ PrintToken (STRING_TOKEN (STR_DP_HANDLE_SECTION2) );\r
+ } else {\r
+ PrintToken (STRING_TOKEN (STR_DP_HANDLE_SECTION) );\r
+ }\r
PrintToken (STRING_TOKEN (STR_DP_DASHES) );\r
\r
LogEntryKey = 0;\r
Count = 0;\r
- while ((LogEntryKey = GetPerformanceMeasurement (\r
+ while ((LogEntryKey = GetPerformanceMeasurementEx (\r
LogEntryKey,\r
&Measurement.Handle,\r
&Measurement.Token,\r
&Measurement.Module,\r
&Measurement.StartTimeStamp,\r
- &Measurement.EndTimeStamp)) != 0)\r
+ &Measurement.EndTimeStamp,\r
+ &Measurement.Identifier)) != 0)\r
{\r
Count++;\r
Duration = GetDuration (&Measurement);\r
mUnicodeToken[11] = 0;\r
if (mGaugeString[0] != 0) {\r
// Display the record if it has a valid handle.\r
- PrintToken (\r
- STRING_TOKEN (STR_DP_HANDLE_VARS),\r
- Count, // 1 based, Which measurement record is being printed\r
- Index + 1, // 1 based, Which handle is being printed\r
- mGaugeString,\r
- mUnicodeToken,\r
- ElapsedTime\r
- );\r
+ if (mShowId) {\r
+ PrintToken (\r
+ STRING_TOKEN (STR_DP_HANDLE_VARS2),\r
+ Count, // 1 based, Which measurement record is being printed\r
+ Index + 1, // 1 based, Which handle is being printed\r
+ mGaugeString,\r
+ mUnicodeToken,\r
+ ElapsedTime,\r
+ Measurement.Identifier\r
+ );\r
+ } else {\r
+ PrintToken (\r
+ STRING_TOKEN (STR_DP_HANDLE_VARS),\r
+ Count, // 1 based, Which measurement record is being printed\r
+ Index + 1, // 1 based, Which handle is being printed\r
+ mGaugeString,\r
+ mUnicodeToken,\r
+ ElapsedTime\r
+ );\r
+ }\r
}\r
}\r
}\r
FreePool (StringPtr);\r
FreePool (StringPtrUnknown);\r
\r
- PrintToken (STRING_TOKEN (STR_DP_PEIM_SECTION));\r
+ if (mShowId) {\r
+ PrintToken (STRING_TOKEN (STR_DP_PEIM_SECTION2));\r
+ } else {\r
+ PrintToken (STRING_TOKEN (STR_DP_PEIM_SECTION));\r
+ }\r
PrintToken (STRING_TOKEN (STR_DP_DASHES));\r
TIndex = 0;\r
LogEntryKey = 0;\r
- while ((LogEntryKey = GetPerformanceMeasurement (\r
+ while ((LogEntryKey = GetPerformanceMeasurementEx (\r
LogEntryKey,\r
&Measurement.Handle,\r
&Measurement.Token,\r
&Measurement.Module,\r
&Measurement.StartTimeStamp,\r
- &Measurement.EndTimeStamp)) != 0)\r
+ &Measurement.EndTimeStamp,\r
+ &Measurement.Identifier)) != 0)\r
{\r
TIndex++;\r
if ((Measurement.EndTimeStamp == 0) ||\r
ElapsedTime = DurationInMicroSeconds ( Duration ); // Calculate elapsed time in microseconds\r
if (ElapsedTime >= mInterestThreshold) {\r
// PEIM FILE Handle is the start address of its FFS file that contains its file guid.\r
- PrintToken (STRING_TOKEN (STR_DP_PEIM_VARS),\r
- TIndex, // 1 based, Which measurement record is being printed\r
- Measurement.Handle, // base address\r
- Measurement.Handle, // file guid\r
- ElapsedTime\r
- );\r
+ if (mShowId) {\r
+ PrintToken (STRING_TOKEN (STR_DP_PEIM_VARS2),\r
+ TIndex, // 1 based, Which measurement record is being printed\r
+ Measurement.Handle, // base address\r
+ Measurement.Handle, // file guid\r
+ ElapsedTime,\r
+ Measurement.Identifier\r
+ );\r
+ } else {\r
+ PrintToken (STRING_TOKEN (STR_DP_PEIM_VARS),\r
+ TIndex, // 1 based, Which measurement record is being printed\r
+ Measurement.Handle, // base address\r
+ Measurement.Handle, // file guid\r
+ ElapsedTime\r
+ );\r
+ }\r
}\r
}\r
}\r
FreePool (StringPtr);\r
FreePool (StringPtrUnknown);\r
\r
- PrintToken (STRING_TOKEN (STR_DP_GLOBAL_SECTION));\r
+ if (mShowId) {\r
+ PrintToken (STRING_TOKEN (STR_DP_GLOBAL_SECTION2));\r
+ } else {\r
+ PrintToken (STRING_TOKEN (STR_DP_GLOBAL_SECTION));\r
+ }\r
PrintToken (STRING_TOKEN (STR_DP_DASHES));\r
\r
Index = 1;\r
LogEntryKey = 0;\r
\r
- while ((LogEntryKey = GetPerformanceMeasurement (\r
+ while ((LogEntryKey = GetPerformanceMeasurementEx (\r
LogEntryKey,\r
&Measurement.Handle,\r
&Measurement.Token,\r
&Measurement.Module,\r
&Measurement.StartTimeStamp,\r
- &Measurement.EndTimeStamp)) != 0)\r
+ &Measurement.EndTimeStamp,\r
+ &Measurement.Identifier)) != 0)\r
{\r
AsciiStrToUnicodeStr (Measurement.Module, mGaugeString);\r
AsciiStrToUnicodeStr (Measurement.Token, mUnicodeToken);\r
- mGaugeString[26] = 0;\r
+ mGaugeString[25] = 0;\r
mUnicodeToken[31] = 0;\r
if ( ! ( IsPhase( &Measurement) ||\r
(Measurement.Handle != NULL) ||\r
Duration = GetDuration (&Measurement);\r
ElapsedTime = DurationInMicroSeconds ( Duration );\r
if (ElapsedTime >= mInterestThreshold) {\r
- PrintToken (\r
- STRING_TOKEN (STR_DP_GLOBAL_VARS),\r
- Index,\r
- mGaugeString,\r
- mUnicodeToken,\r
- ElapsedTime\r
- );\r
+ if (mShowId) {\r
+ PrintToken (\r
+ STRING_TOKEN (STR_DP_GLOBAL_VARS2),\r
+ Index,\r
+ mGaugeString,\r
+ mUnicodeToken,\r
+ ElapsedTime,\r
+ Measurement.Identifier\r
+ );\r
+ } else {\r
+ PrintToken (\r
+ STRING_TOKEN (STR_DP_GLOBAL_VARS),\r
+ Index,\r
+ mGaugeString,\r
+ mUnicodeToken,\r
+ ElapsedTime\r
+ );\r
+ }\r
}\r
}\r
Index++;\r