[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-ppc] [PATCH for-2.13 10/10] spapr: Move PAPR specific cpu logi
From: |
Greg Kurz |
Subject: |
Re: [Qemu-ppc] [PATCH for-2.13 10/10] spapr: Move PAPR specific cpu logic to pseries machine type |
Date: |
Fri, 20 Apr 2018 17:58:55 +0200 |
On Tue, 17 Apr 2018 17:17:22 +1000
David Gibson <address@hidden> wrote:
> cpu_ppc_set_papr() does three things: 1) it sets up the virtual hypervisor
> interface, 2) it prevents the cpu from ever entering hypervisor mode and
> 3) it tells KVM that we're emulating a cpu in PAPR mode.
>
> (1) & (2) make sense for any virtual hypervisor (if one ever exists). (3)
> belongs more properly in the machine type specific to a PAPR guest.
>
> While we're at it, remove an unnecessary test on kvm_enabled() by making
> kvmppc_set_papr() a safe no-op on non-KVM.
>
> Signed-off-by: David Gibson <address@hidden>
> ---
Reviewed-by: Greg Kurz <address@hidden>
> hw/ppc/spapr_cpu_core.c | 4 ++--
> target/ppc/cpu.h | 2 +-
> target/ppc/kvm.c | 4 ++++
> target/ppc/translate_init.c | 7 +------
> 4 files changed, 8 insertions(+), 9 deletions(-)
>
> diff --git a/hw/ppc/spapr_cpu_core.c b/hw/ppc/spapr_cpu_core.c
> index 8be0265d04..0a668b8954 100644
> --- a/hw/ppc/spapr_cpu_core.c
> +++ b/hw/ppc/spapr_cpu_core.c
> @@ -94,8 +94,8 @@ static void spapr_cpu_init(sPAPRMachineState *spapr,
> PowerPCCPU *cpu,
> /* Set time-base frequency to 512 MHz */
> cpu_ppc_tb_init(env, SPAPR_TIMEBASE_FREQ);
>
> - /* Enable PAPR mode in TCG or KVM */
> - cpu_ppc_set_papr(cpu, PPC_VIRTUAL_HYPERVISOR(spapr));
> + cpu_ppc_set_vhyp(cpu, PPC_VIRTUAL_HYPERVISOR(spapr));
> + kvmppc_set_papr(cpu);
>
> qemu_register_reset(spapr_cpu_reset, cpu);
> }
> diff --git a/target/ppc/cpu.h b/target/ppc/cpu.h
> index 8c9e03f54d..740939a085 100644
> --- a/target/ppc/cpu.h
> +++ b/target/ppc/cpu.h
> @@ -1331,7 +1331,7 @@ void store_booke_tcr (CPUPPCState *env, target_ulong
> val);
> void store_booke_tsr (CPUPPCState *env, target_ulong val);
> void ppc_tlb_invalidate_all (CPUPPCState *env);
> void ppc_tlb_invalidate_one (CPUPPCState *env, target_ulong addr);
> -void cpu_ppc_set_papr(PowerPCCPU *cpu, PPCVirtualHypervisor *vhyp);
> +void cpu_ppc_set_vhyp(PowerPCCPU *cpu, PPCVirtualHypervisor *vhyp);
> #endif
> #endif
>
> diff --git a/target/ppc/kvm.c b/target/ppc/kvm.c
> index 51177a8e00..e4341d6ff7 100644
> --- a/target/ppc/kvm.c
> +++ b/target/ppc/kvm.c
> @@ -2090,6 +2090,10 @@ void kvmppc_set_papr(PowerPCCPU *cpu)
> CPUState *cs = CPU(cpu);
> int ret;
>
> + if (!kvm_enabled()) {
> + return;
> + }
> +
> ret = kvm_vcpu_enable_cap(cs, KVM_CAP_PPC_PAPR, 0);
> if (ret) {
> error_report("This vCPU type or KVM version does not support PAPR");
> diff --git a/target/ppc/translate_init.c b/target/ppc/translate_init.c
> index bb5559d799..95e8dba97a 100644
> --- a/target/ppc/translate_init.c
> +++ b/target/ppc/translate_init.c
> @@ -8864,7 +8864,7 @@ POWERPC_FAMILY(POWER9)(ObjectClass *oc, void *data)
> }
>
> #if !defined(CONFIG_USER_ONLY)
> -void cpu_ppc_set_papr(PowerPCCPU *cpu, PPCVirtualHypervisor *vhyp)
> +void cpu_ppc_set_vhyp(PowerPCCPU *cpu, PPCVirtualHypervisor *vhyp)
> {
> CPUPPCState *env = &cpu->env;
>
> @@ -8875,11 +8875,6 @@ void cpu_ppc_set_papr(PowerPCCPU *cpu,
> PPCVirtualHypervisor *vhyp)
> * hypervisor mode itself
> */
> env->msr_mask &= ~MSR_HVB;
> -
> - /* Tell KVM that we're in PAPR mode */
> - if (kvm_enabled()) {
> - kvmppc_set_papr(cpu);
> - }
> }
>
> #endif /* !defined(CONFIG_USER_ONLY) */
- Re: [Qemu-ppc] [PATCH for-2.13 02/10] spapr: Remove support for PowerPC 970 with pseries machine type, (continued)
- [Qemu-ppc] [PATCH for-2.13 05/10] spapr: Move PAPR mode register initialization to spapr code, David Gibson, 2018/04/17
- [Qemu-ppc] [PATCH for-2.13 06/10] target/ppc: Add ppc_store_lpcr() helper, David Gibson, 2018/04/17
- [Qemu-ppc] [PATCH for-2.13 04/10] spapr: Set compatibility mode before the rest of spapr_cpu_reset(), David Gibson, 2018/04/17
- [Qemu-ppc] [PATCH for-2.13 10/10] spapr: Move PAPR specific cpu logic to pseries machine type, David Gibson, 2018/04/17
- Re: [Qemu-ppc] [PATCH for-2.13 10/10] spapr: Move PAPR specific cpu logic to pseries machine type,
Greg Kurz <=
- [Qemu-ppc] [PATCH for-2.13 08/10] spapr: Clean up handling of LPCR power-saving exit bits, David Gibson, 2018/04/17