Files
Tan, Ming aa18d33f85 Features/Intel/BeepDebugFeaturePkg: add it.
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=2792

The BeepDebugFeaturePkg include some useful beep debug
libraries, such as get beep value from status code and beep.

It provide a library BeepStatusCodeHandlerLib used by edk2
StatusCodeHandler.efi, used to do beep if needed.
It also provide a library of BeepMap lib, it map the status code
to beep value.
A library of Beep lib is needed by platform, and this pkg has a
Null implementation.

Cc: Liming Gao <liming.gao@intel.com>
Signed-off-by: Ming Tan <ming.tan@intel.com>
Reviewed-by: Eric Dong <eric.dong@intel.com>
Reviewed-by: Dandan Bi <dandan.bi@intel.com>
2020-06-18 13:51:44 +08:00

117 lines
2.6 KiB
C

/** @file
BeepMap implementation.
Copyright (c) 2012 - 2020, Intel Corporation. All rights reserved.<BR>
SPDX-License-Identifier: BSD-2-Clause-Patent
**/
#include <Base.h>
#include <Uefi.h>
#include "PlatformStatusCodesInternal.h"
STATUS_CODE_TO_DATA_MAP mBeepProgressMap[] = {
//
// PEI
//
// Recovery
{ PEI_RECOVERY_STARTED, 2 },
//
// DXE
//
{0,0}
};
STATUS_CODE_TO_DATA_MAP mBeepErrorMap[] = {
//
// PEI
//
// Regular boot
{ PEI_MEMORY_NOT_DETECTED, 1 },
{ PEI_MEMORY_INSTALLED_TWICE, 1 },
{ PEI_DXEIPL_NOT_FOUND, 3 },
{ PEI_DXE_CORE_NOT_FOUND, 3 },
{ PEI_RESET_NOT_AVAILABLE, 7 },
// Recovery
{ PEI_RECOVERY_FAILED, 4 },
// S3 Resume
{ PEI_S3_RESUME_FAILED, 4 },
//
// DXE
//
{ DXE_ARCH_PROTOCOL_NOT_AVAILABLE, 4 },
{ DXE_NO_CON_OUT, 5 },
{ DXE_NO_CON_IN, 5 },
{ DXE_INVALID_PASSWORD, 1 },
{ DXE_FLASH_UPDATE_FAILED, 6 },
{ DXE_RESET_NOT_AVAILABLE, 7 },
{0,0}
};
STATUS_CODE_TO_DATA_MAP *mBeepStatusCodesMap[] = {
//#define EFI_PROGRESS_CODE 0x00000001
mBeepProgressMap,
//#define EFI_ERROR_CODE 0x00000002
mBeepErrorMap
//#define EFI_DEBUG_CODE 0x00000003
};
/**
Find the beep data from status code value.
@param Map The map used to find in.
@param Value The status code value.
@return BeepValue 0 for not found.
**/
UINT32
FindBeepData (
IN STATUS_CODE_TO_DATA_MAP *Map,
IN EFI_STATUS_CODE_VALUE Value
)
{
while (Map->Value != 0) {
if (Map->Value == Value) {
return Map->Data;
}
Map++;
}
return 0;
}
/**
Get BeepValue from status code type and value.
@param CodeType Indicates the type of status code being reported.
@param Value Describes the current status of a hardware or
software entity. This includes information about the class and
subclass that is used to classify the entity as well as an operation.
For progress codes, the operation is the current activity.
For error codes, it is the exception.For debug codes,it is not defined at this time.
@return BeepValue
**/
UINT32
EFIAPI
GetBeepValueFromStatusCode (
IN EFI_STATUS_CODE_TYPE CodeType,
IN EFI_STATUS_CODE_VALUE Value
)
{
UINT32 CodeTypeIndex;
CodeTypeIndex = STATUS_CODE_TYPE (CodeType) - 1;
if (CodeTypeIndex >= sizeof (mBeepStatusCodesMap) / sizeof(mBeepStatusCodesMap[0])) {
return 0;
}
return FindBeepData (mBeepStatusCodesMap[CodeTypeIndex], Value);
}