powerpc/xive: Clear XIVE internal structures when a CPU is removed
Commiteac1e731b5
("powerpc/xive: guest exploitation of the XIVE interrupt controller") introduced support for the XIVE exploitation mode of the P9 interrupt controller on the pseries platform. At that time, support for CPU removal was not complete on PowerVM and CPU hot unplug remained untested. It appears that some cleanups of the XIVE internal structures are required before releasing the CPU, without which the kernel crashes in a RTAS call doing the CPU isolation. These changes fix the crash by deconfiguring the IPI interrupt source and clearing the event queues of the CPU when it is removed. Fixes:eac1e731b5
("powerpc/xive: guest exploitation of the XIVE interrupt controller") Signed-off-by: Cédric Le Goater <clg@kaod.org> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
This commit is contained in:
parent
74f1282114
commit
cc56939802
|
@ -1402,6 +1402,14 @@ void xive_teardown_cpu(void)
|
||||||
|
|
||||||
if (xive_ops->teardown_cpu)
|
if (xive_ops->teardown_cpu)
|
||||||
xive_ops->teardown_cpu(cpu, xc);
|
xive_ops->teardown_cpu(cpu, xc);
|
||||||
|
|
||||||
|
#ifdef CONFIG_SMP
|
||||||
|
/* Get rid of IPI */
|
||||||
|
xive_cleanup_cpu_ipi(cpu, xc);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Disable and free the queues */
|
||||||
|
xive_cleanup_cpu_queues(cpu, xc);
|
||||||
}
|
}
|
||||||
|
|
||||||
void xive_kexec_teardown_cpu(int secondary)
|
void xive_kexec_teardown_cpu(int secondary)
|
||||||
|
|
Loading…
Reference in New Issue