Yikes! Turns out that FPU registers are only 32 bits wide, and doubles are
authorDavid Given <dg@cowlark.com>
Sun, 9 Sep 2018 16:25:00 +0000 (18:25 +0200)
committerDavid Given <dg@cowlark.com>
Sun, 9 Sep 2018 16:25:00 +0000 (18:25 +0200)
stored in pairs, just like on the PowerPC!

mach/mips/libem/c_ud_i.s
mach/mips/libem/c_uf_i.s
mach/mips/mcg/platform.c
mach/mips/mcg/table

index c43658b..cfb9668 100644 (file)
@@ -9,12 +9,12 @@
 .c_ud_i:
        /* Input: f0
         * Output: r2
-        * Only at and f31 may be used.
+        * Only at and f30/f31 may be used.
         */
 
        ori at, zero, hi16[.fd_80000000]
-       ldc1 f31, lo16[.fd_80000000] (at)
-       c.le.d 0, f31, f0
+       ldc1 f30, lo16[.fd_80000000] (at)
+       c.le.d 0, f30, f0
        bc1t toobig
        nop
 
@@ -24,7 +24,7 @@
        nop
 
 toobig:
-       sub.d f0, f0, f31
+       sub.d f0, f0, f30
        trunc.w.d f0, f0
        mfc1 r2, f0
        addiu r2, r2, 0x8000
index 0a4af44..f8b7f5f 100644 (file)
@@ -9,12 +9,12 @@
 .c_uf_i:
        /* Input: f0
         * Output: r2
-        * Only at and f31 may be used.
+        * Only at and f30/f31 may be used.
         */
 
        ori at, zero, hi16[.ff_80000000]
-       lwc1 f31, lo16[.ff_80000000] (at)
-       c.le.s 0, f31, f0
+       lwc1 f30, lo16[.ff_80000000] (at)
+       c.le.s 0, f30, f0
        bc1t toobig
        nop
 
@@ -24,7 +24,7 @@
        nop
 
 toobig:
-       sub.s f0, f0, f31
+       sub.s f0, f0, f30
        trunc.w.s f0, f0
        mfc1 r2, f0
        addiu r2, r2, 0x8000
index cd3a376..998b5dc 100644 (file)
@@ -320,15 +320,15 @@ struct hop* platform_swap(struct basicblock* bb, struct hreg* src, struct hreg*
             break;
 
         case burm_float_ATTR:
-            hop_add_insel(hop, "mov.s f31, %H", src);
+            hop_add_insel(hop, "mov.s f30, %H", src);
             hop_add_insel(hop, "mov.s %H, %H", src, dest);
-            hop_add_insel(hop, "mov.s %H, f31", dest);
+            hop_add_insel(hop, "mov.s %H, f30", dest);
             break;
 
         case burm_double_ATTR:
-            hop_add_insel(hop, "mov.d f31, %H", src);
+            hop_add_insel(hop, "mov.d f30, %H", src);
             hop_add_insel(hop, "mov.d %H, %H", src, dest);
-            hop_add_insel(hop, "mov.d %H, f31", dest);
+            hop_add_insel(hop, "mov.d %H, f30", dest);
             break;
     }
 
index 76ca419..5b5c1ae 100644 (file)
@@ -75,41 +75,24 @@ REGISTERS
        f27                                           float;
        f28                                           float;
        f29                                           float;
-       f30                                           float;
-    /* f31 is used by the compiler as a temporary. */
-
-       d0  named("f0")  aliases(f0)                  double volatile dret;
-       d1  named("f1")  aliases(f1)                  double volatile;
-       d2  named("f2")  aliases(f2)                  double volatile;
-       d3  named("f3")  aliases(f3)                  double volatile;
-       d4  named("f4")  aliases(f4)                  double volatile;
-       d5  named("f5")  aliases(f5)                  double volatile;
-       d6  named("f6")  aliases(f6)                  double volatile;
-       d7  named("f7")  aliases(f7)                  double volatile;
-       d8  named("f8")  aliases(f8)                  double volatile;
-       d9  named("f9")  aliases(f9)                  double volatile;
-       d10 named("f10") aliases(f10)                 double volatile;
-       d11 named("f11") aliases(f11)                 double volatile;
-       d12 named("f12") aliases(f12)                 double volatile;
-       d13 named("f13") aliases(f13)                 double volatile;
-       d14 named("f14") aliases(f14)                 double volatile;
-       d15 named("f15") aliases(f15)                 double volatile;
-       d16 named("f16") aliases(f16)                 double volatile;
-       d17 named("f17") aliases(f17)                 double volatile;
-       d18 named("f18") aliases(f18)                 double volatile;
-       d19 named("f19") aliases(f19)                 double volatile;
-
-       d20 named("f20") aliases(f20)                 double;
-       d21 named("f21") aliases(f21)                 double;
-       d22 named("f22") aliases(f22)                 double;
-       d23 named("f23") aliases(f23)                 double;
-       d24 named("f24") aliases(f24)                 double;
-       d25 named("f25") aliases(f25)                 double;
-       d26 named("f26") aliases(f26)                 double;
-       d27 named("f27") aliases(f27)                 double;
-       d28 named("f28") aliases(f28)                 double;
-       d29 named("f29") aliases(f29)                 double;
-       d30 named("f30") aliases(f30)                 double;
+    /* f30 and f31 is used by the compiler as a temporary. */
+
+       d0  named("f0")  aliases(f0, f1)              double volatile dret;
+       d2  named("f2")  aliases(f2, f3)              double volatile;
+       d4  named("f4")  aliases(f4, f5)              double volatile;
+       d6  named("f6")  aliases(f6, f7)              double volatile;
+       d8  named("f8")  aliases(f8, f9)              double volatile;
+       d10 named("f10") aliases(f10, f11)            double volatile;
+       d12 named("f12") aliases(f12, f13)            double volatile;
+       d14 named("f14") aliases(f14, f15)            double volatile;
+       d16 named("f16") aliases(f16, f17)            double volatile;
+       d18 named("f18") aliases(f18, f19)            double volatile;
+
+       d20 named("f20") aliases(f20, f21)            double;
+       d22 named("f22") aliases(f22, f23)            double;
+       d24 named("f24") aliases(f24, f25)            double;
+       d26 named("f26") aliases(f26, f27)            double;
+       d28 named("f28") aliases(f28, f29)            double;
 
 
 
@@ -425,7 +408,7 @@ PATTERNS
 
        FARJUMP(addr:LABEL.I)
         with corrupted(volatile)
-               emit "b $addr"
+               emit "j $addr"
         emit "nop"
                cost 8;
 
@@ -458,7 +441,7 @@ PATTERNS
     #define CALLLABEL(insn) \
         insn (dest:LABEL.I) \
             with corrupted(volatile) \
-            emit "bal $dest" \
+            emit "jal $dest" \
             emit "nop" \
             cost 8;
 
@@ -695,8 +678,8 @@ PATTERNS
                cost 30;
 
        out:(int)reg = FROMSD.I(in:(double)reg)
-        emit "trunc.w.d f31, %in"
-        emit "mfc1 %out, f31"
+        emit "trunc.w.d f30, %in"
+        emit "mfc1 %out, f30"
         cost 8;
 
        out:(lret)reg = FROMSD.L(in:(dret)reg)
@@ -748,8 +731,8 @@ PATTERNS
                cost 4;
 
        out:(int)reg = FROMSF.I(in:(float)reg)
-        emit "trunc.w.s f31, %in"
-        emit "mfc1 %out, f31"
+        emit "trunc.w.s f30, %in"
+        emit "mfc1 %out, f30"
         cost 8;
 
        out:(lret)reg = FROMSF.L(in:(fret)reg)