summaryrefslogtreecommitdiff
path: root/arch/powerpc/kernel/head_64.S
diff options
context:
space:
mode:
authorBenjamin Herrenschmidt <benh@kernel.crashing.org>2011-04-05 08:34:58 +0400
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>2011-04-20 05:03:25 +0400
commitdd797738643cd3c2dd9cdff7e4c3a04d318ab23a (patch)
treef8980e617597c0438da133e529656e0b5489db00 /arch/powerpc/kernel/head_64.S
parent948cf67c4726cca2fc57533dccadfb54d890689d (diff)
downloadlinux-dd797738643cd3c2dd9cdff7e4c3a04d318ab23a.tar.xz
powerpc: Perform an isync to synchronize CPUs coming out of secondary_hold
We need to do that to guarantee they see any code change done by dynamic patching during boot. Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Diffstat (limited to 'arch/powerpc/kernel/head_64.S')
-rw-r--r--arch/powerpc/kernel/head_64.S2
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/powerpc/kernel/head_64.S b/arch/powerpc/kernel/head_64.S
index 0700e1135c91..6d17c37f22a1 100644
--- a/arch/powerpc/kernel/head_64.S
+++ b/arch/powerpc/kernel/head_64.S
@@ -147,6 +147,8 @@ __secondary_hold:
mtctr r4
mr r3,r24
li r4,0
+ /* Make sure that patched code is visible */
+ isync
bctr
#else
BUG_OPCODE