| ;------------------------------------------------------------------------------ | |
| ; | |
| ; Copyright (c) 2006 - 2012, Intel Corporation. All rights reserved.<BR> | |
| ; Portions copyright (c) 2011, Apple Inc. All rights reserved. | |
| ; SPDX-License-Identifier: BSD-2-Clause-Patent | |
| ; | |
| ;------------------------------------------------------------------------------ | |
| EXTERN CopyMem:PROC | |
| EXTERN ZeroMem:PROC | |
| .code | |
| ;------------------------------------------------------------------------------ | |
| ; EFI_STATUS | |
| ; EFIAPI | |
| ; SecTemporaryRamSupport ( | |
| ; IN CONST EFI_PEI_SERVICES **PeiServices, // %rcx | |
| ; IN EFI_PHYSICAL_ADDRESS TemporaryMemoryBase, // %rdx | |
| ; IN EFI_PHYSICAL_ADDRESS PermanentMemoryBase, // %r8 | |
| ; IN UINTN CopySize // %r9 | |
| ; ) | |
| ;------------------------------------------------------------------------------ | |
| SecTemporaryRamSupport PROC | |
| ; Adjust callers %rbp to account for stack move | |
| sub rbp, rdx ; Calc offset of %rbp in Temp Memory | |
| add rbp, r8 ; add in permanent base to offset | |
| push rbp ; stack frame is for the debugger | |
| mov rbp, rsp | |
| push rdx ; Save TemporaryMemoryBase | |
| push r8 ; Save PermanentMemoryBase | |
| push r9 ; Save CopySize | |
| ; | |
| ; Copy all of temp RAM to permanent memory, including stack | |
| ; | |
| ; CopyMem (PermanentMemoryBase, TemporaryMemoryBase, CopySize); | |
| ; %rcx, %rdx, %r8 | |
| mov rcx, r8 ; Shift arguments | |
| mov r8, r9 | |
| sub rsp, 028h ; Allocate register spill area & 16-byte align stack | |
| call CopyMem | |
| ; Temp mem stack now copied to permanent location. %esp still in temp memory | |
| add rsp, 028h | |
| pop r9 ; CopySize (old stack) | |
| pop r8 ; PermanentMemoryBase (old stack) | |
| pop rdx ; TemporaryMemoryBase (old stack) | |
| mov rcx, rsp ; Move to new stack | |
| sub rcx, rdx ; Calc offset of stack in Temp Memory | |
| add rcx, r8 ; Calc PermanentMemoryBase address | |
| mov rsp, rcx ; Update stack | |
| ; Stack now points to permanent memory | |
| ; ZeroMem (TemporaryMemoryBase /* rcx */, CopySize /* rdx */); | |
| mov rcx, rdx | |
| mov rdx, r9 | |
| sub rsp, 028h ; Allocate register spill area & 16-byte align stack | |
| call ZeroMem | |
| add rsp, 028h | |
| ; This data comes off the NEW stack | |
| pop rbp | |
| ret | |
| SecTemporaryRamSupport ENDP | |
| END |