mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-05 00:33:55 -06:00
ppc/spapr: Move GPRs setup to one place
At the moment "pseries" starts in SLOF which only expects the FDT blob pointer in r3. As we are going to introduce a OpenFirmware support in QEMU, we will be booting OF clients directly and these expect a stack pointer in r1, Linux looks at r3/r4 for the initramdisk location (although vmlinux can find this from the device tree but zImage from distro kernels cannot). This extends spapr_cpu_set_entry_state() to take more registers. This should cause no behavioral change. Signed-off-by: Alexey Kardashevskiy <aik@ozlabs.ru> Message-Id: <20200310050733.29805-2-aik@ozlabs.ru> Reviewed-by: Greg Kurz <groug@kaod.org> Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
This commit is contained in:
parent
94f040aaec
commit
395a20d3cc
4 changed files with 10 additions and 4 deletions
|
@ -76,13 +76,17 @@ static void spapr_reset_vcpu(PowerPCCPU *cpu)
|
|||
spapr_irq_cpu_intc_reset(spapr, cpu);
|
||||
}
|
||||
|
||||
void spapr_cpu_set_entry_state(PowerPCCPU *cpu, target_ulong nip, target_ulong r3)
|
||||
void spapr_cpu_set_entry_state(PowerPCCPU *cpu, target_ulong nip,
|
||||
target_ulong r1, target_ulong r3,
|
||||
target_ulong r4)
|
||||
{
|
||||
PowerPCCPUClass *pcc = POWERPC_CPU_GET_CLASS(cpu);
|
||||
CPUPPCState *env = &cpu->env;
|
||||
|
||||
env->nip = nip;
|
||||
env->gpr[1] = r1;
|
||||
env->gpr[3] = r3;
|
||||
env->gpr[4] = r4;
|
||||
kvmppc_set_reg_ppc_online(cpu, 1);
|
||||
CPU(cpu)->halted = 0;
|
||||
/* Enable Power-saving mode Exit Cause exceptions */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue