kvm: x86: Fix segment registers to make them VMX compatible
authorAndreas Sandberg <andreas@sandberg.pp.se>
Mon, 30 Sep 2013 07:36:54 +0000 (09:36 +0200)
committerAndreas Sandberg <andreas@sandberg.pp.se>
Mon, 30 Sep 2013 07:36:54 +0000 (09:36 +0200)
commit30841926a3de0895152df31ce9294233db59be76
treee2f3b6deb254ad333a9175afd51c3674775c35ad
parentfbc1feb39ac19379983ca714f4c7fadcd9fdabf6
kvm: x86: Fix segment registers to make them VMX compatible

There are cases when the segment registers in gem5 are not compatible
with VMX. This changeset works around all known such issues. Specifically:

* The accessed bits in CS, SS, DD, ES, FS, GS are forced to 1.
* The busy bit in TR is forced to 1.
* The protection level of SS is forced to the same protection level as
  CS. The difference /seems/ to be caused by a bug in gem5's x86
  implementation.
src/cpu/kvm/x86_cpu.cc