hw/mips/itu: Pass SAAR using QOM link property

QOM objects shouldn't access each other internals fields
except using the QOM API.

mips_cps_realize() instantiates a TYPE_MIPS_ITU object, and
directly sets the 'saar' pointer:

   if (saar_present) {
       s->itu.saar = &env->CP0_SAAR;
   }

In order to avoid that, pass the MIPS_CPU object via a QOM
link property, and set the 'saar' pointer in mips_itu_realize().

Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Tested-by: Jiaxun Yang <jiaxun.yang@flygoat.com>
Reviewed-by: Jiaxun Yang <jiaxun.yang@flygoat.com>
Message-Id: <20230203113650.78146-10-philmd@linaro.org>
This commit is contained in:
Philippe Mathieu-Daudé 2023-02-02 14:22:42 +01:00
parent 10997f2d1d
commit 4c921e3fb2
3 changed files with 26 additions and 28 deletions

View File

@ -66,20 +66,17 @@ static bool cpu_mips_itu_supported(CPUMIPSState *env)
static void mips_cps_realize(DeviceState *dev, Error **errp) static void mips_cps_realize(DeviceState *dev, Error **errp)
{ {
MIPSCPSState *s = MIPS_CPS(dev); MIPSCPSState *s = MIPS_CPS(dev);
CPUMIPSState *env;
MIPSCPU *cpu;
int i;
target_ulong gcr_base; target_ulong gcr_base;
bool itu_present = false; bool itu_present = false;
bool saar_present = false;
if (!clock_get(s->clock)) { if (!clock_get(s->clock)) {
error_setg(errp, "CPS input clock is not connected to an output clock"); error_setg(errp, "CPS input clock is not connected to an output clock");
return; return;
} }
for (i = 0; i < s->num_vp; i++) { for (int i = 0; i < s->num_vp; i++) {
cpu = MIPS_CPU(object_new(s->cpu_type)); MIPSCPU *cpu = MIPS_CPU(object_new(s->cpu_type));
CPUMIPSState *env = &cpu->env;
/* All VPs are halted on reset. Leave powering up to CPC. */ /* All VPs are halted on reset. Leave powering up to CPC. */
if (!object_property_set_bool(OBJECT(cpu), "start-powered-off", true, if (!object_property_set_bool(OBJECT(cpu), "start-powered-off", true,
@ -97,7 +94,6 @@ static void mips_cps_realize(DeviceState *dev, Error **errp)
cpu_mips_irq_init_cpu(cpu); cpu_mips_irq_init_cpu(cpu);
cpu_mips_clock_init(cpu); cpu_mips_clock_init(cpu);
env = &cpu->env;
if (cpu_mips_itu_supported(env)) { if (cpu_mips_itu_supported(env)) {
itu_present = true; itu_present = true;
/* Attach ITC Tag to the VP */ /* Attach ITC Tag to the VP */
@ -107,22 +103,15 @@ static void mips_cps_realize(DeviceState *dev, Error **errp)
qemu_register_reset(main_cpu_reset, cpu); qemu_register_reset(main_cpu_reset, cpu);
} }
cpu = MIPS_CPU(first_cpu);
env = &cpu->env;
saar_present = (bool)env->saarp;
/* Inter-Thread Communication Unit */ /* Inter-Thread Communication Unit */
if (itu_present) { if (itu_present) {
object_initialize_child(OBJECT(dev), "itu", &s->itu, TYPE_MIPS_ITU); object_initialize_child(OBJECT(dev), "itu", &s->itu, TYPE_MIPS_ITU);
object_property_set_link(OBJECT(&s->itu), "cpu[0]",
OBJECT(first_cpu), &error_abort);
object_property_set_uint(OBJECT(&s->itu), "num-fifo", 16, object_property_set_uint(OBJECT(&s->itu), "num-fifo", 16,
&error_abort); &error_abort);
object_property_set_uint(OBJECT(&s->itu), "num-semaphores", 16, object_property_set_uint(OBJECT(&s->itu), "num-semaphores", 16,
&error_abort); &error_abort);
object_property_set_bool(OBJECT(&s->itu), "saar-present", saar_present,
&error_abort);
if (saar_present) {
s->itu.saar = &env->CP0_SAAR;
}
if (!sysbus_realize(SYS_BUS_DEVICE(&s->itu), errp)) { if (!sysbus_realize(SYS_BUS_DEVICE(&s->itu), errp)) {
return; return;
} }
@ -158,7 +147,7 @@ static void mips_cps_realize(DeviceState *dev, Error **errp)
sysbus_mmio_get_region(SYS_BUS_DEVICE(&s->gic), 0)); sysbus_mmio_get_region(SYS_BUS_DEVICE(&s->gic), 0));
/* Global Configuration Registers */ /* Global Configuration Registers */
gcr_base = env->CP0_CMGCRBase << 4; gcr_base = MIPS_CPU(first_cpu)->env.CP0_CMGCRBase << 4;
object_initialize_child(OBJECT(dev), "gcr", &s->gcr, TYPE_MIPS_GCR); object_initialize_child(OBJECT(dev), "gcr", &s->gcr, TYPE_MIPS_GCR);
object_property_set_uint(OBJECT(&s->gcr), "num-vp", s->num_vp, object_property_set_uint(OBJECT(&s->gcr), "num-vp", s->num_vp,

View File

@ -93,10 +93,10 @@ void itc_reconfigure(MIPSITUState *tag)
uint64_t size = (1 * KiB) + (am[1] & ITC_AM1_ADDR_MASK_MASK); uint64_t size = (1 * KiB) + (am[1] & ITC_AM1_ADDR_MASK_MASK);
bool is_enabled = (am[0] & ITC_AM0_EN_MASK) != 0; bool is_enabled = (am[0] & ITC_AM0_EN_MASK) != 0;
if (tag->saar_present) { if (tag->saar) {
address = ((*(uint64_t *) tag->saar) & 0xFFFFFFFFE000ULL) << 4; address = (tag->saar[0] & 0xFFFFFFFFE000ULL) << 4;
size = 1ULL << ((*(uint64_t *) tag->saar >> 1) & 0x1f); size = 1ULL << ((tag->saar[0] >> 1) & 0x1f);
is_enabled = *(uint64_t *) tag->saar & 1; is_enabled = tag->saar[0] & 1;
} }
memory_region_transaction_begin(); memory_region_transaction_begin();
@ -157,7 +157,7 @@ static inline ITCView get_itc_view(hwaddr addr)
static inline int get_cell_stride_shift(const MIPSITUState *s) static inline int get_cell_stride_shift(const MIPSITUState *s)
{ {
/* Minimum interval (for EntryGain = 0) is 128 B */ /* Minimum interval (for EntryGain = 0) is 128 B */
if (s->saar_present) { if (s->saar) {
return 7 + ((s->icr0 >> ITC_ICR0_BLK_GRAIN) & return 7 + ((s->icr0 >> ITC_ICR0_BLK_GRAIN) &
ITC_ICR0_BLK_GRAIN_MASK); ITC_ICR0_BLK_GRAIN_MASK);
} else { } else {
@ -515,6 +515,7 @@ static void mips_itu_init(Object *obj)
static void mips_itu_realize(DeviceState *dev, Error **errp) static void mips_itu_realize(DeviceState *dev, Error **errp)
{ {
MIPSITUState *s = MIPS_ITU(dev); MIPSITUState *s = MIPS_ITU(dev);
CPUMIPSState *env;
if (s->num_fifo > ITC_FIFO_NUM_MAX) { if (s->num_fifo > ITC_FIFO_NUM_MAX) {
error_setg(errp, "Exceed maximum number of FIFO cells: %d", error_setg(errp, "Exceed maximum number of FIFO cells: %d",
@ -526,6 +527,15 @@ static void mips_itu_realize(DeviceState *dev, Error **errp)
s->num_semaphores); s->num_semaphores);
return; return;
} }
if (!s->cpu0) {
error_setg(errp, "Missing 'cpu[0]' property");
return;
}
env = &s->cpu0->env;
if (env->saarp) {
s->saar = env->CP0_SAAR;
}
s->cell = g_new(ITCStorageCell, get_num_cells(s)); s->cell = g_new(ITCStorageCell, get_num_cells(s));
} }
@ -534,8 +544,8 @@ static void mips_itu_reset(DeviceState *dev)
{ {
MIPSITUState *s = MIPS_ITU(dev); MIPSITUState *s = MIPS_ITU(dev);
if (s->saar_present) { if (s->saar) {
*(uint64_t *) s->saar = 0x11 << 1; s->saar[0] = 0x11 << 1;
s->icr0 = get_num_cells(s) << ITC_ICR0_CELL_NUM; s->icr0 = get_num_cells(s) << ITC_ICR0_CELL_NUM;
} else { } else {
s->ITCAddressMap[0] = 0; s->ITCAddressMap[0] = 0;
@ -553,7 +563,7 @@ static Property mips_itu_properties[] = {
ITC_FIFO_NUM_MAX), ITC_FIFO_NUM_MAX),
DEFINE_PROP_UINT32("num-semaphores", MIPSITUState, num_semaphores, DEFINE_PROP_UINT32("num-semaphores", MIPSITUState, num_semaphores,
ITC_SEMAPH_NUM_MAX), ITC_SEMAPH_NUM_MAX),
DEFINE_PROP_BOOL("saar-present", MIPSITUState, saar_present, false), DEFINE_PROP_LINK("cpu[0]", MIPSITUState, cpu0, TYPE_MIPS_CPU, MIPSCPU *),
DEFINE_PROP_END_OF_LIST(), DEFINE_PROP_END_OF_LIST(),
}; };

View File

@ -72,9 +72,8 @@ struct MIPSITUState {
uint64_t icr0; uint64_t icr0;
/* SAAR */ /* SAAR */
bool saar_present; uint64_t *saar;
void *saar; MIPSCPU *cpu0;
}; };
/* Get ITC Configuration Tag memory region. */ /* Get ITC Configuration Tag memory region. */