git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@11297 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			120 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			120 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| #------------------------------------------------------------------------------
 | |
| #
 | |
| # Copyright (c) 2006 - 2008, Intel Corporation. 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.
 | |
| #
 | |
| # Module Name:
 | |
| #
 | |
| #   SwitchStack.S
 | |
| #
 | |
| # Abstract:
 | |
| #
 | |
| #------------------------------------------------------------------------------
 | |
| 
 | |
| 
 | |
| #------------------------------------------------------------------------------
 | |
| # Routine Description:
 | |
| #
 | |
| #   Routine for switching stacks with 3 parameters EFI ABI
 | |
| #   Convert UNIX to EFI ABI
 | |
| #
 | |
| # Arguments:
 | |
| #
 | |
| #   (rdi) EntryPoint    - Entry point with new stack.
 | |
| #   (rsi) Context1      - Parameter1 for entry point. (rcx)
 | |
| #   (rdx) Context2      - Parameter2 for entry point. (rdx) 
 | |
| #   (rcx) Context3      - Parameter3 for entry point. (r8)
 | |
| #   (r8)  NewStack      - The pointer to new stack.
 | |
| #
 | |
| # Returns:
 | |
| #
 | |
| #   None
 | |
| #
 | |
| #------------------------------------------------------------------------------
 | |
| ASM_GLOBAL ASM_PFX(PeiSwitchStacks)
 | |
| ASM_PFX(PeiSwitchStacks):
 | |
|     pushq   %rbp            // stack frame is for the debugger
 | |
|     movq    %rsp, %rbp
 | |
| 
 | |
|     movq    %r8,  %rsp
 | |
|     
 | |
|     movq    %rdi, %rax
 | |
|     movq    %rsi, %rcx
 | |
|     movq    %rcx, %r8    
 | |
|     
 | |
|     #
 | |
|     # Reserve space for register parameters (rcx, rdx, r8 & r9) on the stack,
 | |
|     # in case the callee wishes to spill them.
 | |
|     #
 | |
|     subq    $32, %rsp  // 32-byte shadow space plus alignment pad
 | |
|     call    *%rax
 | |
| 
 | |
| 
 | |
| #------------------------------------------------------------------------------
 | |
| # Routine Description:
 | |
| #
 | |
| #   Routine for switching stacks with 3 parameters UNIX ABI
 | |
| #
 | |
| # Arguments:
 | |
| #
 | |
| #   (rdi) EntryPoint    - Entry point with new stack.
 | |
| #   (rsi) Context1      - Parameter1 for entry point.
 | |
| #   (rdx) Context2      - Parameter2 for entry point.
 | |
| #   (rcx) Context3      - Parameter3 for entry point.
 | |
| #   (r8)  NewStack      - The pointer to new stack.
 | |
| #
 | |
| # Returns:
 | |
| #
 | |
| #   None
 | |
| #
 | |
| #------------------------------------------------------------------------------
 | |
| ASM_GLOBAL ASM_PFX(UnixPeiSwitchStacks)
 | |
| ASM_PFX(UnixPeiSwitchStacks):
 | |
|     pushq   %rbp            // stack frame is for the debugger
 | |
|     movq    %rsp, %rbp
 | |
| 
 | |
|     mov     %rdi, %rax
 | |
|     mov     %rsi, %rdi
 | |
|     mov     %rdx, %rsi
 | |
|     mov     %rcx, %rdx
 | |
|     mov     %r8,  %rsp
 | |
|     
 | |
|     
 | |
|     #
 | |
|     # Reserve space for redzone on the stack,
 | |
|     # in case the callee wishes to spill them.
 | |
|     #
 | |
|     lea     -0x80(%rsp), %rsp
 | |
|     call    *%rax
 | |
| 
 | |
| 
 | |
| 
 | |
| #------------------------------------------------------------------------------
 | |
| # VOID
 | |
| # EFIAPI
 | |
| # SecSwitchStack (
 | |
| #   UINT32   TemporaryMemoryBase, // Rcx, Rdi
 | |
| #   UINT32   PermenentMemoryBase  // Rdx, Rsi
 | |
| #   );
 | |
| #------------------------------------------------------------------------------    
 | |
| ASM_GLOBAL ASM_PFX(SecSwitchStack)
 | |
| ASM_PFX(SecSwitchStack):
 | |
|   pushq   %rbp            // stack frame is for the debugger
 | |
|   movq    %rsp, %rbp
 | |
| 
 | |
|   mov     %rsp, %rax
 | |
|   sub     %rdi, %rax
 | |
|   add     %rsi, %rax
 | |
|   mov    (%rip), %r10
 | |
|   mov    %r10, (%rax) 
 | |
|   
 | |
|   popq   %rbp
 | |
|   ret
 | |
|   
 | |
|   
 |