Signed-off-by: Kuan-Jui Chiu <[email protected]>
---
hw/arm/Kconfig | 1 +
hw/arm/ax3000-soc.c | 8 ++++++++
include/hw/arm/ax3000-soc.h | 2 ++
3 files changed, 11 insertions(+)
diff --git a/hw/arm/Kconfig b/hw/arm/Kconfig
index 818ffdbce56..866e4b14e6f 100644
--- a/hw/arm/Kconfig
+++ b/hw/arm/Kconfig
@@ -723,4 +723,5 @@ config AXIADO_SOC
depends on ARM
select ARM_GIC
select CADENCE # UART
+ select AXIADO_CLK
select UNIMP
diff --git a/hw/arm/ax3000-soc.c b/hw/arm/ax3000-soc.c
index 8e8d2edfb71..9a01d23bcc6 100644
--- a/hw/arm/ax3000-soc.c
+++ b/hw/arm/ax3000-soc.c
@@ -33,6 +33,8 @@ static void ax3000_init(Object *obj)
g_autofree char *name = g_strdup_printf("uart%d", i);
object_initialize_child(obj, name, &s->uart[i], TYPE_CADENCE_UART);
}
+
+ object_initialize_child(obj, "clk", &s->ax3000_clk, TYPE_AX3000_CLK);
}
static void ax3000_realize(DeviceState *dev, Error **errp)
@@ -157,6 +159,12 @@ static void ax3000_realize(DeviceState *dev, Error **errp)
/* Timer control */
create_unimplemented_device("ax3000.timerctrl", AX3000_TIMER_CTRL, 32);
+
+ /* Clock control */
+ if (!sysbus_realize(SYS_BUS_DEVICE(&s->ax3000_clk), errp)) {
+ return;
+ }
+ sysbus_mmio_map(SYS_BUS_DEVICE(&s->ax3000_clk), 0, AX3000_PLL_BASE);
}
static void ax3000_class_init(ObjectClass *oc, const void *data)
diff --git a/include/hw/arm/ax3000-soc.h b/include/hw/arm/ax3000-soc.h
index b984d7a8ec3..329aa4e7698 100644
--- a/include/hw/arm/ax3000-soc.h
+++ b/include/hw/arm/ax3000-soc.h
@@ -12,6 +12,7 @@
#include "cpu.h"
#include "hw/intc/arm_gicv3_common.h"
#include "hw/char/cadence_uart.h"
+#include "hw/misc/axiado_clk.h"
#include "hw/core/sysbus.h"
#include "qemu/units.h"
@@ -49,6 +50,7 @@ typedef struct Ax3000SoCState {
ARMCPU cpu[AX3000_NUM_CPUS];
GICv3State gic;
MemoryRegion dram[AX3000_NUM_BANKS];
+ Ax3000ClkState ax3000_clk;
CadenceUARTState uart[AX3000_NUM_UARTS];
} Ax3000SoCState;
--
2.34.1