]> git.kernelconcepts.de Git - karo-tx-uboot.git/commitdiff
MPC512x: workaround data corruption for unaligned local bus accesses
authorWolfgang Denk <wd@denx.de>
Mon, 28 Jun 2010 23:33:35 +0000 (01:33 +0200)
committerWolfgang Denk <wd@denx.de>
Tue, 29 Jun 2010 12:41:37 +0000 (14:41 +0200)
Commit 460c2ce3 "MPC5200: workaround data corruption for unaligned
local bus accesses" fixed the problem for MPC5200 only, but MPC512x is
affected as well, so apply the same fix here, too.

Signed-off-by: Wolfgang Denk <wd@denx.de>
Cc: Detlev Zundel <dzu@denx.de>
Cc: Anatolij Gustschin <agust@denx.de>
Acked-by: Detlev Zundel <dzu@denx.de>
arch/powerpc/cpu/mpc5xxx/Makefile
arch/powerpc/lib/Makefile
arch/powerpc/lib/memcpy_mpc5200.c [moved from arch/powerpc/cpu/mpc5xxx/memcpy_mpc5200.c with 100% similarity]

index 4ab2b7be765abbc0a2100416fa2299ab7cd5e67c..0ee0611550b0c0db43c708ede83e308238a7adfc 100644 (file)
@@ -30,11 +30,6 @@ SOBJS        = io.o firmware_sc_task_bestcomm.impl.o
 COBJS  = i2c.o traps.o cpu.o cpu_init.o ide.o interrupts.o \
          loadtask.o pci_mpc5200.o serial.o speed.o usb_ohci.o usb.o
 
-# Workaround for local bus unaligned access problem on MPC5200
-#ifdef CONFIG_MPC5200
-COBJS  += memcpy_mpc5200.o
-#endif
-
 SRCS   := $(START:.o=.S) $(SOBJS:.o=.S) $(COBJS:.o=.c)
 OBJS   := $(addprefix $(obj),$(SOBJS) $(COBJS))
 START  := $(addprefix $(obj),$(START))
index bf23790c42733fdefdb2bf98f98dd42388d5f918..2065b6d807fc782c10a37c6d5762ef8b3544ca2c 100644 (file)
@@ -40,14 +40,22 @@ COBJS-y     += interrupts.o
 COBJS-$(CONFIG_CMD_KGDB) += kgdb.o
 COBJS-y        += time.o
 
-SRCS   := $(SOBJS-y:.o=.S) $(COBJS-y:.o=.c)
-OBJS   := $(addprefix $(obj),$(SOBJS-y) $(COBJS-y))
-
-# Workaround for local bus unaligned access problem on MPC5200
+# Workaround for local bus unaligned access problems
+# on MPC512x and MPC5200
+ifdef CONFIG_MPC512X
+$(obj)ppcstring.o: AFLAGS += -Dmemcpy=__memcpy
+COBJS-y += memcpy_mpc5200.o
+endif
 ifdef CONFIG_MPC5200
 $(obj)ppcstring.o: AFLAGS += -Dmemcpy=__memcpy
+COBJS-y += memcpy_mpc5200.o
 endif
 
+COBJS  += $(sort $(COBJS-y))
+
+SRCS   := $(SOBJS-y:.o=.S) $(COBJS-y:.o=.c)
+OBJS   := $(addprefix $(obj),$(SOBJS-y) $(COBJS-y))
+
 $(LIB):        $(obj).depend $(OBJS)
        @if ! $(CROSS_COMPILE)readelf -S $(OBJS) | grep -q '\.fixup.*PROGBITS';\
        then \