/** @file\r
\r
Copyright (c) 2014 - 2015, Intel Corporation. All rights reserved.<BR>\r
- This program and the accompanying materials\r
- are licensed and made available under the terms and conditions of the BSD License\r
- which accompanies this distribution. The full text of the license may be found at\r
- http://opensource.org/licenses/bsd-license.php.\r
-\r
- THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
- WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+ SPDX-License-Identifier: BSD-2-Clause-Patent\r
\r
**/\r
\r
}\r
\r
/**\r
- Migrate bootloader data before destroying CAR.\r
+ Migrate BootLoader data before destroying CAR.\r
\r
**/\r
VOID\r
FSP_INIT_PARAMS *FspInitParams;\r
UINT32 *NewStackTop;\r
VOID *BootLoaderTempRamHob;\r
- VOID *UpdDataRgnPtr;\r
+ UINT32 UpdDataRgnPtr;\r
+ UINT32 MemoryInitUpdPtr;\r
+ UINT32 SiliconInitUpdPtr;\r
VOID *PlatformDataPtr;\r
UINT8 ApiMode;\r
\r
ApiMode = GetFspApiCallingMode ();\r
\r
//\r
- // Get the temporary memory range used by the bootloader\r
+ // Get the temporary memory range used by the BootLoader\r
//\r
BootLoaderTempRamStart = PcdGet32(PcdTemporaryRamBase);\r
BootLoaderTempRamSize = PcdGet32(PcdTemporaryRamSize) - PcdGet32(PcdFspTemporaryRamSize);\r
// Build a Boot Loader Temporary Memory GUID HOB\r
//\r
if (ApiMode == 0) {\r
- BootLoaderTempRamHob = BuildGuidHob (&gFspBootLoaderTempMemoryGuid, BootLoaderTempRamSize);\r
+ BootLoaderTempRamHob = BuildGuidHob (&gFspBootLoaderTemporaryMemoryGuid, BootLoaderTempRamSize);\r
} else {\r
- BootLoaderTempRamHob = (VOID *)AllocatePool (BootLoaderTempRamSize);\r
+ BootLoaderTempRamHob = (VOID *)AllocatePages (EFI_SIZE_TO_PAGES (BootLoaderTempRamSize));\r
}\r
+ ASSERT(BootLoaderTempRamHob != NULL);\r
\r
CopyMem (BootLoaderTempRamHob, (VOID *)BootLoaderTempRamStart, BootLoaderTempRamSize);\r
OffsetGap = (UINT32)BootLoaderTempRamHob - BootLoaderTempRamStart;\r
//\r
// Update UPD pointer in FSP Global Data\r
//\r
- UpdDataRgnPtr = ((FSP_INIT_RT_COMMON_BUFFER *)FspInitParams->RtBufferPtr)->UpdDataRgnPtr;\r
- if (UpdDataRgnPtr != NULL) {\r
- SetFspUpdDataPointer (UpdDataRgnPtr);\r
+ if (ApiMode == 0) {\r
+ UpdDataRgnPtr = (UINT32)((UINT32 *)GetFspUpdDataPointer ());\r
+ if (UpdDataRgnPtr >= BootLoaderTempRamStart && UpdDataRgnPtr < BootLoaderTempRamEnd) {\r
+ MemoryInitUpdPtr = (UINT32)((UINT32 *)GetFspMemoryInitUpdDataPointer ());\r
+ SiliconInitUpdPtr = (UINT32)((UINT32 *)GetFspSiliconInitUpdDataPointer ());\r
+ SetFspUpdDataPointer ((VOID *)(UpdDataRgnPtr + OffsetGap));\r
+ SetFspMemoryInitUpdDataPointer ((VOID *)(MemoryInitUpdPtr + OffsetGap));\r
+ SetFspSiliconInitUpdDataPointer ((VOID *)(SiliconInitUpdPtr + OffsetGap));\r
+ }\r
+ } else {\r
+ MemoryInitUpdPtr = (UINT32)((UINT32 *)GetFspMemoryInitUpdDataPointer ());\r
+ if (MemoryInitUpdPtr >= BootLoaderTempRamStart && MemoryInitUpdPtr < BootLoaderTempRamEnd) {\r
+ SetFspMemoryInitUpdDataPointer ((VOID *)(MemoryInitUpdPtr + OffsetGap));\r
+ }\r
}\r
\r
//\r