From: Jan Kiszka <[email protected]>

A 16-bit TSS is only 44 bytes long. So make sure to test for the correct
size on task switch.

Signed-off-by: Jan Kiszka <[email protected]>
Signed-off-by: Avi Kivity <[email protected]>

diff --git a/arch/x86/kvm/emulate.c b/arch/x86/kvm/emulate.c
index e2bbb9c..64c9854 100644
--- a/arch/x86/kvm/emulate.c
+++ b/arch/x86/kvm/emulate.c
@@ -2351,6 +2351,7 @@ static int emulator_do_task_switch(struct 
x86_emulate_ctxt *ctxt,
        u16 old_tss_sel = ops->get_segment_selector(VCPU_SREG_TR, ctxt->vcpu);
        ulong old_tss_base =
                get_cached_descriptor_base(ctxt, ops, VCPU_SREG_TR);
+       u32 desc_limit;
 
        /* FIXME: old_tss_base == ~0 ? */
 
@@ -2371,7 +2372,10 @@ static int emulator_do_task_switch(struct 
x86_emulate_ctxt *ctxt,
                }
        }
 
-       if (!next_tss_desc.p || desc_limit_scaled(&next_tss_desc) < 0x67) {
+       desc_limit = desc_limit_scaled(&next_tss_desc);
+       if (!next_tss_desc.p ||
+           ((desc_limit < 0x67 && (next_tss_desc.type & 8)) ||
+            desc_limit < 0x2b)) {
                kvm_queue_exception_e(ctxt->vcpu, TS_VECTOR,
                                      tss_selector & 0xfffc);
                return X86EMUL_PROPAGATE_FAULT;
--
To unsubscribe from this list: send the line "unsubscribe kvm-commits" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to