Skip to content
This repository has been archived by the owner on Jan 28, 2023. It is now read-only.

Snapshot issues #248

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open

Conversation

nevilad
Copy link
Contributor

@nevilad nevilad commented Dec 9, 2019

PDPTE values are not restored after snapshot loading. I added PDPTE values reading from guest memory and write these to vmcs after all EFER writes and control register writes from qemu, since these can change memory mode to use PDPTES.
Open questions:

  1. Is it necessary to set the check_pae_pdpt after memory load from qemu? It is theoretically possible not changing CRs and MSRs from qemu, but change memory at location pointed by CR3. Should we assume this scenario?

all EFER writes and control register writes from qemu.

Signed-off-by: Alexey Romko <[email protected]>
@HaxmCI HaxmCI added CI:Build Pass CI:Build Pass CI:Mac Test Pass CI:Mac Test Pass labels Dec 9, 2019
@nevilad
Copy link
Contributor Author

nevilad commented Dec 9, 2019

Windows 7 x86 guest needs EFER MSR, it sets Execute Disable Bit Enable: IA32_EFER.NXE. Current qemu version does not read\write it from haxm. When this MSR will not be saved\restored the guest OS will not work correctly. So I created this patch for qemu.
0001-Windows-7-x86-guest-needs-EFER-MSR.patch.txt

There is a bug in qemu at least on Windows host which does not save the correct registers (https://bugs.launchpad.net/qemu/+bug/1855617). Do they work on other hosts, has somebody used snapshots with haxm on other hosts?

@nevilad
Copy link
Contributor Author

nevilad commented Mar 3, 2020

These MSRs are not saved to/from qemu, but they values may be saved during MSR write exits and returned in MSR read exits:
IA32_MTRRCAP
MTRRFIX64K_00000
IA32_MTRR_DEF_TYPE
IA32_CPUID_FEATURE_MASK
IA32_PMC0
IA32_PMC1
IA32_PMC2
IA32_PMC3
IA32_PERFEVTSEL0
IA32_PERFEVTSEL1
IA32_PERFEVTSEL2
IA32_PERFEVTSEL3

@HaxmCI HaxmCI added CI:Build Fail CI:Build Fail and removed CI:Build Pass CI:Build Pass CI:Mac Test Pass CI:Mac Test Pass labels May 24, 2021
@wcwang wcwang force-pushed the master branch 2 times, most recently from 563eb1b to 6b942e3 Compare November 25, 2022 03:23
@wcwang wcwang force-pushed the master branch 2 times, most recently from b73a231 to da1b8ec Compare January 26, 2023 02:48
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
CI:Build Fail CI:Build Fail
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants