)\r
{\r
UINT32 Index;\r
+ UINT32 Index2;\r
UINT32 NumberOfEntries;\r
PEI_PERFORMANCE_LOG_ENTRY *LogEntryArray;\r
\r
NumberOfEntries = PeiPerformanceLog->NumberOfEntries;\r
LogEntryArray = (PEI_PERFORMANCE_LOG_ENTRY *) (PeiPerformanceLog + 1);\r
\r
+ Index2 = 0;\r
+\r
for (Index = 0; Index < NumberOfEntries; Index++) {\r
- if ((LogEntryArray[Index].Handle == (EFI_PHYSICAL_ADDRESS) (UINTN) Handle) &&\r
- AsciiStrnCmp (LogEntryArray[Index].Token, Token, PEI_PERFORMANCE_STRING_LENGTH) == 0 &&\r
- AsciiStrnCmp (LogEntryArray[Index].Module, Module, PEI_PERFORMANCE_STRING_LENGTH) == 0 &&\r
- (PeiPerformanceIdArray[Index] == Identifier) &&\r
- LogEntryArray[Index].EndTimeStamp == 0\r
- ) {\r
+ Index2 = NumberOfEntries - 1 - Index;\r
+ if (LogEntryArray[Index2].EndTimeStamp == 0 &&\r
+ (LogEntryArray[Index2].Handle == (EFI_PHYSICAL_ADDRESS) (UINTN) Handle) &&\r
+ AsciiStrnCmp (LogEntryArray[Index2].Token, Token, PEI_PERFORMANCE_STRING_LENGTH) == 0 &&\r
+ AsciiStrnCmp (LogEntryArray[Index2].Module, Module, PEI_PERFORMANCE_STRING_LENGTH) == 0 &&\r
+ (PeiPerformanceIdArray[Index2] == Identifier)) {\r
+ Index = Index2;\r
break;\r
}\r
}\r