The value in CIABR persists across kexec which can lead to unintended results when the new kernel hits the old kernel's breakpoint. For example: 0:mon> bi $loadavg_proc_show 0:mon> b type address 1 inst c000000000519060 loadavg_proc_show+0x0/0x130 0:mon> x $ kexec -l /mnt/vmlinux --initrd=/mnt/rootfs.cpio.gz --append='xmon=off' $ kexec -e $ cat /proc/loadavg Trace/breakpoint trap Make sure CIABR is cleared so this does not happen. Signed-off-by: Jordan Niethe <jniethe5@gmail.com> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au> Link: https://lore.kernel.org/r/20201207010519.15597-1-jniethe5@gmail.com
29 lines
557 B
C
29 lines
557 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
#ifndef _ASM_POWERPC_BOOK3S_64_KEXEC_H_
|
|
#define _ASM_POWERPC_BOOK3S_64_KEXEC_H_
|
|
|
|
#include <asm/plpar_wrappers.h>
|
|
|
|
#define reset_sprs reset_sprs
|
|
static inline void reset_sprs(void)
|
|
{
|
|
if (cpu_has_feature(CPU_FTR_ARCH_206)) {
|
|
mtspr(SPRN_AMR, 0);
|
|
mtspr(SPRN_UAMOR, 0);
|
|
}
|
|
|
|
if (cpu_has_feature(CPU_FTR_ARCH_207S)) {
|
|
mtspr(SPRN_IAMR, 0);
|
|
if (cpu_has_feature(CPU_FTR_HVMODE))
|
|
mtspr(SPRN_CIABR, 0);
|
|
else
|
|
plpar_set_ciabr(0);
|
|
}
|
|
|
|
/* Do we need isync()? We are going via a kexec reset */
|
|
isync();
|
|
}
|
|
|
|
#endif
|