on 08/10/2012 10:52 malc said the following:
> On Mon, 8 Oct 2012, Andriy Gapon wrote:
> 
>>
>> I am running Qemu (plain, no kvm, etc) on an AMD 10h machine that
>> provides popcnt instruction.  Qemu advertises availability of pocnt
>> to a guest as well.  What I see in the guest that popcnt
>> 0x20(%r12),%r8 instruction actually placed its result into %rax.
>> With %rdi and %rax operands the instruction worked fine though.
>>
>>
> 
> Does following work?

It does!  Thank you very much.

> diff --git a/target-i386/translate.c b/target-i386/translate.c
> index e896abf..c36cc3e 100644
> --- a/target-i386/translate.c
> +++ b/target-i386/translate.c
> @@ -7818,7 +7818,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;
> 


-- 
Andriy Gapon

Reply via email to