From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from [140.186.70.92] (port=41517 helo=eggs.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1Po040-0007Xc-6V for qemu-devel@nongnu.org; Fri, 11 Feb 2011 15:58:01 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1Po03z-00037D-6W for qemu-devel@nongnu.org; Fri, 11 Feb 2011 15:58:00 -0500 Received: from mail-fx0-f45.google.com ([209.85.161.45]:47910) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Po03y-00036r-LP for qemu-devel@nongnu.org; Fri, 11 Feb 2011 15:57:59 -0500 Received: by fxm12 with SMTP id 12so3249832fxm.4 for ; Fri, 11 Feb 2011 12:57:57 -0800 (PST) From: Dmitry Eremin-Solenikov Date: Fri, 11 Feb 2011 23:57:33 +0300 Message-Id: <1297457859-15685-1-git-send-email-dbaryshkov@gmail.com> Subject: [Qemu-devel] [PATCH 1/7] Add scoop post_load callback that sets IRQs to loaded levels List-Id: qemu-devel.nongnu.org List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Signed-off-by: Dmitry Eremin-Solenikov --- hw/zaurus.c | 19 ++++++++++++++++++- 1 files changed, 18 insertions(+), 1 deletions(-) diff --git a/hw/zaurus.c b/hw/zaurus.c index fca11a5..fb5e228 100644 --- a/hw/zaurus.c +++ b/hw/zaurus.c @@ -181,17 +181,34 @@ static int scoop_init(SysBusDevice *dev) return 0; } +static int scoop_post_load(void *opaque, int version_id) +{ + ScoopInfo *s = (ScoopInfo *) opaque; + int i; + uint32_t level; + + level = s->gpio_level & s->gpio_dir; + + for (i = 0; i < 16; i++) { + qemu_set_irq(s->handler[i], (level >> i) & 1); + } + + s->prev_level = level; + + return 0; +} + static bool is_version_0 (void *opaque, int version_id) { return version_id == 0; } - static const VMStateDescription vmstate_scoop_regs = { .name = "scoop", .version_id = 1, .minimum_version_id = 0, .minimum_version_id_old = 0, + .post_load = scoop_post_load, .fields = (VMStateField []) { VMSTATE_UINT16(status, ScoopInfo), VMSTATE_UINT16(power, ScoopInfo), -- 1.7.2.3