From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([208.118.235.92]:36169) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1SoW1M-0004QQ-Cx for qemu-devel@nongnu.org; Tue, 10 Jul 2012 04:42:18 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1SoW1H-0002bb-M3 for qemu-devel@nongnu.org; Tue, 10 Jul 2012 04:42:11 -0400 Received: from mail-pb0-f45.google.com ([209.85.160.45]:60506) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1SoW1H-0002bV-Cz for qemu-devel@nongnu.org; Tue, 10 Jul 2012 04:42:07 -0400 Received: by pbbro12 with SMTP id ro12so22245391pbb.4 for ; Tue, 10 Jul 2012 01:42:05 -0700 (PDT) Sender: Paolo Bonzini Message-ID: <4FFBEAD7.6060705@redhat.com> Date: Tue, 10 Jul 2012 10:41:59 +0200 From: Paolo Bonzini MIME-Version: 1.0 References: <1341900967-4344-1-git-send-email-qemulist@gmail.com> <1341900967-4344-5-git-send-email-qemulist@gmail.com> In-Reply-To: <1341900967-4344-5-git-send-email-qemulist@gmail.com> Content-Type: text/plain; charset=ISO-8859-15 Content-Transfer-Encoding: 7bit Subject: Re: [Qemu-devel] [PATCH 4/5] qom-cpu: during cpu reset, it will reset its child List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Liu Ping Fan Cc: Blue Swirl , Jan Kiszka , qemu-devel@nongnu.org, Anthony Liguori , =?ISO-8859-15?Q?Andreas_F=E4rber?= Il 10/07/2012 08:16, Liu Ping Fan ha scritto: > This will give the embeded logic module, such as apic has the > opportunity to reset. > > Signed-off-by: Liu Ping Fan > --- > qom/cpu.c | 16 ++++++++++++++++ > 1 files changed, 16 insertions(+), 0 deletions(-) > > diff --git a/qom/cpu.c b/qom/cpu.c > index 5b36046..6aea8e6 100644 > --- a/qom/cpu.c > +++ b/qom/cpu.c > @@ -20,10 +20,26 @@ > > #include "qemu/cpu.h" > #include "qemu-common.h" > +#include "hw/qdev.h" > + > +static int cpu_reset_kid(Object *child, void *opaque) > +{ > + if (object_is_type_str(child, TYPE_DEVICE)) { > + device_reset(DEVICE(child)); > + } else if (object_is_type_str(child, TYPE_BUS)) { > + bus_reset(BUS(child)); > + } else { > + printf("cpu's child must be DEVICE or BUS"); > + abort(); > + } > + return 0; > +} > > void cpu_reset(CPUState *cpu) > { > CPUClass *klass = CPU_GET_CLASS(cpu); > + Object *obj = OBJECT(cpu); > + object_child_foreach(obj, cpu_reset_kid, NULL); Ok, now I see what you want to do. Next time, please add meaningful commit messages to all patches in the series, even those that only add infrastructure. It really looks like time is ripe to make CPUs children of Device, so you can just use qdev_reset_all to reset the CPU. Paolo > if (klass->reset != NULL) { > (*klass->reset)(cpu); >