Il 03/10/2012 15:28, Eduardo Habkost ha scritto: > It would be interesting to make the generic machine intialization code > create a machine object instead, but changing the machine initialization > function signature is a nightmare, so by now I am creating the object > inside pc_init1(). > > The object is not used for anything by now, but it will be used during > some steps of the initialization, later. > > Signed-off-by: Eduardo Habkost <ehabk...@redhat.com> > --- > hw/pc_piix.c | 3 +++ > 1 file changed, 3 insertions(+) > > diff --git a/hw/pc_piix.c b/hw/pc_piix.c > index fd5898f..28b5f8a 100644 > --- a/hw/pc_piix.c > +++ b/hw/pc_piix.c > @@ -148,6 +148,7 @@ static void pc_init1(MemoryRegion *system_memory, > MemoryRegion *pci_memory; > MemoryRegion *rom_memory; > void *fw_cfg = NULL; > + PC *pc = PC(object_new(TYPE_PC_MACHINE)); > > pc_cpus_init(cpu_model); > > @@ -285,6 +286,8 @@ static void pc_init1(MemoryRegion *system_memory, > if (pci_enabled) { > pc_pci_device_init(pci_bus); > } > + > + qdev_init_nofail(DEVICE(pc)); > } > > static void pc_init_pci(ram_addr_t ram_size, >
Can you add a hook to QEMUMachine so that this object is created by qdev_get_machine() and ends up at /machine? Paolo