|
@@ -81,7 +81,7 @@ enum NPCM7xxCLKRegisters {
|
|
|
* All are loaded on power-up reset. CLKENx and SWRSTR should also be loaded on
|
|
|
* core domain reset, but this reset type is not yet supported by QEMU.
|
|
|
*/
|
|
|
-static const uint32_t cold_reset_values[NPCM7XX_CLK_NR_REGS] = {
|
|
|
+static const uint32_t npcm7xx_cold_reset_values[NPCM7XX_CLK_NR_REGS] = {
|
|
|
[NPCM7XX_CLK_CLKEN1] = 0xffffffff,
|
|
|
[NPCM7XX_CLK_CLKSEL] = 0x004aaaaa,
|
|
|
[NPCM7XX_CLK_CLKDIV1] = 0x5413f855,
|
|
@@ -728,10 +728,11 @@ static uint64_t npcm_clk_read(void *opaque, hwaddr offset, unsigned size)
|
|
|
{
|
|
|
uint32_t reg = offset / sizeof(uint32_t);
|
|
|
NPCMCLKState *s = opaque;
|
|
|
+ NPCMCLKClass *c = NPCM_CLK_GET_CLASS(s);
|
|
|
int64_t now_ns;
|
|
|
uint32_t value = 0;
|
|
|
|
|
|
- if (reg >= NPCM7XX_CLK_NR_REGS) {
|
|
|
+ if (reg >= c->nr_regs) {
|
|
|
qemu_log_mask(LOG_GUEST_ERROR,
|
|
|
"%s: offset 0x%04" HWADDR_PRIx " out of range\n",
|
|
|
__func__, offset);
|
|
@@ -776,11 +777,12 @@ static void npcm_clk_write(void *opaque, hwaddr offset,
|
|
|
{
|
|
|
uint32_t reg = offset / sizeof(uint32_t);
|
|
|
NPCMCLKState *s = opaque;
|
|
|
+ NPCMCLKClass *c = NPCM_CLK_GET_CLASS(s);
|
|
|
uint32_t value = v;
|
|
|
|
|
|
trace_npcm_clk_write(offset, value);
|
|
|
|
|
|
- if (reg >= NPCM7XX_CLK_NR_REGS) {
|
|
|
+ if (reg >= c->nr_regs) {
|
|
|
qemu_log_mask(LOG_GUEST_ERROR,
|
|
|
"%s: offset 0x%04" HWADDR_PRIx " out of range\n",
|
|
|
__func__, offset);
|
|
@@ -870,10 +872,10 @@ static const struct MemoryRegionOps npcm_clk_ops = {
|
|
|
static void npcm_clk_enter_reset(Object *obj, ResetType type)
|
|
|
{
|
|
|
NPCMCLKState *s = NPCM_CLK(obj);
|
|
|
+ NPCMCLKClass *c = NPCM_CLK_GET_CLASS(s);
|
|
|
|
|
|
- QEMU_BUILD_BUG_ON(sizeof(s->regs) != sizeof(cold_reset_values));
|
|
|
-
|
|
|
- memcpy(s->regs, cold_reset_values, sizeof(cold_reset_values));
|
|
|
+ g_assert(sizeof(s->regs) >= c->nr_regs * sizeof(uint32_t));
|
|
|
+ memcpy(s->regs, c->cold_reset_values, sizeof(s->regs));
|
|
|
s->ref_ns = qemu_clock_get_ns(QEMU_CLOCK_VIRTUAL);
|
|
|
npcm7xx_clk_update_all_clocks(s);
|
|
|
/*
|
|
@@ -1045,11 +1047,14 @@ static void npcm_clk_class_init(ObjectClass *klass, void *data)
|
|
|
|
|
|
static void npcm7xx_clk_class_init(ObjectClass *klass, void *data)
|
|
|
{
|
|
|
+ NPCMCLKClass *c = NPCM_CLK_CLASS(klass);
|
|
|
DeviceClass *dc = DEVICE_CLASS(klass);
|
|
|
|
|
|
QEMU_BUILD_BUG_ON(NPCM7XX_CLK_REGS_END > NPCM_CLK_MAX_NR_REGS);
|
|
|
QEMU_BUILD_BUG_ON(NPCM7XX_CLK_REGS_END != NPCM7XX_CLK_NR_REGS);
|
|
|
dc->desc = "NPCM7xx Clock Control Registers";
|
|
|
+ c->nr_regs = NPCM7XX_CLK_NR_REGS;
|
|
|
+ c->cold_reset_values = npcm7xx_cold_reset_values;
|
|
|
}
|
|
|
|
|
|
static const TypeInfo npcm7xx_clk_pll_info = {
|
|
@@ -1081,6 +1086,7 @@ static const TypeInfo npcm_clk_info = {
|
|
|
.parent = TYPE_SYS_BUS_DEVICE,
|
|
|
.instance_size = sizeof(NPCMCLKState),
|
|
|
.instance_init = npcm_clk_init,
|
|
|
+ .class_size = sizeof(NPCMCLKClass),
|
|
|
.class_init = npcm_clk_class_init,
|
|
|
.abstract = true,
|
|
|
};
|