;------------------------------------------------------------------------------ ; ; Copyright (c) 2006 - 2022, Intel Corporation. All rights reserved.
; SPDX-License-Identifier: BSD-2-Clause-Patent ; ; Module Name: ; ; LongJump.Asm ; ; Abstract: ; ; Implementation of _LongJump() on IA-32. ; ;------------------------------------------------------------------------------ %include "Nasm.inc" SECTION .text extern ASM_PFX(PcdGet32 (PcdControlFlowEnforcementPropertyMask)) ;------------------------------------------------------------------------------ ; VOID ; EFIAPI ; InternalLongJump ( ; IN BASE_LIBRARY_JUMP_BUFFER *JumpBuffer, ; IN UINTN Value ; ); ;------------------------------------------------------------------------------ global ASM_PFX(InternalLongJump) ASM_PFX(InternalLongJump): mov eax, [ASM_PFX(PcdGet32 (PcdControlFlowEnforcementPropertyMask))] test eax, eax jz CetDone mov eax, cr4 bt eax, 23 ; check if CET is enabled jnc CetDone mov edx, [esp + 4] ; edx = JumpBuffer mov edx, [edx + 24] ; edx = target SSP rdsspd eax sub edx, eax ; edx = delta mov eax, edx ; eax = delta shr eax, 2 ; eax = delta/sizeof(UINT32) incsspd eax CetDone: pop eax ; skip return address pop edx ; edx <- JumpBuffer pop eax ; eax <- Value mov ebx, [edx] mov esi, [edx + 4] mov edi, [edx + 8] mov ebp, [edx + 12] mov esp, [edx + 16] jmp dword [edx + 20] ; restore "eip"