summaryrefslogtreecommitdiffstats
path: root/hw/arm
diff options
context:
space:
mode:
authorPan Nengyuan2020-03-05 17:09:15 +0100
committerPeter Maydell2020-03-05 17:09:15 +0100
commit1afaadb592f3eeb7043a9fb7ae507862579ebf9d (patch)
treed6c4fdbdaa7de8b4f315d1587a5a3a7ccfc61d91 /hw/arm
parenthw/arm/musicpal: Simplify since the machines are little-endian only (diff)
downloadqemu-1afaadb592f3eeb7043a9fb7ae507862579ebf9d.tar.gz
qemu-1afaadb592f3eeb7043a9fb7ae507862579ebf9d.tar.xz
qemu-1afaadb592f3eeb7043a9fb7ae507862579ebf9d.zip
hw/arm/pxa2xx: move timer_new from init() into realize() to avoid memleaks
There are some memleaks when we call 'device_list_properties'. This patch move timer_new from init into realize to fix it. Reported-by: Euler Robot <euler.robot@huawei.com> Signed-off-by: Pan Nengyuan <pannengyuan@huawei.com> Message-id: 20200227025055.14341-3-pannengyuan@huawei.com Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Diffstat (limited to 'hw/arm')
-rw-r--r--hw/arm/pxa2xx.c17
1 files changed, 11 insertions, 6 deletions
diff --git a/hw/arm/pxa2xx.c b/hw/arm/pxa2xx.c
index b33f8f1351..56a36202d7 100644
--- a/hw/arm/pxa2xx.c
+++ b/hw/arm/pxa2xx.c
@@ -1134,18 +1134,22 @@ static void pxa2xx_rtc_init(Object *obj)
s->last_rtcpicr = 0;
s->last_hz = s->last_sw = s->last_pi = qemu_clock_get_ms(rtc_clock);
+ sysbus_init_irq(dev, &s->rtc_irq);
+
+ memory_region_init_io(&s->iomem, obj, &pxa2xx_rtc_ops, s,
+ "pxa2xx-rtc", 0x10000);
+ sysbus_init_mmio(dev, &s->iomem);
+}
+
+static void pxa2xx_rtc_realize(DeviceState *dev, Error **errp)
+{
+ PXA2xxRTCState *s = PXA2XX_RTC(dev);
s->rtc_hz = timer_new_ms(rtc_clock, pxa2xx_rtc_hz_tick, s);
s->rtc_rdal1 = timer_new_ms(rtc_clock, pxa2xx_rtc_rdal1_tick, s);
s->rtc_rdal2 = timer_new_ms(rtc_clock, pxa2xx_rtc_rdal2_tick, s);
s->rtc_swal1 = timer_new_ms(rtc_clock, pxa2xx_rtc_swal1_tick, s);
s->rtc_swal2 = timer_new_ms(rtc_clock, pxa2xx_rtc_swal2_tick, s);
s->rtc_pi = timer_new_ms(rtc_clock, pxa2xx_rtc_pi_tick, s);
-
- sysbus_init_irq(dev, &s->rtc_irq);
-
- memory_region_init_io(&s->iomem, obj, &pxa2xx_rtc_ops, s,
- "pxa2xx-rtc", 0x10000);
- sysbus_init_mmio(dev, &s->iomem);
}
static int pxa2xx_rtc_pre_save(void *opaque)
@@ -1203,6 +1207,7 @@ static void pxa2xx_rtc_sysbus_class_init(ObjectClass *klass, void *data)
dc->desc = "PXA2xx RTC Controller";
dc->vmsd = &vmstate_pxa2xx_rtc_regs;
+ dc->realize = pxa2xx_rtc_realize;
}
static const TypeInfo pxa2xx_rtc_sysbus_info = {
td>Igor Mammedov2016-10-241-0/+5 * pc: apic_common: Restore APIC ID to initial ID on resetIgor Mammedov2016-10-241-0/+1 * pc: apic_common: Extend APIC ID property to 32bitIgor Mammedov2016-10-241-1/+45 * apic: add global apic_get_class()Radim Krčmář2016-10-171-0/+1 * apic: Use apic_id as apic's migration instance_idIgor Mammedov2016-07-201-1/+11 * (kvm)apic: Add unrealize callbacksIgor Mammedov2016-07-201-0/+13 * apic: move MAX_APICS check to 'apic' classIgor Mammedov2016-07-201-8/+0Star * qemu-common: push cpu.h inclusion out of qemu-common.hPaolo Bonzini2016-05-191-0/+2 * include/qemu/osdep.h: Don't include qapi/error.hMarkus Armbruster2016-03-221-0/+1 * x86: Clean up includesPeter Maydell2016-01-291-0/+1 * cpu/apic: drop icc bus/bridgeChen Fan2015-10-021-3/+2Star * apic: move APIC's MMIO region mapping into APICChen Fan2015-10-021-6/+0Star * migration: Use normal VMStateDescriptions for SubsectionsJuan Quintela2015-06-12