mirror of
https://github.com/xemu-project/xemu.git
synced 2025-02-22 05:24:14 +00:00
target/ppc: Fix POWER9 radix guest HV interrupt AIL behaviour
ISA v3.0 radix guest execution has a quirk in AIL behaviour such that the LPCR[AIL] value can apply to hypervisor interrupts. This affects machines that emulate HV=1 mode (i.e., powernv9). Signed-off-by: Nicholas Piggin <npiggin@gmail.com> Message-Id: <20210415054227.1793812-2-npiggin@gmail.com> Reviewed-by: Fabiano Rosas <farosas@linux.ibm.com> Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
This commit is contained in:
parent
37337472e7
commit
9827f20863
@ -791,14 +791,23 @@ static inline void powerpc_excp(PowerPCCPU *cpu, int excp_model, int excp)
|
||||
#endif
|
||||
|
||||
/*
|
||||
* AIL only works if there is no HV transition and we are running
|
||||
* with translations enabled
|
||||
* AIL only works if MSR[IR] and MSR[DR] are both enabled.
|
||||
*/
|
||||
if (!((msr >> MSR_IR) & 1) || !((msr >> MSR_DR) & 1) ||
|
||||
((new_msr & MSR_HVB) && !(msr & MSR_HVB))) {
|
||||
if (!((msr >> MSR_IR) & 1) || !((msr >> MSR_DR) & 1)) {
|
||||
ail = 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* AIL does not work if there is a MSR[HV] 0->1 transition and the
|
||||
* partition is in HPT mode. For radix guests, such interrupts are
|
||||
* allowed to be delivered to the hypervisor in ail mode.
|
||||
*/
|
||||
if ((new_msr & MSR_HVB) && !(msr & MSR_HVB)) {
|
||||
if (!(env->spr[SPR_LPCR] & LPCR_HR)) {
|
||||
ail = 0;
|
||||
}
|
||||
}
|
||||
|
||||
vector = env->excp_vectors[excp];
|
||||
if (vector == (target_ulong)-1ULL) {
|
||||
cpu_abort(cs, "Raised an exception without defined vector %d\n",
|
||||
|
Loading…
x
Reference in New Issue
Block a user