OSDN Git Service

Fix popcnt in long mode
authormalc <av1474@comtv.ru>
Sun, 14 Oct 2012 10:54:38 +0000 (14:54 +0400)
committermalc <av1474@comtv.ru>
Sun, 14 Oct 2012 10:55:09 +0000 (14:55 +0400)
Thanks to Andriy Gapon for initial problem report.

Signed-off-by: malc <av1474@comtv.ru>
target-i386/translate.c

index 0a7e4e3..ee75850 100644 (file)
@@ -7768,7 +7768,7 @@ static target_ulong disas_insn(DisasContext *s, target_ulong pc_start)
             goto illegal_op;
 
         modrm = cpu_ldub_code(cpu_single_env, s->pc++);
-        reg = ((modrm >> 3) & 7);
+        reg = ((modrm >> 3) & 7) | rex_r;
 
         if (s->prefix & PREFIX_DATA)
             ot = OT_WORD;