git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@10806 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			54 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
		
			1.6 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:
 | |
| #
 | |
| #   SetJump.S
 | |
| #
 | |
| # Abstract:
 | |
| #
 | |
| #   Implementation of SetJump() on x86_64
 | |
| #
 | |
| #------------------------------------------------------------------------------
 | |
| 
 | |
| ASM_GLOBAL ASM_PFX(SetJump)
 | |
| ASM_PFX(SetJump):
 | |
|     push   %rcx
 | |
|     add    $0xffffffffffffffe0,%rsp
 | |
|     call   ASM_PFX(InternalAssertJumpBuffer)
 | |
|     add    $0x20,%rsp
 | |
|     pop    %rcx
 | |
|     pop    %rdx
 | |
|     mov    %rbx,(%rcx)
 | |
|     mov    %rsp,0x8(%rcx)
 | |
|     mov    %rbp,0x10(%rcx)
 | |
|     mov    %rdi,0x18(%rcx)
 | |
|     mov    %rsi,0x20(%rcx)
 | |
|     mov    %r12,0x28(%rcx)
 | |
|     mov    %r13,0x30(%rcx)
 | |
|     mov    %r14,0x38(%rcx)
 | |
|     mov    %r15,0x40(%rcx)
 | |
|     mov    %rdx,0x48(%rcx)
 | |
|     # save non-volatile fp registers
 | |
|     stmxcsr 0x50(%rcx)
 | |
|     movdqu  %xmm6, 0x58(%rcx) 
 | |
|     movdqu  %xmm7, 0x68(%rcx)
 | |
|     movdqu  %xmm8, 0x78(%rcx)
 | |
|     movdqu  %xmm9, 0x88(%rcx)
 | |
|     movdqu  %xmm10, 0x98(%rcx)
 | |
|     movdqu  %xmm11, 0xA8(%rcx)
 | |
|     movdqu  %xmm12, 0xB8(%rcx)
 | |
|     movdqu  %xmm13, 0xC8(%rcx)
 | |
|     movdqu  %xmm14, 0xD8(%rcx)
 | |
|     movdqu  %xmm15, 0xE8(%rcx)     
 | |
|     xor    %rax,%rax
 | |
|     jmpq   *%rdx
 |