]> git.sur5r.net Git - u-boot/commitdiff
Blackfin: use common memcpy routine during init
authorMike Frysinger <vapier@gentoo.org>
Sun, 1 Jun 2008 05:21:34 +0000 (01:21 -0400)
committerMike Frysinger <vapier@gentoo.org>
Wed, 28 Jan 2009 18:26:14 +0000 (13:26 -0500)
Rather than using a local custom memcpy function, just call the existing
optimized Blackfin version.

Signed-off-by: Mike Frysinger <vapier@gentoo.org>
cpu/blackfin/start.S

index 9975a0c62f575c94ffee7ddeadf4fcb24295537e..6c5fef7a5223364a26f9aa2a645bfd0bcdd666f1 100644 (file)
@@ -125,8 +125,9 @@ ENTRY(_start)
         */
        r6 = 1 (x);
 
-       /* Relocate from wherever are (FLASH/RAM/etc...) to the
-        * hardcoded monitor location in the end of RAM.
+       /* Relocate from wherever are (FLASH/RAM/etc...) to the hardcoded
+        * monitor location in the end of RAM.  We know that memcpy() only
+        * uses registers, so it is safe to call here.
         */
        serial_early_puts("Relocate");
        call _get_pc;
@@ -135,27 +136,16 @@ ENTRY(_start)
        r2.h = .Loffset;
        r3.l = _start;
        r3.h = _start;
-       r1 = r2 - r3;
-
-       r0 = r0 - r1;
-
-       cc = r0 == r3;
+       r2 = r2 - r3;
+       r1 = r0 - r2;
+       cc = r1 == r3;
        if cc jump .Lnorelocate;
-
        r6 = 0 (x);
-       p1 = r0;
-
-       p2.l = LO(CONFIG_SYS_MONITOR_BASE);
-       p2.h = HI(CONFIG_SYS_MONITOR_BASE);
-
-       p3 = 0x04;
-       p4.l = LO(CONFIG_SYS_MONITOR_BASE + CONFIG_SYS_MONITOR_LEN);
-       p4.h = HI(CONFIG_SYS_MONITOR_BASE + CONFIG_SYS_MONITOR_LEN);
-.Lloop1:
-       r1 = [p1 ++ p3];
-       [p2 ++ p3] = r1;
-       cc=p2==p4;
-       if !cc jump .Lloop1;
+
+       r0 = r3;
+       r2.l = LO(CONFIG_SYS_MONITOR_LEN);
+       r2.h = HI(CONFIG_SYS_MONITOR_LEN);
+       call _memcpy_ASM;
 
        /* Initialize BSS section ... we know that memset() does not
         * use the BSS, so it is safe to call here.  The bootrom LDR