|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen staging] x86emul: treat Hygon guests like AMD ones
commit 935641add6be43aa19e7f81e8471aa009db7f499
Author: Jan Beulich <jbeulich@xxxxxxxx>
AuthorDate: Wed Sep 18 15:13:21 2019 +0200
Commit: Jan Beulich <jbeulich@xxxxxxxx>
CommitDate: Wed Sep 18 15:13:21 2019 +0200
x86emul: treat Hygon guests like AMD ones
For some reason the Hygon enabling series left out the insn emulator.
Make appropriate adjustments wherever we've been special casing AMD.
Signed-off-by: Jan Beulich <jbeulich@xxxxxxxx>
Reviewed-by: Wei Liu <wl@xxxxxxx>
Reviewed-by: Andrew Cooper <andrew.cooper3@xxxxxxxxxx>
Release-acked-by: Juergen Gross <jgross@xxxxxxxx>
---
xen/arch/x86/x86_emulate/x86_emulate.c | 9 ++++++---
1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/xen/arch/x86/x86_emulate/x86_emulate.c
b/xen/arch/x86/x86_emulate/x86_emulate.c
index e57baa4186..f80beec502 100644
--- a/xen/arch/x86/x86_emulate/x86_emulate.c
+++ b/xen/arch/x86/x86_emulate/x86_emulate.c
@@ -1995,7 +1995,8 @@ protmode_load_seg(
case x86_seg_tr:
goto raise_exn;
}
- if ( cp->x86_vendor != X86_VENDOR_AMD || !ops->read_segment ||
+ if ( !(cp->x86_vendor & (X86_VENDOR_AMD | X86_VENDOR_HYGON)) ||
+ !ops->read_segment ||
ops->read_segment(seg, sreg, ctxt) != X86EMUL_OKAY )
memset(sreg, 0, sizeof(*sreg));
else
@@ -2122,7 +2123,8 @@ protmode_load_seg(
*/
bool wide = desc.b & 0x1000
? false : (desc.b & 0xf00) != 0xc00 &&
- cp->x86_vendor != X86_VENDOR_AMD
+ !(cp->x86_vendor &
+ (X86_VENDOR_AMD | X86_VENDOR_HYGON))
? mode_64bit() : ctxt->lma;
if ( wide )
@@ -2140,7 +2142,8 @@ protmode_load_seg(
default:
return rc;
}
- if ( !mode_64bit() && cp->x86_vendor == X86_VENDOR_AMD &&
+ if ( !mode_64bit() &&
+ (cp->x86_vendor & (X86_VENDOR_AMD | X86_VENDOR_HYGON)) &&
(desc.b & 0xf00) != 0xc00 )
desc_hi.b = desc_hi.a = 0;
if ( (desc_hi.b & 0x00001f00) ||
--
generated by git-patchbot for /home/xen/git/xen.git#staging
_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxxxxxxxxx
https://lists.xenproject.org/xen-changelog
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |