projects
/
qemu.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
| inline |
side by side
(parent:
c225492
)
target-i386: Fix long jumps/calls in long mode with REX.W set
author
malc
<av1474@comtv.ru>
Thu, 4 Mar 2010 12:09:26 +0000
(15:09 +0300)
committer
Aurelien Jarno
<aurelien@aurel32.net>
Sat, 6 Mar 2010 18:20:04 +0000
(19:20 +0100)
Signed-off-by: malc <av1474@comtv.ru>
Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>
target-i386/translate.c
patch
|
blob
|
history
diff --git
a/target-i386/translate.c
b/target-i386/translate.c
index 525a83b744d41f774115b2c0e11af8d14219cbaf..7a99e2055ad5b217ab2f2ac2804efd31649fad11 100644
(file)
--- a/
target-i386/translate.c
+++ b/
target-i386/translate.c
@@
-4589,9
+4589,7
@@
static target_ulong disas_insn(DisasContext *s, target_ulong pc_start)
/* operand size for jumps is 64 bit */
ot = OT_QUAD;
} else if (op == 3 || op == 5) {
- /* for call calls, the operand is 16 or 32 bit, even
- in long mode */
- ot = dflag ? OT_LONG : OT_WORD;
+ ot = dflag ? OT_LONG + (rex_w == 1) : OT_WORD;
} else if (op == 6) {
/* default push size is 64 bit */
ot = dflag ? OT_QUAD : OT_WORD;