Files
system76-edk2/OvmfPkg/XenResetVector/Ia32/XenPVHMain.asm
Anthony PERARD 93314ae597 OvmfPkg/XenResetVector: Saving start of day pointer for PVH guests
As described in the Xen PVH documentation [1], "ebx: contains the
physical memory address where the loader has placed the boot start info
structure". To have this pointer saved to be able to use it later in the
PEI phase, we allocate some space in the MEMFD for it. We use 'XPVH' as
a signature (for "Xen PVH").

[1] https://xenbits.xenproject.org/docs/unstable/misc/pvh.html

Ref: https://bugzilla.tianocore.org/show_bug.cgi?id=1689
Signed-off-by: Anthony PERARD <anthony.perard@citrix.com>
Acked-by: Laszlo Ersek <lersek@redhat.com>
Message-Id: <20190813113119.14804-8-anthony.perard@citrix.com>
2019-08-21 18:03:49 +02:00

56 lines
1.3 KiB
NASM

;------------------------------------------------------------------------------
; @file
; An entry point use by Xen when a guest is started in PVH mode.
;
; Copyright (c) 2019, Citrix Systems, Inc.
;
; SPDX-License-Identifier: BSD-2-Clause-Patent
;
;------------------------------------------------------------------------------
BITS 32
xenPVHMain:
;
; 'BP' to indicate boot-strap processor
;
mov di, 'BP'
;
; ESP will be used as initial value of the EAX register
; in Main.asm
;
xor esp, esp
;
; Store "Start of day" struct pointer for later use
;
mov dword[PVH_SPACE (0)], ebx
mov dword[PVH_SPACE (4)], 'XPVH'
mov ebx, ADDR_OF(gdtr)
lgdt [ebx]
mov eax, SEC_DEFAULT_CR0
mov cr0, eax
jmp LINEAR_CODE_SEL:ADDR_OF(.jmpToNewCodeSeg)
.jmpToNewCodeSeg:
mov eax, SEC_DEFAULT_CR4
mov cr4, eax
mov ax, LINEAR_SEL
mov ds, ax
mov es, ax
mov fs, ax
mov gs, ax
mov ss, ax
;
; Jump to the main routine of the pre-SEC code
; skiping the 16-bit part of the routine and
; into the 32-bit flat mode part
;
OneTimeCallRet TransitionFromReal16To32BitFlat