]> gcc.gnu.org Git - gcc.git/commitdiff
* longlong.h (umul_ppmm): Add ColdFire support.
authorPeter Barada <peter@baradas.org>
Thu, 21 Aug 2003 01:11:42 +0000 (01:11 +0000)
committerBernardo Innocenti <bernie@gcc.gnu.org>
Thu, 21 Aug 2003 01:11:42 +0000 (03:11 +0200)
From-SVN: r70631

gcc/ChangeLog
gcc/longlong.h

index 30394f9e0857306fd006d64522dbd363b61b7a55..b59d8bada8b738afc06b1ff952c5971e405299ca 100644 (file)
@@ -1,3 +1,7 @@
+2003-08-06  Peter Barada <peter@baradas.org>
+
+       * longlong.h (umul_ppmm): Add ColdFire support.
+
 2003-08-06  Peter Barada <peter@baradas.org>
             Bernardo Innocenti  <bernie@develer.com>
 
index ebf3591151acee714c0e54554aa7649193287d5a..2fb68e7c373ee3728a33cb28ace3eac43828650a 100644 (file)
@@ -443,7 +443,42 @@ UDItype __umulsidi3 (USItype, USItype);
             "dmi" ((USItype) (d)))
 
 #else /* not mc68020 */
-#if !defined(__mcf5200__)
+#if defined(__mcoldfire__)
+#define umul_ppmm(xh, xl, a, b) \
+  __asm__ ("| Inlined umul_ppmm\n"                                     \
+          "    move%.l %2,%/d0\n"                                      \
+          "    move%.l %3,%/d1\n"                                      \
+          "    move%.l %/d0,%/d2\n"                                    \
+          "    swap    %/d0\n"                                         \
+          "    move%.l %/d1,%/d3\n"                                    \
+          "    swap    %/d1\n"                                         \
+          "    move%.w %/d2,%/d4\n"                                    \
+          "    mulu    %/d3,%/d4\n"                                    \
+          "    mulu    %/d1,%/d2\n"                                    \
+          "    mulu    %/d0,%/d3\n"                                    \
+          "    mulu    %/d0,%/d1\n"                                    \
+          "    move%.l %/d4,%/d0\n"                                    \
+          "    clr%.w  %/d0\n"                                         \
+          "    swap    %/d0\n"                                         \
+          "    add%.l  %/d0,%/d2\n"                                    \
+          "    add%.l  %/d3,%/d2\n"                                    \
+          "    jcc     1f\n"                                           \
+          "    add%.l  %#65536,%/d1\n"                                 \
+          "1:  swap    %/d2\n"                                         \
+          "    moveq   %#0,%/d0\n"                                     \
+          "    move%.w %/d2,%/d0\n"                                    \
+          "    move%.w %/d4,%/d2\n"                                    \
+          "    move%.l %/d2,%1\n"                                      \
+          "    add%.l  %/d1,%/d0\n"                                    \
+          "    move%.l %/d0,%0"                                        \
+          : "=g" ((USItype) (xh)),                                     \
+            "=g" ((USItype) (xl))                                      \
+          : "g" ((USItype) (a)),                                       \
+            "g" ((USItype) (b))                                        \
+          : "d0", "d1", "d2", "d3", "d4")
+#define UMUL_TIME 100
+#define UDIV_TIME 400
+#else /* not ColdFire */
 /* %/ inserts REGISTER_PREFIX, %# inserts IMMEDIATE_PREFIX.  */
 #define umul_ppmm(xh, xl, a, b) \
   __asm__ ("| Inlined umul_ppmm\n"                                     \
@@ -479,7 +514,7 @@ UDItype __umulsidi3 (USItype, USItype);
           : "d0", "d1", "d2", "d3", "d4")
 #define UMUL_TIME 100
 #define UDIV_TIME 400
-#endif /* not mcf5200 */
+#endif /* not ColdFire */
 #endif /* not mc68020 */
 
 /* The '020, '030, '040 and '060 have bitfield insns.
This page took 0.072004 seconds and 5 git commands to generate.