2016-10-19 09:01:13 +02:00
|
|
|
/*++ @file
|
|
|
|
Temp RAM PPI
|
|
|
|
|
|
|
|
Copyright (c) 2011, Apple Inc. All rights reserved.<BR>
|
|
|
|
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
|
|
|
|
http://opensource.org/licenses/bsd-license.php
|
|
|
|
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include <PiPei.h>
|
|
|
|
#include <Library/DebugLib.h>
|
|
|
|
#include <Library/BaseMemoryLib.h>
|
|
|
|
|
|
|
|
#include <Ppi/TemporaryRamSupport.h>
|
|
|
|
|
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
SecSwitchStack (
|
|
|
|
UINT32 TemporaryMemoryBase,
|
|
|
|
UINT32 PermenentMemoryBase
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
EFIAPI
|
|
|
|
SecTemporaryRamSupport (
|
|
|
|
IN CONST EFI_PEI_SERVICES **PeiServices,
|
|
|
|
IN EFI_PHYSICAL_ADDRESS TemporaryMemoryBase,
|
|
|
|
IN EFI_PHYSICAL_ADDRESS PermanentMemoryBase,
|
|
|
|
IN UINTN CopySize
|
|
|
|
)
|
|
|
|
{
|
|
|
|
//
|
|
|
|
// Migrate the whole temporary memory to permanent memory.
|
|
|
|
//
|
|
|
|
CopyMem (
|
|
|
|
(VOID*)(UINTN)PermanentMemoryBase,
|
|
|
|
(VOID*)(UINTN)TemporaryMemoryBase,
|
|
|
|
CopySize
|
|
|
|
);
|
|
|
|
|
|
|
|
//
|
|
|
|
// SecSwitchStack function must be invoked after the memory migration
|
|
|
|
// immediately, also we need fixup the stack change caused by new call into
|
|
|
|
// permanent memory.
|
|
|
|
//
|
|
|
|
SecSwitchStack ((UINT32) TemporaryMemoryBase, (UINT32) PermanentMemoryBase);
|
|
|
|
|
|
|
|
//
|
|
|
|
// We need *not* fix the return address because currently,
|
|
|
|
// The PeiCore is executed in flash.
|
|
|
|
//
|
|
|
|
|
|
|
|
//
|
|
|
|
// Simulate to invalid temporary memory, terminate temporary memory
|
|
|
|
//
|
|
|
|
//ZeroMem ((VOID*)(UINTN)TemporaryMemoryBase, CopySize);
|
|
|
|
|
|
|
|
return EFI_SUCCESS;
|
|
|
|
}
|