91 lines
3.3 KiB
Diff
91 lines
3.3 KiB
Diff
From 8bb294ea3f26a8ce01ad76c19a6de359dce0c113 Mon Sep 17 00:00:00 2001
|
|
From: Laurent Vivier <lvivier@redhat.com>
|
|
Date: Wed, 9 Jun 2021 05:58:35 -0400
|
|
Subject: [PATCH 09/21] spapr: Set LPCR to current AIL mode when starting a new
|
|
CPU
|
|
MIME-Version: 1.0
|
|
Content-Type: text/plain; charset=UTF-8
|
|
Content-Transfer-Encoding: 8bit
|
|
|
|
RH-Author: Miroslav Rezanina <mrezanin@redhat.com>
|
|
RH-MergeRequest: 8: Synchronize with RHEL-AV 8.5 release 19 to RHEL 9
|
|
RH-Commit: [8/8] 7a1cb27881f93c245ab9e8b8540cbd06d4f8c14f (mrezanin/centos-src-qemu-kvm)
|
|
RH-Bugzilla: 1957194
|
|
RH-Acked-by: Daniel P. Berrangé <berrange@redhat.com>
|
|
RH-Acked-by: Greg Kurz <gkurz@redhat.com>
|
|
RH-Acked-by: Laurent Vivier <lvivier@redhat.com>
|
|
RH-Acked-by: Vitaly Kuznetsov <vkuznets@redhat.com>
|
|
|
|
From: Nicholas Piggin <npiggin@gmail.com>
|
|
|
|
TCG does not keep track of AIL mode in a central place, it's based on
|
|
the current LPCR[AIL] bits. Synchronize the new CPU's LPCR to the
|
|
current LPCR in rtas_start_cpu(), similarly to the way the ILE bit is
|
|
synchronized.
|
|
|
|
Open-code the ILE setting as well now that the caller's LPCR is
|
|
available directly, there is no need for the indirection.
|
|
|
|
Without this, under both TCG and KVM, adding a POWER8/9/10 class CPU
|
|
with a new core ID after a modern Linux has booted results in the new
|
|
CPU's LPCR missing the LPCR[AIL]=0b11 setting that the other CPUs have.
|
|
This can cause crashes and unexpected behaviour.
|
|
|
|
Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
|
|
Message-Id: <20210526091626.3388262-3-npiggin@gmail.com>
|
|
Reviewed-by: Cédric Le Goater <clg@kaod.org>
|
|
Reviewed-by: Greg Kurz <groug@kaod.org>
|
|
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
|
|
Signed-off-by: Laurent Vivier <lvivier@redhat.com>
|
|
(cherry picked from commit ac559ecbea2649819e7b3fdd09f4e0243e0128db)
|
|
Signed-off-by: Danilo C. L. de Paula <ddepaula@redhat.com>
|
|
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
|
|
---
|
|
hw/ppc/spapr_rtas.c | 14 +++++++++-----
|
|
1 file changed, 9 insertions(+), 5 deletions(-)
|
|
|
|
diff --git a/hw/ppc/spapr_rtas.c b/hw/ppc/spapr_rtas.c
|
|
index 91c71d1c94..27ab339b0c 100644
|
|
--- a/hw/ppc/spapr_rtas.c
|
|
+++ b/hw/ppc/spapr_rtas.c
|
|
@@ -133,8 +133,8 @@ static void rtas_start_cpu(PowerPCCPU *callcpu, SpaprMachineState *spapr,
|
|
target_ulong id, start, r3;
|
|
PowerPCCPU *newcpu;
|
|
CPUPPCState *env;
|
|
- PowerPCCPUClass *pcc;
|
|
target_ulong lpcr;
|
|
+ target_ulong caller_lpcr;
|
|
|
|
if (nargs != 3 || nret != 1) {
|
|
rtas_st(rets, 0, RTAS_OUT_PARAM_ERROR);
|
|
@@ -153,7 +153,6 @@ static void rtas_start_cpu(PowerPCCPU *callcpu, SpaprMachineState *spapr,
|
|
}
|
|
|
|
env = &newcpu->env;
|
|
- pcc = POWERPC_CPU_GET_CLASS(newcpu);
|
|
|
|
if (!CPU(newcpu)->halted) {
|
|
rtas_st(rets, 0, RTAS_OUT_HW_ERROR);
|
|
@@ -164,10 +163,15 @@ static void rtas_start_cpu(PowerPCCPU *callcpu, SpaprMachineState *spapr,
|
|
|
|
env->msr = (1ULL << MSR_SF) | (1ULL << MSR_ME);
|
|
|
|
+ caller_lpcr = callcpu->env.spr[SPR_LPCR];
|
|
lpcr = env->spr[SPR_LPCR];
|
|
- if (!pcc->interrupts_big_endian(callcpu)) {
|
|
- lpcr |= LPCR_ILE;
|
|
- }
|
|
+
|
|
+ /* Set ILE the same way */
|
|
+ lpcr = (lpcr & ~LPCR_ILE) | (caller_lpcr & LPCR_ILE);
|
|
+
|
|
+ /* Set AIL the same way */
|
|
+ lpcr = (lpcr & ~LPCR_AIL) | (caller_lpcr & LPCR_AIL);
|
|
+
|
|
if (env->mmu_model == POWERPC_MMU_3_00) {
|
|
/*
|
|
* New cpus are expected to start in the same radix/hash mode
|
|
--
|
|
2.27.0
|
|
|