]> git.proxmox.com Git - qemu.git/commitdiff
target-i386: Fix long jumps/calls in long mode with REX.W set
authormalc <av1474@comtv.ru>
Thu, 4 Mar 2010 12:09:26 +0000 (15:09 +0300)
committerAurelien 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

index 525a83b744d41f774115b2c0e11af8d14219cbaf..7a99e2055ad5b217ab2f2ac2804efd31649fad11 100644 (file)
@@ -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;