2016-05-31 03:52:00 +02:00
|
|
|
;------------------------------------------------------------------------------
|
|
|
|
;
|
2019-02-22 14:30:34 +01:00
|
|
|
; Copyright (c) 2006 - 2019, Intel Corporation. All rights reserved.<BR>
|
2016-05-31 03:52:00 +02:00
|
|
|
; 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.Asm
|
|
|
|
;
|
|
|
|
; Abstract:
|
|
|
|
;
|
|
|
|
; Implementation of SetJump() on x64.
|
|
|
|
;
|
|
|
|
;------------------------------------------------------------------------------
|
|
|
|
|
2019-02-22 14:30:34 +01:00
|
|
|
%include "Nasm.inc"
|
|
|
|
|
2016-05-31 03:52:00 +02:00
|
|
|
DEFAULT REL
|
|
|
|
SECTION .text
|
|
|
|
|
|
|
|
extern ASM_PFX(InternalAssertJumpBuffer)
|
2019-02-22 14:30:34 +01:00
|
|
|
extern ASM_PFX(PcdGet32 (PcdControlFlowEnforcementPropertyMask))
|
2016-05-31 03:52:00 +02:00
|
|
|
|
|
|
|
;------------------------------------------------------------------------------
|
|
|
|
; UINTN
|
|
|
|
; EFIAPI
|
|
|
|
; SetJump (
|
|
|
|
; OUT BASE_LIBRARY_JUMP_BUFFER *JumpBuffer
|
|
|
|
; );
|
|
|
|
;------------------------------------------------------------------------------
|
|
|
|
global ASM_PFX(SetJump)
|
|
|
|
ASM_PFX(SetJump):
|
|
|
|
push rcx
|
|
|
|
add rsp, -0x20
|
|
|
|
call ASM_PFX(InternalAssertJumpBuffer)
|
|
|
|
add rsp, 0x20
|
|
|
|
pop rcx
|
|
|
|
pop rdx
|
2019-02-22 14:30:34 +01:00
|
|
|
|
|
|
|
xor rax, rax
|
|
|
|
mov [rcx + 0xF8], rax ; save 0 to SSP
|
|
|
|
|
|
|
|
mov eax, [ASM_PFX(PcdGet32 (PcdControlFlowEnforcementPropertyMask))]
|
|
|
|
test eax, eax
|
|
|
|
jz CetDone
|
|
|
|
mov rax, cr4
|
|
|
|
bt eax, 23 ; check if CET is enabled
|
|
|
|
jnc CetDone
|
|
|
|
|
|
|
|
mov rax, 1
|
|
|
|
INCSSP_RAX ; to read original SSP
|
|
|
|
READSSP_RAX
|
|
|
|
mov [rcx + 0xF8], rax ; save SSP
|
|
|
|
|
|
|
|
CetDone:
|
|
|
|
|
2016-05-31 03:52:00 +02:00
|
|
|
mov [rcx], rbx
|
|
|
|
mov [rcx + 8], rsp
|
|
|
|
mov [rcx + 0x10], rbp
|
|
|
|
mov [rcx + 0x18], rdi
|
|
|
|
mov [rcx + 0x20], rsi
|
|
|
|
mov [rcx + 0x28], r12
|
|
|
|
mov [rcx + 0x30], r13
|
|
|
|
mov [rcx + 0x38], r14
|
|
|
|
mov [rcx + 0x40], r15
|
|
|
|
mov [rcx + 0x48], rdx
|
|
|
|
; save non-volatile fp registers
|
|
|
|
stmxcsr [rcx + 0x50]
|
|
|
|
movdqu [rcx + 0x58], xmm6
|
|
|
|
movdqu [rcx + 0x68], xmm7
|
|
|
|
movdqu [rcx + 0x78], xmm8
|
|
|
|
movdqu [rcx + 0x88], xmm9
|
|
|
|
movdqu [rcx + 0x98], xmm10
|
|
|
|
movdqu [rcx + 0xA8], xmm11
|
|
|
|
movdqu [rcx + 0xB8], xmm12
|
|
|
|
movdqu [rcx + 0xC8], xmm13
|
|
|
|
movdqu [rcx + 0xD8], xmm14
|
|
|
|
movdqu [rcx + 0xE8], xmm15
|
|
|
|
xor rax, rax
|
|
|
|
jmp rdx
|
|
|
|
|