diff options
author | Rob Herring <robh@kernel.org> | 2014-04-16 15:38:26 +0100 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2014-05-25 23:46:51 +0100 |
commit | 1dc5455f6f0b2422b410cc913e8af32a617ba921 (patch) | |
tree | 8d12dcbffddcecd66b5c785ecee46a535e66f514 | |
parent | 07b403415884e961920f55e6db462dff15d9df5a (diff) | |
download | linux-1dc5455f6f0b2422b410cc913e8af32a617ba921.tar.gz linux-1dc5455f6f0b2422b410cc913e8af32a617ba921.tar.bz2 linux-1dc5455f6f0b2422b410cc913e8af32a617ba921.zip |
ARM: 8028/1: move __fixup_smp out of init section
With large kernel builds such as allyesconfig exceeding maximum relative
branch offsets, the init section will be too far away to branch to
directly. This causes veneers to be added by the linker, but veneers
don't work before the MMU is enabled. Fix this by moving __fixup_smp to
the .head.text section as it is not very big.
Signed-off-by: Rob Herring <robh@kernel.org>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
-rw-r--r-- | arch/arm/kernel/head.S | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/arm/kernel/head.S b/arch/arm/kernel/head.S index f8c08839edf3..73dbee3097e4 100644 --- a/arch/arm/kernel/head.S +++ b/arch/arm/kernel/head.S @@ -475,7 +475,7 @@ ENDPROC(__turn_mmu_on) #ifdef CONFIG_SMP_ON_UP - __INIT + __HEAD __fixup_smp: and r3, r9, #0x000f0000 @ architecture version teq r3, #0x000f0000 @ CPU ID supported? |