ARM: mvebu: fix big endian booting after coherency code rework
authorThomas Petazzoni <thomas.petazzoni@free-electrons.com>
Thu, 22 May 2014 12:47:59 +0000 (14:47 +0200)
committerJason Cooper <jason@lakedaemon.net>
Thu, 22 May 2014 14:25:57 +0000 (14:25 +0000)
As part of the introduction of the cpuidle support for Armada XP, the
coherency code was significantly reworked, especially in the
coherency_ll.S file. However, when the ll_get_cpuid function was
created, the big-endian specific code that switches the endianess of
the register was not updated properly.

This patch fixes this code, and therefore makes big endian systems
bootable again.

Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
Link: https://lkml.kernel.org/r/1400762882-10116-2-git-send-email-thomas.petazzoni@free-electrons.com
Fixes: 2e8a5942f875 ("ARM: mvebu: Split low level functions to manipulate HW coherency")
Reported-by: Kevin Hilman <khilman@linaro.org>
Cc: Kevin Hilman <khilman@linaro.org>
Acked-by: Gregory CLEMENT <gregory.clement@free-electrons.com>
Signed-off-by: Jason Cooper <jason@lakedaemon.net>
arch/arm/mach-mvebu/coherency_ll.S

index 6828f9f157b0b36d02abb6daab4843c143d2bf4d..a5e62c62819ad787cff38949f1604767f9a598da 100644 (file)
@@ -49,7 +49,7 @@ ENTRY(ll_get_cpuid)
        and     r3, r3, #15
        mov     r2, #(1 << 24)
        lsl     r3, r2, r3
-ARM_BE8(rev    r1, r1)
+ARM_BE8(rev    r3, r3)
        mov     pc, lr
 ENDPROC(ll_get_cpuid)