diff options
| author | Paolo Bonzini <pbonzini@redhat.com> | 2015-10-14 15:25:52 +0200 | 
|---|---|---|
| committer | Paolo Bonzini <pbonzini@redhat.com> | 2015-10-14 16:39:52 +0200 | 
| commit | b10d92a54dac25a6152f1aa1ffc95c12908035ce (patch) | |
| tree | a3b91faba082c51fcd49319ef355e3783494b832 /lib/mpi/mpi-internal.h | |
| parent | 25188b9986cf6b0cadcf1bc1d1693a2e9c50ed47 (diff) | |
KVM: x86: fix RSM into 64-bit protected mode
In order to get into 64-bit protected mode, you need to enable
paging while EFER.LMA=1.  For this to work, CS.L must be 0.
Currently, we load the segments before CR0 and CR4, which means
that if RSM returns into 64-bit protected mode CS.L is already 1
and everything breaks.
Luckily, CS.L=0 is always the case when executing RSM, because it
is forbidden to execute RSM from 64-bit protected mode.  Hence it
is enough to load CR0 and CR4 first, and only then the segments.
Fixes: 660a5d517aaab9187f93854425c4c63f4a09195c
Cc: stable@vger.kernel.org
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'lib/mpi/mpi-internal.h')
0 files changed, 0 insertions, 0 deletions
