#------------------------------------------------------------------------------ # # Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.
# Portions copyright (c) 2008 - 2009, Apple Inc. All rights reserved.
# SPDX-License-Identifier: BSD-2-Clause-Patent # #------------------------------------------------------------------------------ .text .p2align 2 GCC_ASM_EXPORT(SetJump) GCC_ASM_EXPORT(InternalLongJump) #/** # Saves the current CPU context that can be restored with a call to LongJump() and returns 0.# # # Saves the current CPU context in the buffer specified by JumpBuffer and returns 0. The initial # call to SetJump() must always return 0. Subsequent calls to LongJump() cause a non-zero # value to be returned by SetJump(). # # If JumpBuffer is NULL, then ASSERT(). # # @param JumpBuffer A pointer to CPU context buffer. # #**/ # #UINTN #EFIAPI #SetJump ( # IN BASE_LIBRARY_JUMP_BUFFER *JumpBuffer // R0 # ); # ASM_PFX(SetJump): mov r3, r13 stmia r0, {r3-r12,r14} mov r0, #0 bx lr #/** # Restores the CPU context that was saved with SetJump().# # # Restores the CPU context from the buffer specified by JumpBuffer. # This function never returns to the caller. # Instead it resumes execution based on the state of JumpBuffer. # # @param JumpBuffer A pointer to CPU context buffer. # @param Value The value to return when the SetJump() context is restored. # #**/ #VOID #EFIAPI #InternalLongJump ( # IN BASE_LIBRARY_JUMP_BUFFER *JumpBuffer, // R0 # IN UINTN Value // R1 # ); # ASM_PFX(InternalLongJump): ldmia r0, {r3-r12,r14} mov r13, r3 cmp r1, #0 moveq r1, #1 mov r0, r1 bx lr ASM_FUNCTION_REMOVE_IF_UNREFERENCED