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
This commit is contained in:
@ -13,6 +13,7 @@
|
||||
#------------------------------------------------------------------------------
|
||||
|
||||
ASM_GLOBAL ASM_PFX(JumpToKernel)
|
||||
ASM_GLOBAL ASM_PFX(JumpToUefiKernel)
|
||||
|
||||
#------------------------------------------------------------------------------
|
||||
# VOID
|
||||
@ -67,3 +68,24 @@ ASM_PFX(JumpToKernel):
|
||||
ret
|
||||
.code64
|
||||
|
||||
#------------------------------------------------------------------------------
|
||||
# VOID
|
||||
# EFIAPI
|
||||
# JumpToUefiKernel (
|
||||
# EFI_HANDLE ImageHandle, // rcx
|
||||
# EFI_SYSTEM_TABLE *SystemTable, // rdx
|
||||
# VOID *KernelBootParams, // r8
|
||||
# VOID *KernelStart // r9
|
||||
# );
|
||||
#------------------------------------------------------------------------------
|
||||
ASM_PFX(JumpToUefiKernel):
|
||||
movq %rcx, %rdi
|
||||
movq %rdx, %rsi
|
||||
movq %r8, %rdx
|
||||
xor %rax, %rax
|
||||
movl 0x264(%r8), %eax
|
||||
addq %rax, %r9
|
||||
addq $0x200, %r9
|
||||
callq %r9
|
||||
ret
|
||||
|
||||
|
Reference in New Issue
Block a user