[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v4 03/17] target/ppc: Properly sync cpu state with new msr in
From: |
David Gibson |
Subject: |
Re: [PATCH v4 03/17] target/ppc: Properly sync cpu state with new msr in cpu_load_old |
Date: |
Mon, 22 Mar 2021 14:38:22 +1100 |
On Mon, Mar 15, 2021 at 12:46:01PM -0600, Richard Henderson wrote:
> Match cpu_post_load in using ppc_store_msr to set all of
> the cpu state implied by the value of msr. Do not restore
> hflags or hflags_nmsr, as we recompute them in ppc_store_msr.
>
> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
Applied to ppc-for-6.0, thanks.
> ---
> target/ppc/machine.c | 13 +++++++++++--
> 1 file changed, 11 insertions(+), 2 deletions(-)
>
> diff --git a/target/ppc/machine.c b/target/ppc/machine.c
> index 283db1d28a..87d7bffb86 100644
> --- a/target/ppc/machine.c
> +++ b/target/ppc/machine.c
> @@ -21,6 +21,7 @@ static int cpu_load_old(QEMUFile *f, void *opaque, int
> version_id)
> int32_t slb_nr;
> #endif
> target_ulong xer;
> + target_ulong msr;
>
> for (i = 0; i < 32; i++) {
> qemu_get_betls(f, &env->gpr[i]);
> @@ -111,11 +112,19 @@ static int cpu_load_old(QEMUFile *f, void *opaque, int
> version_id)
> qemu_get_betls(f, &env->ivpr_mask);
> qemu_get_betls(f, &env->hreset_vector);
> qemu_get_betls(f, &env->nip);
> - qemu_get_betls(f, &env->hflags);
> - qemu_get_betls(f, &env->hflags_nmsr);
> + qemu_get_sbetl(f); /* Discard unused hflags */
> + qemu_get_sbetl(f); /* Discard unused hflags_nmsr */
> qemu_get_sbe32(f); /* Discard unused mmu_idx */
> qemu_get_sbe32(f); /* Discard unused power_mode */
>
> + /*
> + * Invalidate all supported msr bits except MSR_TGPR/MSR_HVB
> + * before restoring. Note that this recomputes hflags and mem_idx.
> + */
> + msr = env->msr;
> + env->msr ^= env->msr_mask & ~((1ULL << MSR_TGPR) | MSR_HVB);
> + ppc_store_msr(env, msr);
> +
> /* Recompute mmu indices */
> hreg_compute_mem_idx(env);
>
--
David Gibson | I'll have my music baroque, and my code
david AT gibson.dropbear.id.au | minimalist, thank you. NOT _the_ _other_
| _way_ _around_!
http://www.ozlabs.org/~dgibson
signature.asc
Description: PGP signature
- [PATCH v4 02/17] target/ppc: Move 601 hflags adjustment to hreg_compute_hflags, (continued)
- [PATCH v4 06/17] target/ppc: Fix comment for MSR_FE{0,1}, Richard Henderson, 2021/03/15
- [PATCH v4 05/17] target/ppc: Retain hflags_nmsr only for migration, Richard Henderson, 2021/03/15
- [PATCH v4 08/17] target/ppc: Reduce env->hflags to uint32_t, Richard Henderson, 2021/03/15
- [PATCH v4 01/17] target/ppc: Move helper_regs.h functions out-of-line, Richard Henderson, 2021/03/15