From: Catalin Marinas Date: Mon, 7 Nov 2011 17:05:53 +0000 (+0100) Subject: ARM: 7150/1: Allow kernel unaligned accesses on ARMv6+ processors X-Git-Tag: v3.0.11~47 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=a633bc89bb5626c6d700c3fc5c3bee01da79ce47;p=profile%2Fivi%2Fkernel-adaptation-intel-automotive.git ARM: 7150/1: Allow kernel unaligned accesses on ARMv6+ processors commit 8428e84d42179c2a00f5f6450866e70d802d1d05 upstream. Recent gcc versions generate unaligned accesses by default on ARMv6 and later processors. This patch ensures that the SCTLR.A bit is always cleared on such processors to avoid kernel traping before alignment_init() is called. Signed-off-by: Catalin Marinas Tested-by: John Linn Acked-by: Nicolas Pitre Signed-off-by: Russell King Signed-off-by: Greg Kroah-Hartman --- diff --git a/arch/arm/kernel/head.S b/arch/arm/kernel/head.S index 278c1b0..673151c 100644 --- a/arch/arm/kernel/head.S +++ b/arch/arm/kernel/head.S @@ -348,7 +348,7 @@ __secondary_data: * r13 = *virtual* address to jump to upon completion */ __enable_mmu: -#ifdef CONFIG_ALIGNMENT_TRAP +#if defined(CONFIG_ALIGNMENT_TRAP) && __LINUX_ARM_ARCH__ < 6 orr r0, r0, #CR_A #else bic r0, r0, #CR_A