From: Greg Kurz <groug@kaod.org>
To: David Gibson <david@gibson.dropbear.id.au>
Cc: benh@kernel.crashing.org, qemu-ppc@nongnu.org, qemu-devel@nongnu.org
Subject: Re: [Qemu-devel] [PATCH for-2.13 05/10] spapr: Move PAPR mode register initialization to spapr code
Date: Fri, 20 Apr 2018 17:42:45 +0200 [thread overview]
Message-ID: <20180420174245.12713a5e@bahia.lan> (raw)
In-Reply-To: <20180417071722.9399-6-david@gibson.dropbear.id.au>
On Tue, 17 Apr 2018 17:17:17 +1000
David Gibson <david@gibson.dropbear.id.au> wrote:
> cpu_ppc_set_papr() has code to make sure the LPCR and AMOR (hypervisor
> privileged registers) have values which will make TCG behave correctly for
> paravirtualized guests, where we don't emulate the cpu when in hypervisor
> mode.
>
> It does this by mangling the default values of the SPRs, so that they will
> be set correctly at reset time. Manipulating usually-static parameters of
> the cpu model like this is kind of ugly, especially since the values used
> really have more to do with the platform than the cpu.
>
> The spapr code already has places for PAPR specific initializations of
> register state, so move the handling of LPCR and AMOR to there.
>
> Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
> ---
> hw/ppc/spapr_cpu_core.c | 36 +++++++++++++++++++++++++++++++++++-
> target/ppc/translate_init.c | 39 ---------------------------------------
> 2 files changed, 35 insertions(+), 40 deletions(-)
>
> diff --git a/hw/ppc/spapr_cpu_core.c b/hw/ppc/spapr_cpu_core.c
> index 2aab6ccd15..9080664ec1 100644
> --- a/hw/ppc/spapr_cpu_core.c
> +++ b/hw/ppc/spapr_cpu_core.c
> @@ -28,6 +28,7 @@ static void spapr_cpu_reset(void *opaque)
> CPUState *cs = CPU(cpu);
> CPUPPCState *env = &cpu->env;
> PowerPCCPUClass *pcc = POWERPC_CPU_GET_CLASS(cpu);
> + target_ulong lpcr;
>
> cpu_reset(cs);
>
> @@ -41,13 +42,46 @@ static void spapr_cpu_reset(void *opaque)
> * using an RTAS call */
> cs->halted = 1;
>
> + lpcr = env->spr[SPR_LPCR];
> +
> + /* Set emulated LPCR to not send interrupts to hypervisor. Note that
> + * under KVM, the actual HW LPCR will be set differently by KVM itself,
> + * the settings below ensure proper operations with TCG in absence of
> + * a real hypervisor.
> + *
> + * Clearing VPM0 will also cause us to use RMOR in mmu-hash64.c for
> + * real mode accesses, which thankfully defaults to 0 and isn't
> + * accessible in guest mode.
> + */
> + lpcr &= ~(LPCR_VPM0 | LPCR_VPM1 | LPCR_ISL | LPCR_KBV);
> + lpcr |= LPCR_LPES0 | LPCR_LPES1;
> +
> + /* Set RMLS to the max (ie, 16G) */
> + lpcr &= ~LPCR_RMLS;
> + lpcr |= 1ull << LPCR_RMLS_SHIFT;
> +
> + /* Only enable Power-saving mode Exit Cause exceptions on the boot
> + * CPU. The RTAS command start-cpu will enable them on secondaries.
> + */
> + if (cs == first_cpu) {
> + lpcr |= pcc->lpcr_pm;
> + }
> +
> /* Disable Power-saving mode Exit Cause exceptions for the CPU.
> * This can cause issues when rebooting the guest if a secondary
> * is awaken */
> if (cs != first_cpu) {
> - env->spr[SPR_LPCR] &= ~pcc->lpcr_pm;
> + lpcr &= ~pcc->lpcr_pm;
> }
>
Maybe fold these into a single if-else with a consolidated comment ?
/* Only enable Power-saving mode Exit Cause exceptions on the boot
* CPU and disable it for secondaries because it is known to cause
* issues if a secondary is awaken too early when rebooting the guest.
* The RTAS command start-cpu will enable exceptions on secondaries.
*/
if (cs == first_cpu) {
lpcr |= pcc->lpcr_pm;
} else {
lpcr &= ~pcc->lpcr_pm;
}
Anyway, the patch looks good and makes cpu_ppc_set_papr() a lot clearer.
Reviewed-by: Greg Kurz <groug@kaod.org>
> + env->spr[SPR_LPCR] = lpcr;
> +
> + /* Set a full AMOR so guest can use the AMR as it sees fit */
> + env->spr[SPR_AMOR] = 0xffffffffffffffffull;
> +
> + /* Update some env bits based on new LPCR value */
> + ppc_hash64_update_rmls(cpu);
> + ppc_hash64_update_vrma(cpu);
> }
>
> static void spapr_cpu_destroy(PowerPCCPU *cpu)
> diff --git a/target/ppc/translate_init.c b/target/ppc/translate_init.c
> index 14f346f441..5e89901149 100644
> --- a/target/ppc/translate_init.c
> +++ b/target/ppc/translate_init.c
> @@ -8866,11 +8866,7 @@ POWERPC_FAMILY(POWER9)(ObjectClass *oc, void *data)
> #if !defined(CONFIG_USER_ONLY)
> void cpu_ppc_set_papr(PowerPCCPU *cpu, PPCVirtualHypervisor *vhyp)
> {
> - PowerPCCPUClass *pcc = POWERPC_CPU_GET_CLASS(cpu);
> CPUPPCState *env = &cpu->env;
> - ppc_spr_t *lpcr = &env->spr_cb[SPR_LPCR];
> - ppc_spr_t *amor = &env->spr_cb[SPR_AMOR];
> - CPUState *cs = CPU(cpu);
>
> cpu->vhyp = vhyp;
>
> @@ -8881,41 +8877,6 @@ void cpu_ppc_set_papr(PowerPCCPU *cpu, PPCVirtualHypervisor *vhyp)
> */
> env->msr_mask &= ~((1ull << MSR_EP) | MSR_HVB);
>
> - /* Set emulated LPCR to not send interrupts to hypervisor. Note that
> - * under KVM, the actual HW LPCR will be set differently by KVM itself,
> - * the settings below ensure proper operations with TCG in absence of
> - * a real hypervisor.
> - *
> - * Clearing VPM0 will also cause us to use RMOR in mmu-hash64.c for
> - * real mode accesses, which thankfully defaults to 0 and isn't
> - * accessible in guest mode.
> - */
> - lpcr->default_value &= ~(LPCR_VPM0 | LPCR_VPM1 | LPCR_ISL | LPCR_KBV);
> - lpcr->default_value |= LPCR_LPES0 | LPCR_LPES1;
> -
> - /* Set RMLS to the max (ie, 16G) */
> - lpcr->default_value &= ~LPCR_RMLS;
> - lpcr->default_value |= 1ull << LPCR_RMLS_SHIFT;
> -
> - /* Only enable Power-saving mode Exit Cause exceptions on the boot
> - * CPU. The RTAS command start-cpu will enable them on secondaries.
> - */
> - if (cs == first_cpu) {
> - lpcr->default_value |= pcc->lpcr_pm;
> - }
> -
> - /* We should be followed by a CPU reset but update the active value
> - * just in case...
> - */
> - env->spr[SPR_LPCR] = lpcr->default_value;
> -
> - /* Set a full AMOR so guest can use the AMR as it sees fit */
> - env->spr[SPR_AMOR] = amor->default_value = 0xffffffffffffffffull;
> -
> - /* Update some env bits based on new LPCR value */
> - ppc_hash64_update_rmls(cpu);
> - ppc_hash64_update_vrma(cpu);
> -
> /* Tell KVM that we're in PAPR mode */
> if (kvm_enabled()) {
> kvmppc_set_papr(cpu);
next prev parent reply other threads:[~2018-04-20 15:42 UTC|newest]
Thread overview: 40+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-04-17 7:17 [Qemu-devel] [PATCH for-2.13 00/10] spapr: Cleanups to PAPR mode setup David Gibson
2018-04-17 7:17 ` [Qemu-devel] [PATCH for-2.13 01/10] spapr: Avoid redundant calls to spapr_cpu_reset() David Gibson
2018-04-19 13:48 ` Greg Kurz
2018-04-20 6:34 ` David Gibson
2018-04-20 9:15 ` Greg Kurz
2018-04-20 15:39 ` [Qemu-devel] [Qemu-ppc] " Greg Kurz
2018-06-18 3:42 ` David Gibson
2018-06-18 9:01 ` Greg Kurz
2018-04-17 7:17 ` [Qemu-devel] [PATCH for-2.13 02/10] spapr: Remove support for PowerPC 970 with pseries machine type David Gibson
2018-04-19 17:21 ` Greg Kurz
2018-04-20 5:58 ` [Qemu-devel] [Qemu-ppc] " Thomas Huth
2018-04-20 6:40 ` [Qemu-devel] " David Gibson
2018-04-20 6:48 ` [Qemu-devel] [Qemu-ppc] " luigi burdo
2018-04-20 7:15 ` David Gibson
2018-04-20 12:25 ` [Qemu-devel] " Greg Kurz
2018-05-03 6:23 ` David Gibson
2018-04-17 7:17 ` [Qemu-devel] [PATCH for-2.13 03/10] target/ppc: Remove unnecessary initialization of LPCR_UPRT David Gibson
2018-04-20 11:34 ` Greg Kurz
2018-04-20 12:57 ` David Gibson
2018-04-25 9:52 ` [Qemu-devel] [Qemu-ppc] " Cédric Le Goater
2018-04-26 6:46 ` David Gibson
2018-04-26 7:20 ` Cédric Le Goater
2018-05-01 6:39 ` David Gibson
2018-05-01 15:59 ` Cédric Le Goater
2018-04-17 7:17 ` [Qemu-devel] [PATCH for-2.13 04/10] spapr: Set compatibility mode before the rest of spapr_cpu_reset() David Gibson
2018-04-20 9:16 ` Greg Kurz
2018-04-20 10:48 ` David Gibson
2018-04-17 7:17 ` [Qemu-devel] [PATCH for-2.13 05/10] spapr: Move PAPR mode register initialization to spapr code David Gibson
2018-04-20 15:42 ` Greg Kurz [this message]
2018-04-17 7:17 ` [Qemu-devel] [PATCH for-2.13 06/10] target/ppc: Add ppc_store_lpcr() helper David Gibson
2018-04-20 15:46 ` Greg Kurz
2018-04-17 7:17 ` [Qemu-devel] [PATCH for-2.13 07/10] spapr: Make a helper to set up cpu entry point state David Gibson
2018-04-20 15:48 ` Greg Kurz
2018-04-17 7:17 ` [Qemu-devel] [PATCH for-2.13 08/10] spapr: Clean up handling of LPCR power-saving exit bits David Gibson
2018-04-20 15:56 ` Greg Kurz
2018-04-17 7:17 ` [Qemu-devel] [PATCH for-2.13 09/10] target/ppc: Don't bother with MSR_EP in cpu_ppc_set_papr() David Gibson
2018-04-20 6:08 ` [Qemu-devel] [Qemu-ppc] " Thomas Huth
2018-04-20 6:21 ` David Gibson
2018-04-17 7:17 ` [Qemu-devel] [PATCH for-2.13 10/10] spapr: Move PAPR specific cpu logic to pseries machine type David Gibson
2018-04-20 15:58 ` Greg Kurz
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20180420174245.12713a5e@bahia.lan \
--to=groug@kaod.org \
--cc=benh@kernel.crashing.org \
--cc=david@gibson.dropbear.id.au \
--cc=qemu-devel@nongnu.org \
--cc=qemu-ppc@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).