diff options
author | Philippe Mathieu-Daudé <philmd@linaro.org> | 2023-10-24 18:24:19 +0200 |
---|---|---|
committer | Cédric Le Goater <clg@kaod.org> | 2023-10-25 09:52:44 +0200 |
commit | 24a88476ffbecdd6ffb96a5298d90de10176a301 (patch) | |
tree | d58ab9c86c89240b88d76778983bbe608e3f930c | |
parent | 1a94fae4c18aacc563a6c6bf61aa7f357f1e2eb0 (diff) | |
download | qemu-24a88476ffbecdd6ffb96a5298d90de10176a301.zip qemu-24a88476ffbecdd6ffb96a5298d90de10176a301.tar.gz qemu-24a88476ffbecdd6ffb96a5298d90de10176a301.tar.bz2 |
hw/arm/aspeed: Check 'memory' link is set in common aspeed_soc_realize
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Cédric Le Goater <clg@kaod.org>
Signed-off-by: Cédric Le Goater <clg@kaod.org>
-rw-r--r-- | hw/arm/aspeed_soc_common.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/hw/arm/aspeed_soc_common.c b/hw/arm/aspeed_soc_common.c index b66f769..828f610 100644 --- a/hw/arm/aspeed_soc_common.c +++ b/hw/arm/aspeed_soc_common.c @@ -114,6 +114,16 @@ void aspeed_mmio_map_unimplemented(AspeedSoCState *s, SysBusDevice *dev, sysbus_mmio_get_region(dev, 0), -1000); } +static void aspeed_soc_realize(DeviceState *dev, Error **errp) +{ + AspeedSoCState *s = ASPEED_SOC(dev); + + if (!s->memory) { + error_setg(errp, "'memory' link is not set"); + return; + } +} + static Property aspeed_soc_properties[] = { DEFINE_PROP_LINK("dram", AspeedSoCState, dram_mr, TYPE_MEMORY_REGION, MemoryRegion *), @@ -126,6 +136,7 @@ static void aspeed_soc_class_init(ObjectClass *oc, void *data) { DeviceClass *dc = DEVICE_CLASS(oc); + dc->realize = aspeed_soc_realize; device_class_set_props(dc, aspeed_soc_properties); } |