X-Git-Url: https://git.proxmox.com/?p=mirror_edk2.git;a=blobdiff_plain;f=BaseTools%2FSource%2FC%2FVfrCompile%2FVfrUtilityLib.cpp;h=5cab7bbfa1afdeee0a56e7d8b45f319ff0d81267;hp=0fe14b0d29215213c48ee38b27e9a0c3efa40130;hb=65e0e10d23323b18f31bf9aa9eef3c2434f53780;hpb=631ffb70ebbe78b6e3f342b7ad9ab9b75f8796ae diff --git a/BaseTools/Source/C/VfrCompile/VfrUtilityLib.cpp b/BaseTools/Source/C/VfrCompile/VfrUtilityLib.cpp index 0fe14b0d29..5cab7bbfa1 100644 --- a/BaseTools/Source/C/VfrCompile/VfrUtilityLib.cpp +++ b/BaseTools/Source/C/VfrCompile/VfrUtilityLib.cpp @@ -2,7 +2,7 @@ Vfr common library functions. -Copyright (c) 2004 - 2017, Intel Corporation. All rights reserved.
+Copyright (c) 2004 - 2018, 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 @@ -15,6 +15,7 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. #include "stdio.h" #include "stdlib.h" +#include "assert.h" #include "CommonLib.h" #include "VfrUtilityLib.h" #include "VfrFormPkg.h" @@ -359,7 +360,7 @@ CVfrBufferConfig::Write ( case 'i' : // set info if (mItemListPos->mId != NULL) { - delete mItemListPos->mId; + delete[] mItemListPos->mId; } mItemListPos->mId = NULL; if (Id != NULL) { @@ -842,7 +843,9 @@ CVfrVarDataTypeDB::InternalTypesListInit ( for (Index = 0; gInternalTypesTable[Index].mTypeName != NULL; Index++) { New = new SVfrDataType; if (New != NULL) { - strcpy (New->mTypeName, gInternalTypesTable[Index].mTypeName); + assert (strlen (gInternalTypesTable[Index].mTypeName) < MAX_NAME_LEN); + strncpy (New->mTypeName, gInternalTypesTable[Index].mTypeName, MAX_NAME_LEN - 1); + New->mTypeName[MAX_NAME_LEN - 1] = 0; New->mType = gInternalTypesTable[Index].mType; New->mAlign = gInternalTypesTable[Index].mAlign; New->mTotalSize = gInternalTypesTable[Index].mSize; @@ -955,6 +958,7 @@ CVfrVarDataTypeDB::CVfrVarDataTypeDB ( mPackAlign = DEFAULT_PACK_ALIGN; mPackStack = NULL; mFirstNewDataTypeName = NULL; + mCurrDataType = NULL; InternalTypesListInit (); } @@ -1084,7 +1088,8 @@ CVfrVarDataTypeDB::SetNewTypeName ( } } - strcpy(mNewDataType->mTypeName, TypeName); + strncpy(mNewDataType->mTypeName, TypeName, MAX_NAME_LEN - 1); + mNewDataType->mTypeName[MAX_NAME_LEN - 1] = 0; return VFR_RETURN_SUCCESS; } @@ -1145,7 +1150,8 @@ CVfrVarDataTypeDB::DataTypeAddBitField ( MaxDataTypeSize = mNewDataType->mTotalSize; if (FieldName != NULL) { - strcpy (pNewField->mFieldName, FieldName); + strncpy (pNewField->mFieldName, FieldName, MAX_NAME_LEN - 1); + pNewField->mFieldName[MAX_NAME_LEN - 1] = 0; } pNewField->mFieldType = pFieldType; pNewField->mIsBitField = TRUE; @@ -1239,7 +1245,8 @@ CVfrVarDataTypeDB::DataTypeAddField ( if ((pNewField = new SVfrDataField) == NULL) { return VFR_RETURN_OUT_FOR_RESOURCES; } - strcpy (pNewField->mFieldName, FieldName); + strncpy (pNewField->mFieldName, FieldName, MAX_NAME_LEN - 1); + pNewField->mFieldName[MAX_NAME_LEN - 1] = 0; pNewField->mFieldType = pFieldType; pNewField->mArrayNum = ArrayNum; pNewField->mIsBitField = FALSE; @@ -1599,6 +1606,7 @@ SVfrVarStorageNode::SVfrVarStorageNode ( IN EFI_VARSTORE_ID VarStoreId ) { + memset (&mGuid, 0, sizeof (EFI_GUID)); if (StoreName != NULL) { mVarStoreName = new CHAR8[strlen(StoreName) + 1]; strcpy (mVarStoreName, StoreName); @@ -1610,6 +1618,7 @@ SVfrVarStorageNode::SVfrVarStorageNode ( mVarStoreType = EFI_VFR_VARSTORE_NAME; mStorageInfo.mNameSpace.mNameTable = new EFI_VARSTORE_ID[DEFAULT_NAME_TABLE_ITEMS]; mStorageInfo.mNameSpace.mTableSize = 0; + mAssignedFlag = FALSE; } SVfrVarStorageNode::~SVfrVarStorageNode ( @@ -1621,7 +1630,7 @@ SVfrVarStorageNode::~SVfrVarStorageNode ( } if (mVarStoreType == EFI_VFR_VARSTORE_NAME) { - delete mStorageInfo.mNameSpace.mNameTable; + delete[] mStorageInfo.mNameSpace.mNameTable; } } @@ -3480,7 +3489,7 @@ CVfrStringDB::CVfrStringDB () CVfrStringDB::~CVfrStringDB () { if (mStringFileName != NULL) { - delete mStringFileName; + delete[] mStringFileName; } mStringFileName = NULL; } @@ -3495,6 +3504,10 @@ CVfrStringDB::SetStringFileName(IN CHAR8 *StringFileName) return; } + if (mStringFileName != NULL) { + delete[] mStringFileName; + } + FileLen = strlen (StringFileName) + 1; mStringFileName = new CHAR8[FileLen]; if (mStringFileName == NULL) {