From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([140.186.70.92]:37427) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1RsFAF-0005Qo-CF for qemu-devel@nongnu.org; Tue, 31 Jan 2012 09:58:32 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1RsFA2-0007MU-Mk for qemu-devel@nongnu.org; Tue, 31 Jan 2012 09:58:31 -0500 Received: from mx1.redhat.com ([209.132.183.28]:1030) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1RsFA2-0007MC-G8 for qemu-devel@nongnu.org; Tue, 31 Jan 2012 09:58:18 -0500 Message-ID: <4F280184.3080607@redhat.com> Date: Tue, 31 Jan 2012 15:58:12 +0100 From: Paolo Bonzini MIME-Version: 1.0 References: <1327604460-31142-1-git-send-email-aliguori@us.ibm.com> <1327604460-31142-7-git-send-email-aliguori@us.ibm.com> <4F27FBE6.7040800@siemens.com> <4F27FEFD.5070507@codemonkey.ws> <4F28000B.5060406@siemens.com> In-Reply-To: <4F28000B.5060406@siemens.com> Content-Type: text/plain; charset=ISO-8859-15; format=flowed Content-Transfer-Encoding: 7bit Subject: Re: [Qemu-devel] [PATCH 06/15] piix: create i8254 through composition List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Jan Kiszka Cc: Peter Maydell , Anthony Liguori , Markus Armbruster , "qemu-devel@nongnu.org" , Avi Kivity On 01/31/2012 03:51 PM, Jan Kiszka wrote: >> > >> > BTW, this is yet another benefit of making structures public. You can take the >> > address of a child and set link fields directly without accessors. > Well, that has two sides. We introduced properties to avoid this direct > messing. > > Does linking also work without exposing internals? Perhaps it doesn't need to expose internals. Just like we create interfaces automatically when creating a parent object, perhaps we can create children as well, like TypeInfo type_piix3 = { ... .children = { { "pic[0]", TYPE_I8259, offsetof(PIIX3, pic[0]) }, { "pic[1]", TYPE_I8259, offsetof(PIIX3, pic[1]) }, { "pit, TYPE_I8254, offsetof(PIIX3, pit) }, { "rtc", TYPE_RTC, offsetof(PIIX3, rtc) }, { } } } QOM's object_init would allocate a single malloced block for all of them, carve out space for the parent and all children, and add the properties. Paolo