target/i386: fix access to the T bit of the TSS
The T bit is bit 0 of the 16-bit word at offset 100 of the TSS. However,
accessing it with a 32-bit word is not really correct, because bytes
102-103 contain the I/O map base address (relative to the base of the
TSS) and bits 1-15 are reserved. In particular, any task switch to a TSS that
has a nonzero I/O map base address is broken.
This fixes the eventinj and taskswitch tests in kvm-unit-tests.
Cc: qemu-stable@nongnu.org
Fixes: ad441b8b79 ("target/i386: implement TSS trap bit", 2025-05-12)
Reported-by: Thomas Huth <thuth@redhat.com>
Closes: https://gitlab.com/qemu-project/qemu/-/issues/3101
Tested-by: Thomas Huth <thuth@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
5a2faa0a0a
commit
0d22b621b7
1 changed files with 1 additions and 1 deletions
|
|
@ -456,7 +456,7 @@ static void switch_tss_ra(CPUX86State *env, int tss_selector,
|
|||
new_segs[i] = access_ldw(&new, tss_base + (0x48 + i * 4));
|
||||
}
|
||||
new_ldt = access_ldw(&new, tss_base + 0x60);
|
||||
new_trap = access_ldl(&new, tss_base + 0x64);
|
||||
new_trap = access_ldw(&new, tss_base + 0x64) & 1;
|
||||
} else {
|
||||
/* 16 bit */
|
||||
new_cr3 = 0;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue