Fix DIV, DIV1 (wrong check for overflow) and DIVU1 (shouldn't check
authorAndrew Cagney <cagney@redhat.com>
Tue, 3 Mar 1998 05:39:49 +0000 (05:39 +0000)
committerAndrew Cagney <cagney@redhat.com>
Tue, 3 Mar 1998 05:39:49 +0000 (05:39 +0000)
for overflow).
Pacify GCC.

sim/mips/ChangeLog
sim/mips/mips.igen
sim/mips/sim-main.h

index 9b2a8e54cfad7564b6de0cc3d731291e8bc918b5..2044b4149c1df11bf3f370d2b8a30495fd04994a 100644 (file)
@@ -1,3 +1,23 @@
+Tue Mar  3 13:58:43 1998  Andrew Cagney  <cagney@b1.cygnus.com>
+
+       * sim-main.h (GETFCC): Return an unsigned value.
+
+start-sanitize-r5900
+       * r5900.igen: Use an unsigned array index variable `i'.
+       (QFSRV): Ditto for variable bytes.
+       
+end-sanitize-r5900
+Tue Mar  3 13:21:37 1998  Andrew Cagney  <cagney@b1.cygnus.com>
+
+       * mips.igen (DIV): Fix check for -1 / MIN_INT.
+       (DADD): Result destination is RD not RT.
+
+start-sanitize-r5900
+       * r5900.igen (DIV1): Fix check for -1 / MIN_INT.
+       (DIVU1): Don't check for MIN_INT / -1 as performing unsigned
+       divide.
+
+end-sanitize-r5900
 Fri Feb 27 13:49:49 1998  Andrew Cagney  <cagney@b1.cygnus.com>
 
        * sim-main.h (HIACCESS, LOACCESS): Always define.
index 839ae7a12e207458acc4e9ddb2645b2bd8bc2c48..64a7c73eb9c434e5a427374868ec50a9f4734751 100644 (file)
@@ -1,3 +1,5 @@
+// -*- C -*-
+//
 //    <insn> ::=
 //        <insn-word> { "+" <insn-word> }
 //        ":" <format-name>
 *tx19:
 // end-sanitize-tx19
 {
+  /* this check's for overflow */
   ALU64_BEGIN (GPR[RS]);
   ALU64_ADD (GPR[RT]);
-  ALU64_END (GPR[RT]);
+  ALU64_END (GPR[RD]);
 }
 
 
        LO = EXTEND32 (0x80000000);
        HI = EXTEND32 (0);
       }
-    else if (d == -1 && d == 0x80000000)
+    else if (n == SIGNED32 (0x80000000) && d == -1)
       {
        LO = EXTEND32 (0x80000000);
        HI = EXTEND32 (0);
index f9a927828f6c552b7e37cc6e0dee8aa39590793f..697d14574727287e7a35ac32e2eab4c871720935 100644 (file)
@@ -126,7 +126,7 @@ convert (SD, CPU, cia, rm, op, from, to)
   int bit = ((cc == 0) ? 23 : (24 + (cc)));\
   FCSR = ((FCSR & ~(1 << bit)) | ((v) << bit));\
 }
-#define GETFCC(cc) (((((cc) == 0) ? (FCSR & (1 << 23)) : (FCSR & (1 << (24 + (cc))))) != 0) ? 1 : 0)
+#define GETFCC(cc) (((((cc) == 0) ? (FCSR & (1 << 23)) : (FCSR & (1 << (24 + (cc))))) != 0) ? 1U : 0)
 
 /* This should be the COC1 value at the start of the preceding
    instruction: */