From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received-SPF: Pass (sender SPF authorized) identity=mailfrom; client-ip=192.55.52.88; helo=mga01.intel.com; envelope-from=chasel.chiu@intel.com; receiver=edk2-devel@lists.01.org Received: from mga01.intel.com (mga01.intel.com [192.55.52.88]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ml01.01.org (Postfix) with ESMTPS id 9BF512119BBFA for ; Tue, 18 Dec 2018 19:21:47 -0800 (PST) X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga004.jf.intel.com ([10.7.209.38]) by fmsmga101.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 18 Dec 2018 19:21:47 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.56,371,1539673200"; d="scan'208";a="260607627" Received: from kmsmsx153.gar.corp.intel.com ([172.21.73.88]) by orsmga004.jf.intel.com with ESMTP; 18 Dec 2018 19:21:45 -0800 Received: from pgsmsx111.gar.corp.intel.com ([169.254.2.232]) by KMSMSX153.gar.corp.intel.com ([169.254.5.24]) with mapi id 14.03.0415.000; Wed, 19 Dec 2018 11:21:44 +0800 From: "Chiu, Chasel" To: "Zeng, Star" , "edk2-devel@lists.01.org" CC: "Wang, Jian J" , "Wu, Hao A" , "Gao, Liming" , "Ni, Ruiyu" , "Kinney, Michael D" , "Desimone, Nathaniel L" Thread-Topic: [PATCH V2 1/7] MdeModulePkg PeiCore: Remove the using of PcdPeiCoreMaxPeimPerFv Thread-Index: AQHUlpghx0xPcI4zCEqt6oAPXKgKtaWFZpww Date: Wed, 19 Dec 2018 03:21:43 +0000 Message-ID: <3C3EFB470A303B4AB093197B6777CCEC501F652E@PGSMSX111.gar.corp.intel.com> References: <1545113286-49760-1-git-send-email-star.zeng@intel.com> <1545113286-49760-2-git-send-email-star.zeng@intel.com> In-Reply-To: <1545113286-49760-2-git-send-email-star.zeng@intel.com> Accept-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: dlp-product: dlpe-windows dlp-version: 11.0.400.15 dlp-reaction: no-action x-titus-metadata-40: eyJDYXRlZ29yeUxhYmVscyI6IiIsIk1ldGFkYXRhIjp7Im5zIjoiaHR0cDpcL1wvd3d3LnRpdHVzLmNvbVwvbnNcL0ludGVsMyIsImlkIjoiOGYwZTkxZmUtMzM4OC00N2YzLThjMzgtZDZlZjkyM2ExNDIzIiwicHJvcHMiOlt7Im4iOiJDVFBDbGFzc2lmaWNhdGlvbiIsInZhbHMiOlt7InZhbHVlIjoiQ1RQX05UIn1dfV19LCJTdWJqZWN0TGFiZWxzIjpbXSwiVE1DVmVyc2lvbiI6IjE3LjEwLjE4MDQuNDkiLCJUcnVzdGVkTGFiZWxIYXNoIjoiYnhiVnZoaEZ6T3B6XC9vSzQ5Mys2QWd1WVlYQk5rTEhZTnErSVZ5UDFwMDVMbzVwZzgzUVBQTmVDS0ZpY1R4a1QifQ== x-ctpclassification: CTP_NT x-originating-ip: [172.30.20.205] MIME-Version: 1.0 Subject: Re: [PATCH V2 1/7] MdeModulePkg PeiCore: Remove the using of PcdPeiCoreMaxPeimPerFv X-BeenThere: edk2-devel@lists.01.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: EDK II Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 19 Dec 2018 03:21:47 -0000 Content-Language: en-US Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: quoted-printable Reviewed-by: Chasel Chiu -----Original Message----- From: Zeng, Star=20 Sent: Tuesday, December 18, 2018 2:08 PM To: edk2-devel@lists.01.org Cc: Zeng, Star ; Wang, Jian J ;= Wu, Hao A ; Gao, Liming ; Ni, Ru= iyu ; Kinney, Michael D ; D= esimone, Nathaniel L ; Chiu, Chasel Subject: [PATCH V2 1/7] MdeModulePkg PeiCore: Remove the using of PcdPeiCor= eMaxPeimPerFv REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3D1405 Background as below. Problem: As static configuration from the PCDs, the binary PeiCore (for example in F= SP binary with dispatch mode) could not predict how many FVs, Files or PPIs= for different platforms. Burden: Platform developers need configure the PCDs accordingly for different platf= orms. To solve the problem and remove the burden, we can update code to remove th= e using of PcdPeiCoreMaxFvSupported, PcdPeiCoreMaxPeimPerFv and PcdPeiCoreM= axPpiSupported by extending buffer dynamically for FV, File and PPI managem= ent. This patch removes the using of PcdPeiCoreMaxPeimPerFv in PeiCore. Cc: Jian J Wang Cc: Hao Wu Cc: Liming Gao Cc: Ruiyu Ni Cc: Michael D Kinney Cc: Nate DeSimone Cc: Chasel Chiu Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Star Zeng --- MdeModulePkg/Core/Pei/Dispatcher/Dispatcher.c | 173 +++++++++++++++-------= ---- MdeModulePkg/Core/Pei/PeiMain.h | 22 ++-- MdeModulePkg/Core/Pei/PeiMain.inf | 1 - MdeModulePkg/Core/Pei/PeiMain/PeiMain.c | 48 ++++--- 4 files changed, 136 insertions(+), 108 deletions(-) diff --git a/MdeModulePkg/Core/Pei/Dispatcher/Dispatcher.c b/MdeModulePkg/C= ore/Pei/Dispatcher/Dispatcher.c index f6bb35a5fe8d..9692e2f6bf51 100644 --- a/MdeModulePkg/Core/Pei/Dispatcher/Dispatcher.c +++ b/MdeModulePkg/Core/Pei/Dispatcher/Dispatcher.c @@ -41,7 +41,7 @@ DiscoverPeimsAndOrderWithApriori ( UINTN PeimCount; EFI_GUID *Guid; EFI_PEI_FILE_HANDLE *TempFileHandles; - EFI_GUID *FileGuid; + EFI_GUID *TempFileGuid; EFI_PEI_FIRMWARE_VOLUME_PPI *FvPpi; EFI_FV_FILE_INFO FileInfo; =20 @@ -51,38 +51,81 @@ DiscoverPeimsAndOrderWithApriori ( // Walk the FV and find all the PEIMs and the Apriori file. // AprioriFileHandle =3D NULL; - Private->CurrentFvFileHandles[0] =3D NULL; + Private->CurrentFvFileHandles =3D NULL; Guid =3D NULL; - FileHandle =3D NULL; - TempFileHandles =3D Private->FileHandles; - FileGuid =3D Private->FileGuid; =20 // - // If the current Fv has been scanned, directly get its cachable record. + // If the current Fv has been scanned, directly get its cached records. // - if (Private->Fv[Private->CurrentPeimFvCount].ScanFv) { - CopyMem (Private->CurrentFvFileHandles, Private->Fv[Private->CurrentPe= imFvCount].FvFileHandles, sizeof (EFI_PEI_FILE_HANDLE) * PcdGet32 (PcdPeiCo= reMaxPeimPerFv)); + if (CoreFileHandle->ScanFv) { + Private->CurrentFvFileHandles =3D CoreFileHandle->FvFileHandles; return; } =20 + TempFileHandles =3D Private->TempFileHandles; + TempFileGuid =3D Private->TempFileGuid; + // - // Go ahead to scan this Fv, and cache FileHandles within it. + // Go ahead to scan this Fv, get PeimCount and cache FileHandles within = it to TempFileHandles. // - Status =3D EFI_NOT_FOUND; - for (PeimCount =3D 0; PeimCount <=3D PcdGet32 (PcdPeiCoreMaxPeimPerFv); = PeimCount++) { + PeimCount =3D 0; + FileHandle =3D NULL; + do { Status =3D FvPpi->FindFileByType (FvPpi, PEI_CORE_INTERNAL_FFS_FILE_DI= SPATCH_TYPE, CoreFileHandle->FvHandle, &FileHandle); - if (Status !=3D EFI_SUCCESS || PeimCount =3D=3D PcdGet32 (PcdPeiCoreMa= xPeimPerFv)) { - break; + if (!EFI_ERROR (Status)) { + if (PeimCount >=3D Private->TempPeimCount) { + // + // Run out of room, grow the buffer. + // + TempFileHandles =3D AllocatePool ( + sizeof (EFI_PEI_FILE_HANDLE) * (Private->TempP= eimCount + TEMP_FILE_GROWTH_STEP)); + ASSERT (TempFileHandles !=3D NULL); + CopyMem ( + TempFileHandles, + Private->TempFileHandles, + sizeof (EFI_PEI_FILE_HANDLE) * Private->TempPeimCount + ); + Private->TempFileHandles =3D TempFileHandles; + TempFileGuid =3D AllocatePool ( + sizeof (EFI_GUID) * (Private->TempPeimCount + TEM= P_FILE_GROWTH_STEP)); + ASSERT (TempFileGuid !=3D NULL); + CopyMem ( + TempFileGuid, + Private->TempFileGuid, + sizeof (EFI_GUID) * Private->TempPeimCount + ); + Private->TempFileGuid =3D TempFileGuid; + Private->TempPeimCount =3D Private->TempPeimCount + TEMP_FILE_GROW= TH_STEP; + } + + TempFileHandles[PeimCount++] =3D FileHandle; } + } while (!EFI_ERROR (Status)); + + DEBUG (( + DEBUG_INFO, + "%a(): Found 0x%x PEI FFS files in the %dth FV\n", + __FUNCTION__, + PeimCount, + Private->CurrentPeimFvCount + )); =20 - Private->CurrentFvFileHandles[PeimCount] =3D FileHandle; + if (PeimCount =3D=3D 0) { + // + // No PEIM FFS file is found, set ScanFv flag and return. + // + CoreFileHandle->ScanFv =3D TRUE; + return; } =20 // - // Check whether the count of files exceeds the max support files in a F= V image - // If more files are required in a FV image, PcdPeiCoreMaxPeimPerFv can = be set to a larger value in DSC file. + // Record PeimCount, allocate buffer for PeimState and FvFileHandles. // - ASSERT ((Status !=3D EFI_SUCCESS) || (PeimCount < PcdGet32 (PcdPeiCoreMa= xPeimPerFv))); + CoreFileHandle->PeimCount =3D PeimCount; CoreFileHandle->PeimState =3D= =20 + AllocateZeroPool (sizeof (UINT8) * PeimCount); ASSERT=20 + (CoreFileHandle->PeimState !=3D NULL); CoreFileHandle->FvFileHandles =3D= =20 + AllocateZeroPool (sizeof (EFI_PEI_FILE_HANDLE) * PeimCount); ASSERT=20 + (CoreFileHandle->FvFileHandles !=3D NULL); =20 // // Get Apriori File handle @@ -96,7 +139,7 @@ DiscoverPeimsAndOrderWithApriori ( Status =3D FvPpi->FindSectionByType (FvPpi, EFI_SECTION_RAW, AprioriFi= leHandle, (VOID **) &Apriori); if (!EFI_ERROR (Status)) { // - // Calculate the number of PEIMs in the A Priori list + // Calculate the number of PEIMs in the Apriori file // Status =3D FvPpi->GetFileInfo (FvPpi, AprioriFileHandle, &FileInfo); ASSERT_EFI_ERROR (Status); @@ -113,71 +156,55 @@ DiscoverPeimsAndOrderWithApriori ( // Make an array of file name guids that matches the FileHandle ar= ray so we can convert // quickly from file name to file handle // - Status =3D FvPpi->GetFileInfo (FvPpi, Private->CurrentFvFileHandle= s[Index], &FileInfo); - CopyMem (&FileGuid[Index], &FileInfo.FileName, sizeof(EFI_GUID)); + Status =3D FvPpi->GetFileInfo (FvPpi, TempFileHandles[Index], &Fil= eInfo); + ASSERT_EFI_ERROR (Status); + CopyMem (&TempFileGuid[Index], &FileInfo.FileName,=20 + sizeof(EFI_GUID)); } =20 // - // Walk through FileGuid array to find out who is invalid PEIM guid = in Apriori file. - // Add available PEIMs in Apriori file into TempFileHandles array at= first. + // Walk through TempFileGuid array to find out who is invalid PEIM g= uid in Apriori file. + // Add available PEIMs in Apriori file into FvFileHandles array. // - Index2 =3D 0; - for (Index =3D 0; Index2 < Private->AprioriCount; Index++) { - while (Index2 < Private->AprioriCount) { - Guid =3D ScanGuid (FileGuid, PeimCount * sizeof (EFI_GUID), &Apr= iori[Index2++]); - if (Guid !=3D NULL) { - break; - } - } - if (Guid =3D=3D NULL) { - break; - } - PeimIndex =3D ((UINTN)Guid - (UINTN)&FileGuid[0])/sizeof (EFI_GUID= ); - TempFileHandles[Index] =3D Private->CurrentFvFileHandles[PeimIndex= ]; + Index =3D 0; + for (Index2 =3D 0; Index2 < Private->AprioriCount; Index2++) { + Guid =3D ScanGuid (TempFileGuid, PeimCount * sizeof (EFI_GUID), &A= priori[Index2]); + if (Guid !=3D NULL) { + PeimIndex =3D ((UINTN)Guid - (UINTN)&TempFileGuid[0])/sizeof (EF= I_GUID); + CoreFileHandle->FvFileHandles[Index++] =3D=20 + TempFileHandles[PeimIndex]; =20 - // - // Since we have copied the file handle we can remove it from this= list. - // - Private->CurrentFvFileHandles[PeimIndex] =3D NULL; + // + // Since we have copied the file handle we can remove it from th= is list. + // + TempFileHandles[PeimIndex] =3D NULL; + } } =20 // - // Update valid Aprioricount + // Update valid AprioriCount // Private->AprioriCount =3D Index; =20 // // Add in any PEIMs not in the Apriori file // - for (;Index < PeimCount; Index++) { - for (Index2 =3D 0; Index2 < PeimCount; Index2++) { - if (Private->CurrentFvFileHandles[Index2] !=3D NULL) { - TempFileHandles[Index] =3D Private->CurrentFvFileHandles[Index= 2]; - Private->CurrentFvFileHandles[Index2] =3D NULL; - break; - } + for (Index2 =3D 0; Index2 < PeimCount; Index2++) { + if (TempFileHandles[Index2] !=3D NULL) { + CoreFileHandle->FvFileHandles[Index++] =3D TempFileHandles[Index= 2]; + TempFileHandles[Index2] =3D NULL; } } - // - //Index the end of array contains re-range Pei moudle. - // - TempFileHandles[Index] =3D NULL; - - // - // Private->CurrentFvFileHandles is currently in PEIM in the FV orde= r. - // We need to update it to start with files in the A Priori list and - // then the remaining files in PEIM order. - // - CopyMem (Private->CurrentFvFileHandles, TempFileHandles, sizeof (EFI= _PEI_FILE_HANDLE) * PcdGet32 (PcdPeiCoreMaxPeimPerFv)); + ASSERT (Index =3D=3D PeimCount); } + } else { + CopyMem (CoreFileHandle->FvFileHandles, TempFileHandles, sizeof=20 + (EFI_PEI_FILE_HANDLE) * PeimCount); } + // - // Cache the current Fv File Handle. So that we don't have to scan the F= v again. - // Instead, we can retrieve the file handles within this Fv from cachabl= e data. + // The current Fv File Handles have been cached. So that we don't have t= o scan the Fv again. + // Instead, we can retrieve the file handles within this Fv from cached = records. // - Private->Fv[Private->CurrentPeimFvCount].ScanFv =3D TRUE; - CopyMem (Private->Fv[Private->CurrentPeimFvCount].FvFileHandles, Private= ->CurrentFvFileHandles, sizeof (EFI_PEI_FILE_HANDLE) * PcdGet32 (PcdPeiCore= MaxPeimPerFv)); - + CoreFileHandle->ScanFv =3D TRUE; + Private->CurrentFvFileHandles =3D CoreFileHandle->FvFileHandles; } =20 // @@ -977,7 +1004,7 @@ PeiDispatcher ( SaveCurrentFileHandle =3D Private->CurrentFileHandle; =20 for (Index1 =3D 0; Index1 < Private->FvCount; Index1++) { - for (Index2 =3D 0; (Index2 < PcdGet32 (PcdPeiCoreMaxPeimPerFv)) && (= Private->Fv[Index1].FvFileHandles[Index2] !=3D NULL); Index2++) { + for (Index2 =3D 0; Index2 < Private->Fv[Index1].PeimCount;=20 + Index2++) { if (Private->Fv[Index1].PeimState[Index2] =3D=3D PEIM_STATE_REGIST= ER_FOR_SHADOW) { PeimFileHandle =3D Private->Fv[Index1].FvFileHandles[Index2]; Private->CurrentFileHandle =3D PeimFileHandle; @@ -1063,7 +1090,7 @@ PeiDispatcher ( // Start to dispatch all modules within the current Fv. // for (PeimCount =3D Private->CurrentPeimCount; - (PeimCount < PcdGet32 (PcdPeiCoreMaxPeimPerFv)) && (Private->Cu= rrentFvFileHandles[PeimCount] !=3D NULL); + PeimCount < Private->Fv[FvCount].PeimCount; PeimCount++) { Private->CurrentPeimCount =3D PeimCount; PeimFileHandle =3D Private->CurrentFileHandle =3D Private->Current= FvFileHandles[PeimCount]; @@ -1207,21 +1234,17 @@ PeiDispatcher ( } =20 // - // We set to NULL here to optimize the 2nd entry to this routine aft= er - // memory is found. This reprevents rescanning of the FV. We set to - // NULL here so we start at the begining of the next FV + // Before walking through the next FV, we should set them to NULL/0 = to + // start at the begining of the next FV. // Private->CurrentFileHandle =3D NULL; Private->CurrentPeimCount =3D 0; - // - // Before walking through the next FV,Private->CurrentFvFileHandles[= ]should set to NULL - // - SetMem (Private->CurrentFvFileHandles, sizeof (EFI_PEI_FILE_HANDLE) = * PcdGet32 (PcdPeiCoreMaxPeimPerFv), 0); + Private->CurrentFvFileHandles =3D NULL; } =20 // - // Before making another pass, we should set Private->CurrentPeimFvCou= nt =3D0 to go - // through all the FV. + // Before making another pass, we should set it to 0 to + // go through all the FVs. // Private->CurrentPeimFvCount =3D 0; =20 @@ -1300,7 +1323,7 @@ DepexSatisfied ( =20 if (PeimCount < Private->AprioriCount) { // - // If its in the A priori file then we set Depex to TRUE + // If it's in the Apriori file then we set Depex to TRUE // DEBUG ((DEBUG_DISPATCH, " RESULT =3D TRUE (Apriori)\n")); return TRUE; diff --git a/MdeModulePkg/Core/Pei/PeiMain.h b/MdeModulePkg/Core/Pei/PeiMai= n.h index 6469436b8f79..195bdc3425b6 100644 --- a/MdeModulePkg/Core/Pei/PeiMain.h +++ b/MdeModulePkg/Core/Pei/PeiMain.h @@ -111,12 +111,13 @@ typedef struct { EFI_FIRMWARE_VOLUME_HEADER *FvHeader; EFI_PEI_FIRMWARE_VOLUME_PPI *FvPpi; EFI_PEI_FV_HANDLE FvHandle; + UINTN PeimCount; // - // Ponter to the buffer with the PcdPeiCoreMaxPeimPerFv number of Entrie= s. + // Ponter to the buffer with the PeimCount number of Entries. // UINT8 *PeimState; // - // Ponter to the buffer with the PcdPeiCoreMaxPeimPerFv number of Entrie= s. + // Ponter to the buffer with the PeimCount number of Entries. // EFI_PEI_FILE_HANDLE *FvFileHandles; BOOLEAN ScanFv; @@ -176,6 +177,11 @@ EFI_STATUS IN PEI_CORE_INSTANCE *OldCoreData ); =20 +// +// Number of files to grow by each time we run out of room // #define=20 +TEMP_FILE_GROWTH_STEP 32 + #define PEI_CORE_HANDLE_SIGNATURE SIGNATURE_32('P','e','i','C') =20 /// @@ -209,7 +215,7 @@ struct _PEI_CORE_INSTANCE { UINTN UnknownFvInfoCount; =20 /// - /// Pointer to the buffer with the PcdPeiCoreMaxPeimPerFv number of entr= ies. + /// Pointer to the buffer FvFileHandlers in PEI_CORE_FV_HANDLE specified= by CurrentPeimFvCount. /// EFI_PEI_FILE_HANDLE *CurrentFvFileHandles; UINTN AprioriCount; @@ -256,14 +262,16 @@ struct _PEI_CORE_INSTANCE { // PE_COFF_LOADER_READ_FILE ShadowedImageRead; =20 + UINTN TempPeimCount; + // - // Pointer to the temp buffer with the PcdPeiCoreMaxPeimPerFv + 1 number= of entries. + // Pointer to the temp buffer with the TempPeimCount number of entries. // - EFI_PEI_FILE_HANDLE *FileHandles; + EFI_PEI_FILE_HANDLE *TempFileHandles; // - // Pointer to the temp buffer with the PcdPeiCoreMaxPeimPerFv number of = entries. + // Pointer to the temp buffer with the TempPeimCount number of entries. // - EFI_GUID *FileGuid; + EFI_GUID *TempFileGuid; =20 // // Temp Memory Range is not covered by PeiTempMem and Stack. diff --git a/MdeModulePkg/Core/Pei/PeiMain.inf b/MdeModulePkg/Core/Pei/PeiM= ain.inf index 4e1581a926d9..d106c3606e97 100644 --- a/MdeModulePkg/Core/Pei/PeiMain.inf +++ b/MdeModulePkg/Core/Pei/PeiMain.inf @@ -105,7 +105,6 @@ [Ppis] =20 [Pcd] gEfiMdeModulePkgTokenSpaceGuid.PcdPeiCoreMaxFvSupported = ## CONSUMES - gEfiMdeModulePkgTokenSpaceGuid.PcdPeiCoreMaxPeimPerFv = ## CONSUMES gEfiMdeModulePkgTokenSpaceGuid.PcdPeiCoreMaxPpiSupported = ## CONSUMES gEfiMdeModulePkgTokenSpaceGuid.PcdPeiCoreMaxPeiStackSize = ## CONSUMES gEfiMdeModulePkgTokenSpaceGuid.PcdPeiCoreImageLoaderSearchTeSectionFirst= ## CONSUMES diff --git a/MdeModulePkg/Core/Pei/PeiMain/PeiMain.c b/MdeMod= ulePkg/Core/Pei/PeiMain/PeiMain.c index e3a301dfe0f2..52adefeb44b4 100644 --- a/MdeModulePkg/Core/Pei/PeiMain/PeiMain.c +++ b/MdeModulePkg/Core/Pei/PeiMain/PeiMain.c @@ -185,27 +185,39 @@ PeiCore ( if (OldCoreData->HeapOffsetPositive) { OldCoreData->HobList.Raw =3D (VOID *)(OldCoreData->HobList.Raw + O= ldCoreData->HeapOffset); OldCoreData->UnknownFvInfo =3D (PEI_CORE_UNKNOW_FORMAT_FV_I= NFO *) ((UINT8 *) OldCoreData->UnknownFvInfo + OldCoreData->HeapOffset); - OldCoreData->CurrentFvFileHandles =3D (EFI_PEI_FILE_HANDLE *) ((UI= NT8 *) OldCoreData->CurrentFvFileHandles + OldCoreData->HeapOffset); + if (OldCoreData->CurrentFvFileHandles !=3D NULL) { + OldCoreData->CurrentFvFileHandles =3D (EFI_PEI_FILE_HANDLE *) ((= UINT8 *) OldCoreData->CurrentFvFileHandles + OldCoreData->HeapOffset); + } OldCoreData->PpiData.PpiListPtrs =3D (PEI_PPI_LIST_POINTERS *) ((= UINT8 *) OldCoreData->PpiData.PpiListPtrs + OldCoreData->HeapOffset); OldCoreData->Fv =3D (PEI_CORE_FV_HANDLE *) ((UIN= T8 *) OldCoreData->Fv + OldCoreData->HeapOffset); for (Index =3D 0; Index < PcdGet32 (PcdPeiCoreMaxFvSupported); Ind= ex ++) { - OldCoreData->Fv[Index].PeimState =3D (UINT8 *) OldCoreData->= Fv[Index].PeimState + OldCoreData->HeapOffset; - OldCoreData->Fv[Index].FvFileHandles =3D (EFI_PEI_FILE_HANDLE *)= ((UINT8 *) OldCoreData->Fv[Index].FvFileHandles + OldCoreData->HeapOffset)= ; + if (OldCoreData->Fv[Index].PeimState !=3D NULL) { + OldCoreData->Fv[Index].PeimState =3D (UINT8 *) OldCoreData= ->Fv[Index].PeimState + OldCoreData->HeapOffset; + } + if (OldCoreData->Fv[Index].FvFileHandles !=3D NULL) { + OldCoreData->Fv[Index].FvFileHandles =3D (EFI_PEI_FILE_HANDLE = *) ((UINT8 *) OldCoreData->Fv[Index].FvFileHandles + OldCoreData->HeapOffse= t); + } } - OldCoreData->FileGuid =3D (EFI_GUID *) ((UINT8 *) OldC= oreData->FileGuid + OldCoreData->HeapOffset); - OldCoreData->FileHandles =3D (EFI_PEI_FILE_HANDLE *) ((UI= NT8 *) OldCoreData->FileHandles + OldCoreData->HeapOffset); + OldCoreData->TempFileGuid =3D (EFI_GUID *) ((UINT8 *) OldC= oreData->TempFileGuid + OldCoreData->HeapOffset); + OldCoreData->TempFileHandles =3D (EFI_PEI_FILE_HANDLE *) ((UI= NT8 *) OldCoreData->TempFileHandles + OldCoreData->HeapOffset); } else { OldCoreData->HobList.Raw =3D (VOID *)(OldCoreData->HobList.Raw - O= ldCoreData->HeapOffset); OldCoreData->UnknownFvInfo =3D (PEI_CORE_UNKNOW_FORMAT_FV_I= NFO *) ((UINT8 *) OldCoreData->UnknownFvInfo - OldCoreData->HeapOffset); - OldCoreData->CurrentFvFileHandles =3D (EFI_PEI_FILE_HANDLE *) ((UI= NT8 *) OldCoreData->CurrentFvFileHandles - OldCoreData->HeapOffset); + if (OldCoreData->CurrentFvFileHandles !=3D NULL) { + OldCoreData->CurrentFvFileHandles =3D (EFI_PEI_FILE_HANDLE *) ((= UINT8 *) OldCoreData->CurrentFvFileHandles - OldCoreData->HeapOffset); + } OldCoreData->PpiData.PpiListPtrs =3D (PEI_PPI_LIST_POINTERS *) ((= UINT8 *) OldCoreData->PpiData.PpiListPtrs - OldCoreData->HeapOffset); OldCoreData->Fv =3D (PEI_CORE_FV_HANDLE *) ((UIN= T8 *) OldCoreData->Fv - OldCoreData->HeapOffset); for (Index =3D 0; Index < PcdGet32 (PcdPeiCoreMaxFvSupported); Ind= ex ++) { - OldCoreData->Fv[Index].PeimState =3D (UINT8 *) OldCoreData->= Fv[Index].PeimState - OldCoreData->HeapOffset; - OldCoreData->Fv[Index].FvFileHandles =3D (EFI_PEI_FILE_HANDLE *)= ((UINT8 *) OldCoreData->Fv[Index].FvFileHandles - OldCoreData->HeapOffset)= ; + if (OldCoreData->Fv[Index].PeimState !=3D NULL) { + OldCoreData->Fv[Index].PeimState =3D (UINT8 *) OldCoreData= ->Fv[Index].PeimState - OldCoreData->HeapOffset; + } + if (OldCoreData->Fv[Index].FvFileHandles !=3D NULL) { + OldCoreData->Fv[Index].FvFileHandles =3D (EFI_PEI_FILE_HANDLE = *) ((UINT8 *) OldCoreData->Fv[Index].FvFileHandles - OldCoreData->HeapOffse= t); + } } - OldCoreData->FileGuid =3D (EFI_GUID *) ((UINT8 *) OldC= oreData->FileGuid - OldCoreData->HeapOffset); - OldCoreData->FileHandles =3D (EFI_PEI_FILE_HANDLE *) ((UI= NT8 *) OldCoreData->FileHandles - OldCoreData->HeapOffset); + OldCoreData->TempFileGuid =3D (EFI_GUID *) ((UINT8 *) OldC= oreData->TempFileGuid - OldCoreData->HeapOffset); + OldCoreData->TempFileHandles =3D (EFI_PEI_FILE_HANDLE *) ((UI= NT8 *) OldCoreData->TempFileHandles - OldCoreData->HeapOffset); } =20 // @@ -320,7 +332,7 @@ PeiCore ( // // Initialize PEI Core Services // - InitializeMemoryServices (&PrivateData, SecCoreData, OldCoreData); + InitializeMemoryServices (&PrivateData, SecCoreData, OldCoreData); if (OldCoreData =3D=3D NULL) { // // Initialize PEI Core Private Data Buffer @@ -329,22 +341,8 @@ PeiCor= e ( ASSERT (PrivateData.PpiData.PpiListPtrs !=3D NULL); PrivateData.Fv =3D AllocateZeroPool (sizeof (PEI_COR= E_FV_HANDLE) * PcdGet32 (PcdPeiCoreMaxFvSupported)); ASSERT (PrivateData.Fv !=3D NULL); - PrivateData.Fv[0].PeimState =3D AllocateZeroPool (sizeof (UINT8) = * PcdGet32 (PcdPeiCoreMaxPeimPerFv) * PcdGet32 (PcdPeiCoreMaxFvSupported)); - ASSERT (PrivateData.Fv[0].PeimState !=3D NULL); - PrivateData.Fv[0].FvFileHandles =3D AllocateZeroPool (sizeof (EFI_PEI= _FILE_HANDLE) * PcdGet32 (PcdPeiCoreMaxPeimPerFv) * PcdGet32 (PcdPeiCoreMax= FvSupported)); - ASSERT (PrivateData.Fv[0].FvFileHandles !=3D NULL); - for (Index =3D 1; Index < PcdGet32 (PcdPeiCoreMaxFvSupported); Index += +) { - PrivateData.Fv[Index].PeimState =3D PrivateData.Fv[Index - 1].Pe= imState + PcdGet32 (PcdPeiCoreMaxPeimPerFv); - PrivateData.Fv[Index].FvFileHandles =3D PrivateData.Fv[Index - 1].Fv= FileHandles + PcdGet32 (PcdPeiCoreMaxPeimPerFv); - } PrivateData.UnknownFvInfo =3D AllocateZeroPool (sizeof (PEI_COR= E_UNKNOW_FORMAT_FV_INFO) * PcdGet32 (PcdPeiCoreMaxFvSupported)); ASSERT (PrivateData.UnknownFvInfo !=3D NULL); - PrivateData.CurrentFvFileHandles =3D AllocateZeroPool (sizeof (EFI_PEI= _FILE_HANDLE) * PcdGet32 (PcdPeiCoreMaxPeimPerFv)); - ASSERT (PrivateData.CurrentFvFileHandles !=3D NULL); - PrivateData.FileGuid =3D AllocatePool (sizeof (EFI_GUID) *= PcdGet32 (PcdPeiCoreMaxPeimPerFv)); - ASSERT (PrivateData.FileGuid !=3D NULL); - PrivateData.FileHandles =3D AllocatePool (sizeof (EFI_PEI_FIL= E_HANDLE) * (PcdGet32 (PcdPeiCoreMaxPeimPerFv) + 1)); - ASSERT (PrivateData.FileHandles !=3D NULL); } InitializePpiServices (&PrivateData, OldCoreData); =20 -- 2.7.0.windows.1