summaryrefslogtreecommitdiffstats
path: root/hw
diff options
context:
space:
mode:
authorxiaoqiang.zhao2016-03-07 08:05:42 +0100
committerPeter Maydell2016-05-12 14:40:48 +0200
commit3f5ab2549065229bd165d0db66b71512385dbd7a (patch)
tree65ebd393d56a980267b3c7261c07cb97404f3624 /hw
parenttarget-arm: Avoid unnecessary TLB flush on TCR_EL2, TCR_EL3 writes (diff)
downloadqemu-3f5ab2549065229bd165d0db66b71512385dbd7a.tar.gz
qemu-3f5ab2549065229bd165d0db66b71512385dbd7a.tar.xz
qemu-3f5ab2549065229bd165d0db66b71512385dbd7a.zip
hw/arm: QOM'ify armv7m.c
Drop the use of old SysBus init function and use instance_init Signed-off-by: xiaoqiang zhao <zxq_yx_007@163.com> Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Diffstat (limited to 'hw')
-rw-r--r--hw/arm/armv7m.c11
1 files changed, 5 insertions, 6 deletions
diff --git a/hw/arm/armv7m.c b/hw/arm/armv7m.c
index bb2a22d967..49d30782c8 100644
--- a/hw/arm/armv7m.c
+++ b/hw/arm/armv7m.c
@@ -132,14 +132,14 @@ typedef struct {
uint32_t base;
} BitBandState;
-static int bitband_init(SysBusDevice *dev)
+static void bitband_init(Object *obj)
{
- BitBandState *s = BITBAND(dev);
+ BitBandState *s = BITBAND(obj);
+ SysBusDevice *dev = SYS_BUS_DEVICE(obj);
- memory_region_init_io(&s->iomem, OBJECT(s), &bitband_ops, &s->base,
+ memory_region_init_io(&s->iomem, obj, &bitband_ops, &s->base,
"bitband", 0x02000000);
sysbus_init_mmio(dev, &s->iomem);
- return 0;
}
static void armv7m_bitband_init(void)
@@ -244,9 +244,7 @@ static Property bitband_properties[] = {
static void bitband_class_init(ObjectClass *klass, void *data)
{
DeviceClass *dc = DEVICE_CLASS(klass);
- SysBusDeviceClass *k = SYS_BUS_DEVICE_CLASS(klass);
- k->init = bitband_init;
dc->props = bitband_properties;
}
@@ -254,6 +252,7 @@ static const TypeInfo bitband_info = {
.name = TYPE_BITBAND,
.parent = TYPE_SYS_BUS_DEVICE,
.instance_size = sizeof(BitBandState),
+ .instance_init = bitband_init,
.class_init = bitband_class_init,
};