2009-07-17 11:10:31 +02:00
/** @file
2018-07-05 11:40:04 +02:00
2009-07-17 11:10:31 +02:00
VfrCompiler error handler .
2018-07-05 11:40:04 +02:00
Copyright ( c ) 2004 - 2018 , Intel Corporation . All rights reserved . < BR >
2019-04-04 01:03:11 +02:00
SPDX - License - Identifier : BSD - 2 - Clause - Patent
2009-07-17 11:10:31 +02:00
* */
# include "stdio.h"
# include "string.h"
# include "stdlib.h"
# include "VfrError.h"
# include "EfiUtilityMsgs.h"
static SVFR_ERROR_HANDLE VFR_ERROR_HANDLE_TABLE [ ] = {
{ VFR_RETURN_SUCCESS , NULL } ,
{ VFR_RETURN_ERROR_SKIPED , NULL } ,
{ VFR_RETURN_FATAL_ERROR , " : fatal error!! " } ,
{ VFR_RETURN_MISMATCHED , " : unexpected token " } ,
{ VFR_RETURN_INVALID_PARAMETER , " : invalid parameter " } ,
{ VFR_RETURN_OUT_FOR_RESOURCES , " : system out of memory " } ,
{ VFR_RETURN_UNSUPPORTED , " : unsupported " } ,
{ VFR_RETURN_REDEFINED , " : already defined " } ,
{ VFR_RETURN_FORMID_REDEFINED , " : form id already defined " } ,
{ VFR_RETURN_QUESTIONID_REDEFINED , " : question id already defined " } ,
{ VFR_RETURN_VARSTOREID_REDEFINED , " : varstore id already defined " } ,
{ VFR_RETURN_UNDEFINED , " : undefined " } ,
{ VFR_RETURN_VAR_NOTDEFINED_BY_QUESTION , " : some variable has not defined by a question " } ,
2011-05-11 12:26:49 +02:00
{ VFR_RETURN_VARSTORE_DATATYPE_REDEFINED_ERROR , " : Data Structure is defined by more than one varstores, it can't be referred as varstore, only varstore name could be used. " } ,
2009-07-17 11:10:31 +02:00
{ VFR_RETURN_GET_EFIVARSTORE_ERROR , " : get efi varstore error " } ,
{ VFR_RETURN_EFIVARSTORE_USE_ERROR , " : can not use the efi varstore like this " } ,
{ VFR_RETURN_EFIVARSTORE_SIZE_ERROR , " : unsupport efi varstore size should be <= 8 bytes " } ,
{ VFR_RETURN_GET_NVVARSTORE_ERROR , " : get name value varstore error " } ,
{ VFR_RETURN_QVAR_REUSE , " : variable reused by more than one question " } ,
{ VFR_RETURN_FLAGS_UNSUPPORTED , " : flags unsupported " } ,
{ VFR_RETURN_ERROR_ARRARY_NUM , " : array number error, the valid value is in (0 ~ MAX_INDEX-1) for UEFI vfr and in (1 ~ MAX_INDEX) for Framework Vfr " } ,
{ VFR_RETURN_DATA_STRING_ERROR , " : data field string error or not support " } ,
{ VFR_RETURN_DEFAULT_VALUE_REDEFINED , " : default value re-defined with different value " } ,
{ VFR_RETURN_CONSTANT_ONLY , " : only constant is allowed in the expression " } ,
2019-02-06 08:44:39 +01:00
{ VFR_RETURN_VARSTORE_NAME_REDEFINED_ERROR , " : Varstore name is defined by more than one varstores, it can't be referred as varstore, only varstore structure name could be used. " } ,
2017-08-23 10:27:26 +02:00
{ VFR_RETURN_BIT_WIDTH_ERROR , " : bit width must be <= sizeof (type) * 8 and the max width can not > 32 " } ,
2018-12-28 09:18:06 +01:00
{ VFR_RETURN_STRING_TO_UINT_OVERFLOW , " : String to UINT* Overflow " } ,
2009-07-17 11:10:31 +02:00
{ VFR_RETURN_CODEUNDEFINED , " : undefined Error Code " }
} ;
2013-08-23 04:18:16 +02:00
static SVFR_WARNING_HANDLE VFR_WARNING_HANDLE_TABLE [ ] = {
{ VFR_WARNING_DEFAULT_VALUE_REDEFINED , " : default value re-defined with different value " } ,
2014-07-25 23:09:48 +02:00
{ VFR_WARNING_ACTION_WITH_TEXT_TWO , " : Action opcode should not have TextTwo part " } ,
2014-07-25 23:10:10 +02:00
{ VFR_WARNING_OBSOLETED_FRAMEWORK_OPCODE , " : Not recommend to use obsoleted framework opcode " } ,
2013-08-23 04:18:16 +02:00
{ VFR_WARNING_CODEUNDEFINED , " : undefined Warning Code " }
} ;
2009-07-17 11:10:31 +02:00
CVfrErrorHandle : : CVfrErrorHandle (
VOID
)
{
2013-08-23 04:18:16 +02:00
mInputFileName = NULL ;
mScopeRecordListHead = NULL ;
mScopeRecordListTail = NULL ;
mVfrErrorHandleTable = VFR_ERROR_HANDLE_TABLE ;
mVfrWarningHandleTable = VFR_WARNING_HANDLE_TABLE ;
2017-12-18 03:11:57 +01:00
mWarningAsError = FALSE ;
2009-07-17 11:10:31 +02:00
}
CVfrErrorHandle : : ~ CVfrErrorHandle (
VOID
)
{
SVfrFileScopeRecord * pNode = NULL ;
if ( mInputFileName ! = NULL ) {
2018-02-27 06:53:46 +01:00
delete [ ] mInputFileName ;
2009-07-17 11:10:31 +02:00
}
while ( mScopeRecordListHead ! = NULL ) {
pNode = mScopeRecordListHead ;
mScopeRecordListHead = mScopeRecordListHead - > mNext ;
delete pNode ;
}
2013-08-23 04:18:16 +02:00
mScopeRecordListHead = NULL ;
mScopeRecordListTail = NULL ;
mVfrErrorHandleTable = NULL ;
mVfrWarningHandleTable = NULL ;
}
VOID
CVfrErrorHandle : : SetWarningAsError (
IN BOOLEAN WarningAsError
)
{
mWarningAsError = WarningAsError ;
2009-07-17 11:10:31 +02:00
}
VOID
CVfrErrorHandle : : SetInputFile (
IN CHAR8 * InputFile
)
{
if ( InputFile ! = NULL ) {
mInputFileName = new CHAR8 [ strlen ( InputFile ) + 1 ] ;
strcpy ( mInputFileName , InputFile ) ;
}
}
SVfrFileScopeRecord : : SVfrFileScopeRecord (
2018-07-05 11:40:04 +02:00
IN CHAR8 * Record ,
2009-07-17 11:10:31 +02:00
IN UINT32 LineNum
)
{
UINT32 Index ;
CHAR8 * FileName = NULL ;
CHAR8 * Str = NULL ;
mWholeScopeLine = LineNum ;
mNext = NULL ;
Str = strchr ( Record , ' ' ) ;
mScopeLineStart = atoi ( + + Str ) ;
Str = strchr ( Str , ' \" ' ) ;
FileName = + + Str ;
while ( ( Str = strstr ( FileName , " \\ \\ " ) ) ! = NULL ) {
FileName = Str + 2 ;
}
if ( ( mFileName = new CHAR8 [ strlen ( FileName ) ] ) ! = NULL ) {
for ( Index = 0 ; FileName [ Index ] ! = ' \" ' ; Index + + ) {
mFileName [ Index ] = FileName [ Index ] ;
}
mFileName [ Index ] = ' \0 ' ;
}
return ;
}
SVfrFileScopeRecord : : ~ SVfrFileScopeRecord (
VOID
)
{
if ( mFileName ! = NULL ) {
2016-09-27 07:40:58 +02:00
delete [ ] mFileName ;
2009-07-17 11:10:31 +02:00
}
}
VOID
CVfrErrorHandle : : ParseFileScopeRecord (
2018-07-05 11:40:04 +02:00
IN CHAR8 * Record ,
2009-07-17 11:10:31 +02:00
IN UINT32 WholeScopeLine
)
{
SVfrFileScopeRecord * pNode = NULL ;
if ( Record = = NULL ) {
return ;
}
if ( ( pNode = new SVfrFileScopeRecord ( Record , WholeScopeLine ) ) = = NULL ) {
return ;
}
if ( mScopeRecordListHead = = NULL ) {
mScopeRecordListTail = mScopeRecordListHead = pNode ;
} else {
mScopeRecordListTail - > mNext = pNode ;
mScopeRecordListTail = pNode ;
}
}
VOID
CVfrErrorHandle : : GetFileNameLineNum (
IN UINT32 LineNum ,
OUT CHAR8 * * FileName ,
OUT UINT32 * FileLine
)
{
SVfrFileScopeRecord * pNode = NULL ;
if ( ( FileName = = NULL ) | | ( FileLine = = NULL ) ) {
return ;
}
* FileName = NULL ;
* FileLine = 0xFFFFFFFF ;
//
// Some errors occur before scope record list been built.
//
if ( mScopeRecordListHead = = NULL ) {
* FileLine = LineNum ;
* FileName = mInputFileName ;
return ;
}
for ( pNode = mScopeRecordListHead ; pNode - > mNext ! = NULL ; pNode = pNode - > mNext ) {
if ( ( LineNum > pNode - > mWholeScopeLine ) & & ( pNode - > mNext - > mWholeScopeLine > LineNum ) ) {
* FileName = pNode - > mFileName ;
* FileLine = LineNum - pNode - > mWholeScopeLine + pNode - > mScopeLineStart - 1 ;
return ;
}
}
* FileName = pNode - > mFileName ;
* FileLine = LineNum - pNode - > mWholeScopeLine + pNode - > mScopeLineStart - 1 ;
}
VOID
CVfrErrorHandle : : PrintMsg (
IN UINT32 LineNum ,
IN CHAR8 * TokName ,
2010-03-01 00:39:39 +01:00
IN CONST CHAR8 * MsgType ,
IN CONST CHAR8 * ErrorMsg
2009-07-17 11:10:31 +02:00
)
{
CHAR8 * FileName = NULL ;
UINT32 FileLine ;
2018-07-05 11:40:04 +02:00
2009-09-11 05:14:43 +02:00
if ( strncmp ( " Warning " , MsgType , strlen ( " Warning " ) ) = = 0 ) {
2010-03-01 00:39:39 +01:00
VerboseMsg ( ( CHAR8 * ) ErrorMsg ) ;
2009-09-11 05:14:43 +02:00
return ;
}
2009-07-17 11:10:31 +02:00
GetFileNameLineNum ( LineNum , & FileName , & FileLine ) ;
2010-03-01 00:39:39 +01:00
Error ( FileName , FileLine , 0x3000 , TokName , ( CHAR8 * ) " \t %s \n " , ( CHAR8 * ) ErrorMsg ) ;
2009-07-17 11:10:31 +02:00
}
UINT8
CVfrErrorHandle : : HandleError (
IN EFI_VFR_RETURN_CODE ErrorCode ,
IN UINT32 LineNum ,
IN CHAR8 * TokName
)
{
UINT32 Index ;
CHAR8 * FileName = NULL ;
UINT32 FileLine ;
2010-03-01 00:39:39 +01:00
CONST CHAR8 * ErrorMsg = NULL ;
2009-07-17 11:10:31 +02:00
if ( mVfrErrorHandleTable = = NULL ) {
return 1 ;
}
for ( Index = 0 ; mVfrErrorHandleTable [ Index ] . mErrorCode ! = VFR_RETURN_CODEUNDEFINED ; Index + + ) {
if ( ErrorCode = = mVfrErrorHandleTable [ Index ] . mErrorCode ) {
ErrorMsg = mVfrErrorHandleTable [ Index ] . mErrorMsg ;
break ;
}
}
if ( ErrorMsg ! = NULL ) {
GetFileNameLineNum ( LineNum , & FileName , & FileLine ) ;
2010-03-01 00:39:39 +01:00
Error ( FileName , FileLine , 0x3000 , TokName , ( CHAR8 * ) " \t %s \n " , ( CHAR8 * ) ErrorMsg ) ;
2009-07-17 11:10:31 +02:00
return 1 ;
} else {
return 0 ;
}
}
2013-08-23 04:18:16 +02:00
UINT8
CVfrErrorHandle : : HandleWarning (
IN EFI_VFR_WARNING_CODE WarningCode ,
IN UINT32 LineNum ,
IN CHAR8 * TokName
)
{
UINT32 Index ;
CHAR8 * FileName = NULL ;
UINT32 FileLine ;
CONST CHAR8 * WarningMsg = NULL ;
if ( mVfrWarningHandleTable = = NULL ) {
return 1 ;
}
GetFileNameLineNum ( LineNum , & FileName , & FileLine ) ;
if ( mWarningAsError ) {
2015-11-17 08:40:00 +01:00
Error ( FileName , FileLine , 0x2220 , ( CHAR8 * ) " warning treated as error " , NULL ) ;
2013-08-23 04:18:16 +02:00
}
for ( Index = 0 ; mVfrWarningHandleTable [ Index ] . mWarningCode ! = VFR_WARNING_CODEUNDEFINED ; Index + + ) {
if ( WarningCode = = mVfrWarningHandleTable [ Index ] . mWarningCode ) {
WarningMsg = mVfrWarningHandleTable [ Index ] . mWarningMsg ;
break ;
}
}
if ( WarningMsg ! = NULL ) {
Warning ( FileName , FileLine , 0 , TokName , ( CHAR8 * ) " \t %s \n " , ( CHAR8 * ) WarningMsg ) ;
return 1 ;
} else {
return 0 ;
}
}
2009-07-17 11:10:31 +02:00
CVfrErrorHandle gCVfrErrorHandle ;