Am 27.11.2013 10:10, schrieb Peter Maydell: > On 27 November 2013 09:02, Peter Crosthwaite > <peter.crosthwa...@xilinx.com> wrote: >> To allow the machine model to set device properties before CPU >> realization. >> >> Signed-off-by: Peter Crosthwaite <peter.crosthwa...@xilinx.com> >> --- >> >> hw/arm/highbank.c | 13 ++++++++++--- >> 1 file changed, 10 insertions(+), 3 deletions(-) >> >> diff --git a/hw/arm/highbank.c b/hw/arm/highbank.c >> index fe98ef1..70831ba 100644 >> --- a/hw/arm/highbank.c >> +++ b/hw/arm/highbank.c >> @@ -228,11 +228,18 @@ static void calxeda_init(QEMUMachineInitArgs *args, >> enum cxmachines machine) >> } >> } >> >> + cpu_model = g_strdup_printf("%s-" TYPE_ARM_CPU, cpu_model); >> + > > Please use cpu_class_by_name() rather than hand-constructing > the classname. (see also the hw/arm/virt.c code I posted the other > day, which needs to set a property for other reasons.) > >> for (n = 0; n < smp_cpus; n++) { >> ARMCPU *cpu; >> - cpu = cpu_arm_init(cpu_model); >> - if (cpu == NULL) { >> - fprintf(stderr, "Unable to find CPU definition\n"); >> + Error *err = NULL; >> + >> + cpu = ARM_CPU(object_new(cpu_model)); >> + g_free((void *)cpu_model); >> + >> + object_property_set_bool(OBJECT(cpu), true, "realized", &err); >> + if (err) { >> + fprintf(stderr, "%s\n", error_get_pretty(err));
And use of error_report() (without \n) will be appreciated. :) Cheers, Andreas >> exit(1); >> } > > thanks > -- PMM -- SUSE LINUX Products GmbH, Maxfeldstr. 5, 90409 Nürnberg, Germany GF: Jeff Hawn, Jennifer Guild, Felix Imendörffer; HRB 16746 AG Nürnberg