From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([208.118.235.92]:53463) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1StHs7-0004Zm-FD for qemu-devel@nongnu.org; Mon, 23 Jul 2012 08:36:27 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1StHry-000652-Rx for qemu-devel@nongnu.org; Mon, 23 Jul 2012 08:36:23 -0400 Received: from e28smtp04.in.ibm.com ([122.248.162.4]:40860) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1StHry-00064G-7b for qemu-devel@nongnu.org; Mon, 23 Jul 2012 08:36:14 -0400 Received: from /spool/local by e28smtp04.in.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Mon, 23 Jul 2012 18:06:08 +0530 Received: from d28av03.in.ibm.com (d28av03.in.ibm.com [9.184.220.65]) by d28relay02.in.ibm.com (8.13.8/8.13.8/NCO v10.0) with ESMTP id q6NCa4eu22151244 for ; Mon, 23 Jul 2012 18:06:04 +0530 Received: from d28av03.in.ibm.com (loopback [127.0.0.1]) by d28av03.in.ibm.com (8.14.4/8.13.1/NCO v10.0 AVout) with ESMTP id q6NCa3pl010892 for ; Mon, 23 Jul 2012 22:36:04 +1000 From: Wanpeng Li Date: Mon, 23 Jul 2012 20:35:56 +0800 Message-Id: <1343046959-6659-1-git-send-email-liwanp@linux.vnet.ibm.com> Subject: [Qemu-devel] [PATCH v5 0/3] refactor PC machine, i440fx and piix3 to take advantage of QOM List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Anthony Liguori Cc: Ram Pai , Gavin Shan , "Michael S. Tsirkin" , Jan Kiszka , qemu-devel@nongnu.org, Liu Ping Fan , Blue Swirl , Stefan Weil , Avi Kivity , Paolo Bonzini , Wanpeng Li This series aggressively refactors the PC machine initialization to be more modelled and less ad-hoc. The highlights of this series are: 1) Things like -m and -bios-name are now device model properties 2) The i440fx and piix3 are now modelled in a thorough fashion 3) i440fx_init is trivialized to creating devices and setting properties 4) convert PCI host bridge to QOM The point (3) is the most important one. As we refactor in this fashion, we should quickly get to the point where machine->init disappears completely in favor of just creating a handful of devices. The two stage initialization of QOM is important here. instance_init() is when composed devices are created which means that after you've created a device, all of its children are visible in the device model. This lets you set properties of the parent and its children. realize() (which is still called DeviceState::init today) will be called right before the guest starts up for the first time. Signed-off-by: Anthony Liguori Signed-off-by: Wanpeng Li Change in v5: * drop patch "convert MemoryRegion to QOM" and "prepare to create HPET, RTC and i8254 through composition" * add Andreas' recent attempt against pci_host Change in v4: *rebase patchset Changes in v3: * fix coding style issues * fix rebase error * add changes log Changes in v2: * Rebase patch series of i440fx in Anthony's qom-rebase.12 branch to upstream * convert MemoryRegion to QOM * convert pci_host to QOM Anthony Liguori (3): eliminate piix_pci.c and module i440fx and piix3 merge pc_piix.c to pc.c convert pci-host to QOM hw/i386/Makefile.objs | 3 +- hw/i440fx.c | 434 ++++++++++++++++++++++++++++++ hw/i440fx.h | 77 ++++++ hw/pc.c | 695 +++++++++++++++++++++++++++++++++++++++++++++---- hw/pc.h | 46 +--- hw/pc_piix.c | 661 ---------------------------------------------- hw/pci_host.c | 14 + hw/pci_host.h | 2 + hw/piix3.c | 234 +++++++++++++++++ hw/piix3.h | 69 +++++ hw/piix_pci.c | 599 ------------------------------------------ 11 files changed, 1481 insertions(+), 1353 deletions(-) create mode 100644 hw/i440fx.c create mode 100644 hw/i440fx.h delete mode 100644 hw/pc_piix.c create mode 100644 hw/piix3.c create mode 100644 hw/piix3.h delete mode 100644 hw/piix_pci.c -- 1.7.7.6