90 lines
3.2 KiB
Diff
90 lines
3.2 KiB
Diff
From 28794dca79a94d01c8732b84fe6ac6ba2986ce45 Mon Sep 17 00:00:00 2001
|
|
From: Laurent Vivier <lvivier@redhat.com>
|
|
Date: Wed, 9 Jun 2021 10:05:01 -0400
|
|
Subject: [PATCH 4/4] 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: Laurent Vivier <lvivier@redhat.com>
|
|
Message-id: <20210609100501.427096-3-lvivier@redhat.com>
|
|
Patchwork-id: 101683
|
|
O-Subject: [RHEL-8.5.0 qemu-kvm PATCH 2/2] spapr: Set LPCR to current AIL mode when starting a new CPU
|
|
Bugzilla: 1969768
|
|
RH-Acked-by: Stefano Garzarella <sgarzare@redhat.com>
|
|
RH-Acked-by: David Gibson <dgibson@redhat.com>
|
|
RH-Acked-by: Greg Kurz <gkurz@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>
|
|
(cherry picked from commit ac559ecbea2649819e7b3fdd09f4e0243e0128db)
|
|
Signed-off-by: Laurent Vivier <lvivier@redhat.com>
|
|
Signed-off-by: Danilo C. L. de Paula <ddepaula@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 295eac986e..5acb7c1f10 100644
|
|
--- a/hw/ppc/spapr_rtas.c
|
|
+++ b/hw/ppc/spapr_rtas.c
|
|
@@ -132,8 +132,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);
|
|
@@ -152,7 +152,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);
|
|
@@ -163,10 +162,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
|
|
|