2006-07-21 16:25:43 +02:00
|
|
|
/** @file
|
|
|
|
Status Code Architectural Protocol implementation as defined in Tiano
|
|
|
|
Architecture Specification.
|
|
|
|
|
|
|
|
This driver has limited functionality at runtime and will not log to Data Hub
|
|
|
|
at runtime.
|
|
|
|
|
|
|
|
Notes:
|
|
|
|
This driver assumes the following ReportStatusCode strategy:
|
|
|
|
PEI -> uses PeiReportStatusCode
|
|
|
|
DXE IPL -> uses PeiReportStatusCode
|
|
|
|
early DXE -> uses PeiReportStatusCode via HOB
|
|
|
|
DXE -> This driver
|
|
|
|
RT -> This driver
|
|
|
|
|
2006-07-24 13:53:34 +02:00
|
|
|
Copyright (c) 2006, Intel Corporation
|
|
|
|
All rights reserved. This program and the accompanying materials
|
|
|
|
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
|
|
|
|
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.
|
2006-07-21 16:25:43 +02:00
|
|
|
|
|
|
|
Module Name: StatusCode.c
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include "DxeStatusCode.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
Dispatch initialization request to sub status code devices based on
|
|
|
|
customized feature flags.
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
InitializationDispatcherWorker (
|
|
|
|
VOID
|
|
|
|
)
|
|
|
|
{
|
|
|
|
EFI_PEI_HOB_POINTERS Hob;
|
2006-09-01 07:37:49 +02:00
|
|
|
EFI_STATUS Status;
|
2006-07-21 16:25:43 +02:00
|
|
|
MEMORY_STATUSCODE_PACKET_HEADER *PacketHeader;
|
|
|
|
MEMORY_STATUSCODE_RECORD *Record;
|
|
|
|
UINTN ExpectedPacketIndex = 0;
|
|
|
|
UINTN Index;
|
|
|
|
VOID *HobStart;
|
|
|
|
|
|
|
|
//
|
|
|
|
// If enable UseSerial, then initialize serial port.
|
|
|
|
// if enable UseRuntimeMemory, then initialize runtime memory status code worker.
|
|
|
|
// if enable UseDataHub, then initialize data hub status code worker.
|
|
|
|
//
|
|
|
|
if (FeaturePcdGet (PcdStatusCodeUseEfiSerial)) {
|
2006-09-01 07:37:49 +02:00
|
|
|
Status = EfiSerialStatusCodeInitializeWorker ();
|
|
|
|
ASSERT_EFI_ERROR (Status);
|
2006-07-21 16:25:43 +02:00
|
|
|
}
|
|
|
|
if (FeaturePcdGet (PcdStatusCodeUseHardSerial)) {
|
2006-09-01 07:37:49 +02:00
|
|
|
Status = SerialPortInitialize ();
|
|
|
|
ASSERT_EFI_ERROR (Status);
|
2006-07-21 16:25:43 +02:00
|
|
|
}
|
|
|
|
if (FeaturePcdGet (PcdStatusCodeUseRuntimeMemory)) {
|
2006-09-01 07:37:49 +02:00
|
|
|
Status = RtMemoryStatusCodeInitializeWorker ();
|
|
|
|
ASSERT_EFI_ERROR (Status);
|
2006-07-21 16:25:43 +02:00
|
|
|
}
|
|
|
|
if (FeaturePcdGet (PcdStatusCodeUseDataHub)) {
|
2006-09-01 07:37:49 +02:00
|
|
|
Status = DataHubStatusCodeInitializeWorker ();
|
|
|
|
ASSERT_EFI_ERROR (Status);
|
2006-07-21 16:25:43 +02:00
|
|
|
}
|
|
|
|
if (FeaturePcdGet (PcdStatusCodeUseOEM)) {
|
2006-09-01 07:37:49 +02:00
|
|
|
Status = OemHookStatusCodeInitialize ();
|
|
|
|
ASSERT_EFI_ERROR (Status);
|
2006-07-21 16:25:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// Replay Status code which saved in GUID'ed HOB to all supported device.
|
|
|
|
//
|
|
|
|
|
|
|
|
//
|
|
|
|
// Journal GUID'ed HOBs to find all record entry, if found,
|
|
|
|
// then output record to support replay device.
|
|
|
|
//
|
|
|
|
Hob.Raw = GetFirstGuidHob (&gMemoryStatusCodeRecordGuid);
|
|
|
|
HobStart = Hob.Raw;
|
|
|
|
while (Hob.Raw != NULL) {
|
|
|
|
PacketHeader = (MEMORY_STATUSCODE_PACKET_HEADER *) GET_GUID_HOB_DATA (Hob.Guid);
|
|
|
|
if (PacketHeader->PacketIndex == ExpectedPacketIndex) {
|
|
|
|
Record = (MEMORY_STATUSCODE_RECORD *) (PacketHeader + 1);
|
|
|
|
for (Index = 0; Index < PacketHeader->RecordIndex; Index++) {
|
|
|
|
//
|
|
|
|
// Dispatch records to devices based on feature flag.
|
|
|
|
//
|
|
|
|
if (FeaturePcdGet (PcdStatusCodeReplayInSerial) &&
|
|
|
|
(FeaturePcdGet (PcdStatusCodeUseHardSerial) ||
|
|
|
|
FeaturePcdGet (PcdStatusCodeUseEfiSerial))) {
|
|
|
|
SerialStatusCodeReportWorker (
|
|
|
|
Record[Index].CodeType,
|
|
|
|
Record[Index].Value,
|
|
|
|
Record[Index].Instance,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
);
|
|
|
|
}
|
|
|
|
if (FeaturePcdGet (PcdStatusCodeReplayInRuntimeMemory) &&
|
|
|
|
FeaturePcdGet (PcdStatusCodeUseRuntimeMemory)) {
|
|
|
|
RtMemoryStatusCodeReportWorker (
|
|
|
|
gDxeStatusCode.RtMemoryStatusCodeTable[PHYSICAL_MODE],
|
|
|
|
Record[Index].CodeType,
|
|
|
|
Record[Index].Value,
|
|
|
|
Record[Index].Instance
|
|
|
|
);
|
|
|
|
}
|
|
|
|
if (FeaturePcdGet (PcdStatusCodeReplayInDataHub) &&
|
|
|
|
FeaturePcdGet (PcdStatusCodeUseDataHub)) {
|
|
|
|
DataHubStatusCodeReportWorker (
|
|
|
|
Record[Index].CodeType,
|
|
|
|
Record[Index].Value,
|
|
|
|
Record[Index].Instance,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
);
|
|
|
|
}
|
|
|
|
if (FeaturePcdGet (PcdStatusCodeReplayInOEM) &&
|
|
|
|
FeaturePcdGet (PcdStatusCodeUseOEM)) {
|
|
|
|
OemHookStatusCodeReport (
|
|
|
|
Record[Index].CodeType,
|
|
|
|
Record[Index].Value,
|
|
|
|
Record[Index].Instance,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
ExpectedPacketIndex++;
|
|
|
|
|
|
|
|
//
|
|
|
|
// See whether there is gap of packet or not
|
|
|
|
//
|
|
|
|
if (HobStart) {
|
|
|
|
HobStart = NULL;
|
|
|
|
Hob.Raw = HobStart;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
} else if (HobStart != NULL) {
|
|
|
|
//
|
|
|
|
// Cache the found packet for improve the performance
|
|
|
|
//
|
|
|
|
HobStart = Hob.Raw;
|
|
|
|
}
|
|
|
|
|
|
|
|
Hob.Raw = GetNextGuidHob (&gMemoryStatusCodeRecordGuid, Hob.Raw);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|