Commit 743cdb7b authored by Paul Mackerras's avatar Paul Mackerras Committed by Michael Ellerman

powerpc/kasan: Mark more real-mode code as not to be instrumented

This marks more files and functions that can possibly be called in
real mode as not to be instrumented by KASAN.  Most were found by
inspection, except for get_pseries_errorlog() which was reported as
causing a crash in testing.
Reported-by: default avatarNageswara R Sastry <rnsastry@linux.ibm.com>
Signed-off-by: default avatarPaul Mackerras <paulus@ozlabs.org>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/YoX1kZPnmUX4RZEK@cleo
parent 6112bd00
...@@ -37,6 +37,8 @@ KASAN_SANITIZE_paca.o := n ...@@ -37,6 +37,8 @@ KASAN_SANITIZE_paca.o := n
KASAN_SANITIZE_setup_64.o := n KASAN_SANITIZE_setup_64.o := n
KASAN_SANITIZE_mce.o := n KASAN_SANITIZE_mce.o := n
KASAN_SANITIZE_mce_power.o := n KASAN_SANITIZE_mce_power.o := n
KASAN_SANITIZE_udbg.o := n
KASAN_SANITIZE_udbg_16550.o := n
# we have to be particularly careful in ppc64 to exclude code that # we have to be particularly careful in ppc64 to exclude code that
# runs with translations off, as we cannot access the shadow with # runs with translations off, as we cannot access the shadow with
......
...@@ -993,7 +993,7 @@ int rtas_call_reentrant(int token, int nargs, int nret, int *outputs, ...) ...@@ -993,7 +993,7 @@ int rtas_call_reentrant(int token, int nargs, int nret, int *outputs, ...)
* *
* Return: A pointer to the specified errorlog or NULL if not found. * Return: A pointer to the specified errorlog or NULL if not found.
*/ */
struct pseries_errorlog *get_pseries_errorlog(struct rtas_error_log *log, noinstr struct pseries_errorlog *get_pseries_errorlog(struct rtas_error_log *log,
uint16_t section_id) uint16_t section_id)
{ {
struct rtas_ext_event_log_v6 *ext_log = struct rtas_ext_event_log_v6 *ext_log =
......
...@@ -224,7 +224,7 @@ void crash_kexec_secondary(struct pt_regs *regs) ...@@ -224,7 +224,7 @@ void crash_kexec_secondary(struct pt_regs *regs)
/* wait for all the CPUs to hit real mode but timeout if they don't come in */ /* wait for all the CPUs to hit real mode but timeout if they don't come in */
#if defined(CONFIG_SMP) && defined(CONFIG_PPC64) #if defined(CONFIG_SMP) && defined(CONFIG_PPC64)
static void __maybe_unused crash_kexec_wait_realmode(int cpu) noinstr static void __maybe_unused crash_kexec_wait_realmode(int cpu)
{ {
unsigned int msecs; unsigned int msecs;
int i; int i;
......
...@@ -4,6 +4,7 @@ ...@@ -4,6 +4,7 @@
# in particular, idle code runs a bunch of things in real mode # in particular, idle code runs a bunch of things in real mode
KASAN_SANITIZE_idle.o := n KASAN_SANITIZE_idle.o := n
KASAN_SANITIZE_pci-ioda.o := n KASAN_SANITIZE_pci-ioda.o := n
KASAN_SANITIZE_pci-ioda-tce.o := n
# pnv_machine_check_early # pnv_machine_check_early
KASAN_SANITIZE_setup.o := n KASAN_SANITIZE_setup.o := n
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment