hw/mips: Have mips_cpu_create_with_clock() take an endianness argument
mips_cpu_create_with_clock() creates a vCPU. Pass it the vCPU endianness requested by argument. Update the board call sites. Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> Reviewed-by: Jiaxun Yang <jiaxun.yang@flygoat.com> Tested-by: Jiaxun Yang <jiaxun.yang@flygoat.com> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Message-Id: <20241010215015.44326-17-philmd@linaro.org>
This commit is contained in:
parent
805659a895
commit
3e8f019be7
@ -229,7 +229,7 @@ static void mips_fuloong2e_init(MachineState *machine)
|
||||
clock_set_hz(cpuclk, 533080000); /* ~533 MHz */
|
||||
|
||||
/* init CPUs */
|
||||
cpu = mips_cpu_create_with_clock(machine->cpu_type, cpuclk);
|
||||
cpu = mips_cpu_create_with_clock(machine->cpu_type, cpuclk, false);
|
||||
env = &cpu->env;
|
||||
|
||||
qemu_register_reset(main_cpu_reset, cpu);
|
||||
|
@ -212,7 +212,8 @@ static void mips_jazz_init(MachineState *machine,
|
||||
* ext_clk[jazz_model].pll_mult);
|
||||
|
||||
/* init CPUs */
|
||||
cpu = mips_cpu_create_with_clock(machine->cpu_type, cpuclk);
|
||||
cpu = mips_cpu_create_with_clock(machine->cpu_type, cpuclk,
|
||||
TARGET_BIG_ENDIAN);
|
||||
env = &cpu->env;
|
||||
qemu_register_reset(main_cpu_reset, cpu);
|
||||
|
||||
|
@ -567,7 +567,7 @@ static void mips_loongson3_virt_init(MachineState *machine)
|
||||
int ip;
|
||||
|
||||
/* init CPUs */
|
||||
cpu = mips_cpu_create_with_clock(machine->cpu_type, cpuclk);
|
||||
cpu = mips_cpu_create_with_clock(machine->cpu_type, cpuclk, false);
|
||||
|
||||
/* Init internal devices */
|
||||
cpu_mips_irq_init_cpu(cpu);
|
||||
|
@ -1034,7 +1034,8 @@ static void create_cpu_without_cps(MachineState *ms, MaltaState *s,
|
||||
int i;
|
||||
|
||||
for (i = 0; i < ms->smp.cpus; i++) {
|
||||
cpu = mips_cpu_create_with_clock(ms->cpu_type, s->cpuclk);
|
||||
cpu = mips_cpu_create_with_clock(ms->cpu_type, s->cpuclk,
|
||||
TARGET_BIG_ENDIAN);
|
||||
|
||||
/* Init internal devices */
|
||||
cpu_mips_irq_init_cpu(cpu);
|
||||
|
@ -160,7 +160,8 @@ mips_mipssim_init(MachineState *machine)
|
||||
#endif
|
||||
|
||||
/* Init CPUs. */
|
||||
cpu = mips_cpu_create_with_clock(machine->cpu_type, cpuclk);
|
||||
cpu = mips_cpu_create_with_clock(machine->cpu_type, cpuclk,
|
||||
TARGET_BIG_ENDIAN);
|
||||
env = &cpu->env;
|
||||
|
||||
reset_info = g_new0(ResetData, 1);
|
||||
|
@ -643,12 +643,15 @@ static void mips_cpu_register_types(void)
|
||||
type_init(mips_cpu_register_types)
|
||||
|
||||
/* Could be used by generic CPU object */
|
||||
MIPSCPU *mips_cpu_create_with_clock(const char *cpu_type, Clock *cpu_refclk)
|
||||
MIPSCPU *mips_cpu_create_with_clock(const char *cpu_type, Clock *cpu_refclk,
|
||||
bool is_big_endian)
|
||||
{
|
||||
DeviceState *cpu;
|
||||
|
||||
cpu = DEVICE(object_new(cpu_type));
|
||||
qdev_connect_clock_in(cpu, "clk-in", cpu_refclk);
|
||||
object_property_set_bool(OBJECT(cpu), "big-endian", is_big_endian,
|
||||
&error_abort);
|
||||
qdev_realize(cpu, NULL, &error_abort);
|
||||
|
||||
return MIPS_CPU(cpu);
|
||||
|
@ -1376,12 +1376,14 @@ static inline void cpu_get_tb_cpu_state(CPUMIPSState *env, vaddr *pc,
|
||||
* mips_cpu_create_with_clock:
|
||||
* @typename: a MIPS CPU type.
|
||||
* @cpu_refclk: this cpu input clock (an output clock of another device)
|
||||
* @is_big_endian: whether this CPU is configured in big endianness
|
||||
*
|
||||
* Instantiates a MIPS CPU, set the input clock of the CPU to @cpu_refclk,
|
||||
* then realizes the CPU.
|
||||
*
|
||||
* Returns: A #CPUState or %NULL if an error occurred.
|
||||
*/
|
||||
MIPSCPU *mips_cpu_create_with_clock(const char *cpu_type, Clock *cpu_refclk);
|
||||
MIPSCPU *mips_cpu_create_with_clock(const char *cpu_type, Clock *cpu_refclk,
|
||||
bool is_big_endian);
|
||||
|
||||
#endif /* MIPS_CPU_H */
|
||||
|
Loading…
Reference in New Issue
Block a user