hw/gpio: QOM'ify zaurus.c
Drop the old SysBus init function and use instance_init Signed-off-by: xiaoqiang zhao <zxq_yx_007@163.com> Message-id: 1465815255-21776-8-git-send-email-zxq_yx_007@163.com Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
09e6fb3e36
commit
5367766742
@ -167,19 +167,18 @@ static void scoop_gpio_set(void *opaque, int line, int level)
|
||||
s->gpio_level &= ~(1 << line);
|
||||
}
|
||||
|
||||
static int scoop_init(SysBusDevice *sbd)
|
||||
static void scoop_init(Object *obj)
|
||||
{
|
||||
DeviceState *dev = DEVICE(sbd);
|
||||
ScoopInfo *s = SCOOP(dev);
|
||||
DeviceState *dev = DEVICE(obj);
|
||||
ScoopInfo *s = SCOOP(obj);
|
||||
SysBusDevice *sbd = SYS_BUS_DEVICE(obj);
|
||||
|
||||
s->status = 0x02;
|
||||
qdev_init_gpio_out(dev, s->handler, 16);
|
||||
qdev_init_gpio_in(dev, scoop_gpio_set, 16);
|
||||
memory_region_init_io(&s->iomem, OBJECT(s), &scoop_ops, s, "scoop", 0x1000);
|
||||
memory_region_init_io(&s->iomem, obj, &scoop_ops, s, "scoop", 0x1000);
|
||||
|
||||
sysbus_init_mmio(sbd, &s->iomem);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int scoop_post_load(void *opaque, int version_id)
|
||||
@ -239,9 +238,7 @@ static const VMStateDescription vmstate_scoop_regs = {
|
||||
static void scoop_sysbus_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
SysBusDeviceClass *k = SYS_BUS_DEVICE_CLASS(klass);
|
||||
|
||||
k->init = scoop_init;
|
||||
dc->desc = "Scoop2 Sharp custom ASIC";
|
||||
dc->vmsd = &vmstate_scoop_regs;
|
||||
}
|
||||
@ -250,6 +247,7 @@ static const TypeInfo scoop_sysbus_info = {
|
||||
.name = TYPE_SCOOP,
|
||||
.parent = TYPE_SYS_BUS_DEVICE,
|
||||
.instance_size = sizeof(ScoopInfo),
|
||||
.instance_init = scoop_init,
|
||||
.class_init = scoop_sysbus_class_init,
|
||||
};
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user