Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 26602161 authored by Russell King's avatar Russell King
Browse files

ARM: bugs: hook processor bug checking into SMP and suspend paths



Check for CPU bugs when secondary processors are being brought online,
and also when CPUs are resuming from a low power mode.  This gives an
opportunity to check that processor specific bug workarounds are
correctly enabled for all paths that a CPU re-enters the kernel.

Signed-off-by: default avatarRussell King <rmk+kernel@armlinux.org.uk>
Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Boot-tested-by: default avatarTony Lindgren <tony@atomide.com>
Reviewed-by: default avatarTony Lindgren <tony@atomide.com>
Acked-by: default avatarMarc Zyngier <marc.zyngier@arm.com>
parent a5b9177f
Loading
Loading
Loading
Loading
+2 −0
Original line number Diff line number Diff line
@@ -14,8 +14,10 @@ extern void check_writebuffer_bugs(void);

#ifdef CONFIG_MMU
extern void check_bugs(void);
extern void check_other_bugs(void);
#else
#define check_bugs() do { } while (0)
#define check_other_bugs() do { } while (0)
#endif

#endif
+5 −0
Original line number Diff line number Diff line
@@ -3,7 +3,12 @@
#include <asm/bugs.h>
#include <asm/proc-fns.h>

void check_other_bugs(void)
{
}

void __init check_bugs(void)
{
	check_writebuffer_bugs();
	check_other_bugs();
}
+4 −0
Original line number Diff line number Diff line
@@ -31,6 +31,7 @@
#include <linux/irq_work.h>

#include <linux/atomic.h>
#include <asm/bugs.h>
#include <asm/smp.h>
#include <asm/cacheflush.h>
#include <asm/cpu.h>
@@ -405,6 +406,9 @@ asmlinkage void secondary_start_kernel(void)
	 * before we continue - which happens after __cpu_up returns.
	 */
	set_cpu_online(cpu, true);

	check_other_bugs();

	complete(&cpu_running);

	local_irq_enable();
+2 −0
Original line number Diff line number Diff line
@@ -3,6 +3,7 @@
#include <linux/slab.h>
#include <linux/mm_types.h>

#include <asm/bugs.h>
#include <asm/cacheflush.h>
#include <asm/idmap.h>
#include <asm/pgalloc.h>
@@ -36,6 +37,7 @@ int cpu_suspend(unsigned long arg, int (*fn)(unsigned long))
		cpu_switch_mm(mm->pgd, mm);
		local_flush_bp_all();
		local_flush_tlb_all();
		check_other_bugs();
	}

	return ret;