qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [PATCH 11/15] target-i386: Add property getter for CPU


From: Michael Roth
Subject: Re: [Qemu-devel] [PATCH 11/15] target-i386: Add property getter for CPU model-id
Date: Thu, 19 Apr 2012 19:41:13 -0500
User-agent: Mutt/1.5.21 (2010-09-15)

On Wed, Apr 18, 2012 at 01:11:15AM +0200, Andreas Färber wrote:
> Signed-off-by: Andreas Färber <address@hidden>
> ---
>  target-i386/cpu.c |   17 ++++++++++++++++-
>  1 files changed, 16 insertions(+), 1 deletions(-)
> 
> diff --git a/target-i386/cpu.c b/target-i386/cpu.c
> index 0c98fcc..cc4f566 100644
> --- a/target-i386/cpu.c
> +++ b/target-i386/cpu.c
> @@ -711,6 +711,21 @@ static void x86_cpuid_version_set_stepping(Object *obj, 
> Visitor *v,
>      env->cpuid_version |= value & 0xf;
>  }
>  
> +static char *x86_cpuid_get_model_id(Object *obj, Error **errp)
> +{
> +    X86CPU *cpu = X86_CPU(obj);
> +    CPUX86State *env = &cpu->env;
> +    char *value;
> +    int i;
> +
> +    value = g_malloc(48 + 1);
> +    for (i = 0; i < 48; i++) {
> +        value[i] = env->cpuid_model[i >> 2] >> (8 * (i & 3));

setter code is a bit difficult to parse but I think we need value[i] &= 0xff
here

> +    }
> +    value[48] = '\0';
> +    return value;
> +}
> +
>  static void x86_cpuid_set_model_id(Object *obj, const char *model_id,
>                                     Error **errp)
>  {
> @@ -1586,7 +1601,7 @@ static void x86_cpu_initfn(Object *obj)
>                          x86_cpuid_version_get_stepping,
>                          x86_cpuid_version_set_stepping, NULL, NULL, NULL);
>      object_property_add_str(obj, "model-id",
> -                            NULL,
> +                            x86_cpuid_get_model_id,
>                              x86_cpuid_set_model_id, NULL);
>  
>      env->cpuid_apic_id = env->cpu_index;
> -- 
> 1.7.7
> 
> 



reply via email to

[Prev in Thread] Current Thread [Next in Thread]