On Wed, Apr 18, 2012 at 01:11:15AM +0200, Andreas Färber wrote: > Signed-off-by: Andreas Färber <afaer...@suse.de> > --- > 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 > >