2007-07-02 11:34:25 +02:00
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
#
|
2018-06-27 15:11:33 +02:00
|
|
|
# Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>
|
2010-04-23 18:00:47 +02:00
|
|
|
# This program and the accompanying materials
|
2007-07-02 11:34:25 +02:00
|
|
|
# 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
|
2010-06-25 23:56:02 +02:00
|
|
|
# http://opensource.org/licenses/bsd-license.php.
|
2007-07-02 11:34:25 +02:00
|
|
|
#
|
|
|
|
# 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:
|
|
|
|
#
|
2008-10-23 09:02:59 +02:00
|
|
|
# LongJump.S
|
2007-07-02 11:34:25 +02:00
|
|
|
#
|
|
|
|
# Abstract:
|
|
|
|
#
|
|
|
|
# Implementation of _LongJump() on x64.
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
# VOID
|
|
|
|
# EFIAPI
|
|
|
|
# InternalLongJump (
|
|
|
|
# IN BASE_LIBRARY_JUMP_BUFFER *JumpBuffer,
|
|
|
|
# IN UINTN Value
|
|
|
|
# );
|
|
|
|
#------------------------------------------------------------------------------
|
2009-05-20 11:42:59 +02:00
|
|
|
ASM_GLOBAL ASM_PFX(InternalLongJump)
|
2008-07-31 08:23:32 +02:00
|
|
|
ASM_PFX(InternalLongJump):
|
2007-07-02 11:34:25 +02:00
|
|
|
mov (%rcx), %rbx
|
|
|
|
mov 0x8(%rcx), %rsp
|
|
|
|
mov 0x10(%rcx), %rbp
|
|
|
|
mov 0x18(%rcx), %rdi
|
|
|
|
mov 0x20(%rcx), %rsi
|
|
|
|
mov 0x28(%rcx), %r12
|
|
|
|
mov 0x30(%rcx), %r13
|
|
|
|
mov 0x38(%rcx), %r14
|
|
|
|
mov 0x40(%rcx), %r15
|
2009-06-10 10:07:37 +02:00
|
|
|
# load non-volatile fp registers
|
|
|
|
ldmxcsr 0x50(%rcx)
|
2009-06-10 11:00:21 +02:00
|
|
|
movdqu 0x58(%rcx), %xmm6
|
|
|
|
movdqu 0x68(%rcx), %xmm7
|
|
|
|
movdqu 0x78(%rcx), %xmm8
|
|
|
|
movdqu 0x88(%rcx), %xmm9
|
|
|
|
movdqu 0x98(%rcx), %xmm10
|
|
|
|
movdqu 0xA8(%rcx), %xmm11
|
|
|
|
movdqu 0xB8(%rcx), %xmm12
|
|
|
|
movdqu 0xC8(%rcx), %xmm13
|
|
|
|
movdqu 0xD8(%rcx), %xmm14
|
2018-06-27 15:11:33 +02:00
|
|
|
movdqu 0xE8(%rcx), %xmm15
|
2008-10-28 15:23:36 +01:00
|
|
|
mov %rdx, %rax # set return value
|
2007-07-02 11:34:25 +02:00
|
|
|
jmp *0x48(%rcx)
|