Files
system76-edk2/OvmfPkg/Library/LoadLinuxLib/Ia32/JumpToKernel.S
jljusten dd71f6e287 OvmfPkg LoadLinuxLib: Use kernel's EFI entry point where available
Usage of the EFI entry point was made feasible in the kernel
x64 boot protocol 2.12 where a 32-bit & 64-bit entry point
became well defined.

http://git.kernel.org/linus/09c205af

Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
Reviewed-by: Jordan Justen <jordan.l.justen@intel.com>

git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@14132 6f19259b-4bc3-4df7-8a09-765794883524
2013-02-14 19:21:39 +00:00

47 lines
1.5 KiB
ArmAsm

#------------------------------------------------------------------------------
#
# Copyright (c) 2006 - 2013, Intel Corporation. All rights reserved.<BR>
#
# 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.
#
#------------------------------------------------------------------------------
ASM_GLOBAL ASM_PFX(JumpToKernel)
ASM_GLOBAL ASM_PFX(JumpToUefiKernel)
#------------------------------------------------------------------------------
# VOID
# EFIAPI
# JumpToKernel (
# VOID *KernelStart,
# VOID *KernelBootParams
# );
#------------------------------------------------------------------------------
ASM_PFX(JumpToKernel):
movl 0x8(%esp), %esi
calll 0x4(%esp)
ret
#------------------------------------------------------------------------------
# VOID
# EFIAPI
# JumpToUefiKernel (
# EFI_HANDLE ImageHandle,
# EFI_SYSTEM_TABLE *SystemTable,
# VOID *KernelBootParams,
# VOID *KernelStart
# );
#------------------------------------------------------------------------------
ASM_PFX(JumpToUefiKernel):
movl 0xc(%esp), %eax
movl 0x264(%eax), %eax
addl 0x10(%esp), %eax
jmp %eax