+++ /dev/null
-#------------------------------------------------------------------------------\r
-#\r
-# Copyright (c) 2006 - 2012, 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
-#\r
-# Module Name:\r
-#\r
-# LongJump.S\r
-#\r
-# Abstract:\r
-#\r
-# Implementation of _LongJump() on x64.\r
-#\r
-#------------------------------------------------------------------------------\r
-#include <EdkIIGlueBase.h>\r
-#------------------------------------------------------------------------------\r
-# VOID\r
-# EFIAPI\r
-# InternalLongJump (\r
-# IN BASE_LIBRARY_JUMP_BUFFER *JumpBuffer,\r
-# IN UINTN Value\r
-# );\r
-#------------------------------------------------------------------------------\r
-.globl ASM_PFX(InternalLongJump)\r
-ASM_PFX(InternalLongJump):\r
- mov (%rcx), %rbx\r
- mov 0x8(%rcx), %rsp\r
- mov 0x10(%rcx), %rbp\r
- mov 0x18(%rcx), %rdi\r
- mov 0x20(%rcx), %rsi\r
- mov 0x28(%rcx), %r12\r
- mov 0x30(%rcx), %r13\r
- mov 0x38(%rcx), %r14\r
- mov 0x40(%rcx), %r15\r
- # load non-volatile fp registers\r
- ldmxcsr 0x50(%rcx)\r
- movdqu 0x58(%rcx), %xmm6\r
- movdqu 0x68(%rcx), %xmm7\r
- movdqu 0x78(%rcx), %xmm8\r
- movdqu 0x88(%rcx), %xmm9\r
- movdqu 0x98(%rcx), %xmm10\r
- movdqu 0xA8(%rcx), %xmm11\r
- movdqu 0xB8(%rcx), %xmm12\r
- movdqu 0xC8(%rcx), %xmm13\r
- movdqu 0xD8(%rcx), %xmm14\r
- movdqu 0xE8(%rcx), %xmm15 \r
- mov %rdx, %rax # set return value\r
- jmp *0x48(%rcx)\r