i386.c (ix86_expand_fp_compare): Delay creating of scratch register until when it...
authorJan Hubicka <jh@suse.cz>
Sat, 3 Mar 2001 18:49:05 +0000 (19:49 +0100)
committerJan Hubicka <hubicka@gcc.gnu.org>
Sat, 3 Mar 2001 18:49:05 +0000 (18:49 +0000)
* i386.c (ix86_expand_fp_compare): Delay creating of scratch register
until when it is really needed.
(ix86_expand_compare): Update call of ix86_expand_fp_compare.
* i386.h (PREDICATE_CODES): Add all codes for sse_comparison_operator
* i386.md (float?i?f splitter): Don't force source operand to memory
for SSE.
(sse_movdfcc): Fix constraint.
(sse_movdfcc splitter): Handle properly the second alternative.

From-SVN: r40216

gcc/ChangeLog
gcc/config/i386/i386.c
gcc/config/i386/i386.h
gcc/config/i386/i386.md

index 1abe8fbf66f6c440c00d18219b7c2a2a82616132..7c2ddebbf5c31476bea9eaae72595a0e0fa7d577 100644 (file)
@@ -1,3 +1,14 @@
+Sat Mar  3 19:47:13 CET 2001  Jan Hubicka  <jh@suse.cz>
+
+       * i386.c (ix86_expand_fp_compare): Delay creating of scratch register
+       until when it is really needed.
+       (ix86_expand_compare): Update call of ix86_expand_fp_compare.
+       * i386.h (PREDICATE_CODES): Add all codes for sse_comparison_operator
+       * i386.md (float?i?f splitter): Don't force source operand to memory
+       for SSE.
+       (sse_movdfcc): Fix constraint.
+       (sse_movdfcc splitter): Handle properly the second alternative.
+
 2001-03-03  Neil Booth  <neil@daikokuya.demon.co.uk>
 
         * cpplex.c (parse_string): Unconditionally pedwarn.
index d287d1a0a22ced4d0ac0a0972904a1f93d112363..380f6af1ec42066317f75867e7e9eeb783587a05 100644 (file)
@@ -5196,6 +5196,8 @@ ix86_expand_fp_compare (code, op0, op1, scratch, second_test, bypass_test)
        {
          tmp = gen_rtx_COMPARE (fpcmp_mode, op0, op1);
          tmp2 = gen_rtx_UNSPEC (HImode, gen_rtvec (1, tmp), 9);
+         if (!scratch)
+           scratch = gen_reg_rtx (HImode);
          emit_insn (gen_rtx_SET (VOIDmode, scratch, tmp2));
          emit_insn (gen_x86_sahf_1 (scratch));
        }
@@ -5217,6 +5219,8 @@ ix86_expand_fp_compare (code, op0, op1, scratch, second_test, bypass_test)
       /* Sadness wrt reg-stack pops killing fpsr -- gotta get fnstsw first.  */
       tmp = gen_rtx_COMPARE (fpcmp_mode, op0, op1);
       tmp2 = gen_rtx_UNSPEC (HImode, gen_rtvec (1, tmp), 9);
+      if (!scratch)
+       scratch = gen_reg_rtx (HImode);
       emit_insn (gen_rtx_SET (VOIDmode, scratch, tmp2));
 
       /* In the unordered case, we have to check C2 for NaN's, which
@@ -5357,7 +5361,7 @@ ix86_expand_compare (code, second_test, bypass_test)
     *bypass_test = NULL_RTX;
 
   if (GET_MODE_CLASS (GET_MODE (op0)) == MODE_FLOAT)
-    ret = ix86_expand_fp_compare (code, op0, op1, gen_reg_rtx (HImode),
+    ret = ix86_expand_fp_compare (code, op0, op1, NULL_RTX,
                                  second_test, bypass_test);
   else
     ret = ix86_expand_int_compare (code, op0, op1);
index b7a74af809ee4617e8acc7d478a8dd0f6b3d0049..31c7a8e2ff6e8bee0a57bd1c38c3f3726260b9b3 100644 (file)
@@ -2869,7 +2869,9 @@ do { long l;                                              \
   {"fcmov_comparison_operator", {EQ, NE, LTU, GTU, LEU, GEU, UNORDERED, \
                                 ORDERED, LT, UNLT, GT, UNGT, LE, UNLE, \
                                 GE, UNGE, LTGT, UNEQ}},                \
-  {"sse_comparison_operator", {EQ, LT, LE, UNORDERED }},               \
+  {"sse_comparison_operator", {EQ, LT, LE, UNORDERED, NE, UNGE, UNGT,  \
+                              ORDERED, UNEQ, UNLT, UNLE, LTGT, GE, GT  \
+                              }},                                      \
   {"ix86_comparison_operator", {EQ, NE, LE, LT, GE, GT, LEU, LTU, GEU, \
                               GTU, UNORDERED, ORDERED, UNLE, UNLT,     \
                               UNGE, UNGT, LTGT, UNEQ }},               \
index 51e0e70ce76c204d1083f05a91c44fb63ad8fac1..fc341af8d33ec4b0c24bb22f8cbee375c6eb668f 100644 (file)
 (define_split
   [(set (match_operand 0 "register_operand" "")
        (float (match_operand 1 "register_operand" "")))]
-  "reload_completed && FLOAT_MODE_P (GET_MODE (operands[0]))"
+  "reload_completed && FLOAT_MODE_P (GET_MODE (operands[0]))
+   && FP_REG_P (operands[0])"
   [(const_int 0)]
   "
 {
                         (match_operand:SF 5 "nonimmediate_operand" "xm#f,xm#f,f#x,f#x,x#f,x#f,f#x,f#x,x#f,x#f")])
                      (match_operand:SF 2 "nonimmediate_operand" "x#fr,0#fr,f#fx,0#fx,f#fx,0#fx,rm#rx,0#rx,rm#rx,0#rx")
                      (match_operand:SF 3 "nonimmediate_operand" "x#fr,x#fr,0#fx,f#fx,0#fx,f#fx,0#fx,rm#rx,0#rx,rm#rx")))
-   (clobber (match_scratch:SF 6 "=2,&5,X,X,X,X,X,X,X,X"))
+   (clobber (match_scratch:SF 6 "=2,&4,X,X,X,X,X,X,X,X"))
    (clobber (reg:CC 17))]
   "TARGET_SSE
    && (GET_CODE (operands[2]) != MEM || GET_CODE (operands[3]) != MEM)"
                         (match_operand:DF 5 "nonimmediate_operand" "xm#f,xm#f,f#x,f#x,x#f,x#f,f#x,f#x,x#f,x#f")])
                      (match_operand:DF 2 "nonimmediate_operand" "x#fr,0#fr,f#fx,0#fx,f#fx,0#fx,rm#rx,0#rx,rm#rx,0#rx")
                      (match_operand:DF 3 "nonimmediate_operand" "x#fr,x#fr,0#fx,f#fx,0#fx,f#fx,0#fx,rm#rx,0#rx,rm#rx")))
-   (clobber (match_scratch:DF 6 "=2,&5,X,X,X,X,X,X,X,X"))
+   (clobber (match_scratch:DF 6 "=2,&4,X,X,X,X,X,X,X,X"))
    (clobber (reg:CC 17))]
   "TARGET_SSE2
    && (GET_CODE (operands[2]) != MEM || GET_CODE (operands[3]) != MEM)"
                         (match_operand 5 "nonimmediate_operand" "")])
                      (match_operand 2 "register_operand" "")
                      (match_operand 3 "register_operand" "")))
-   (clobber (match_dup 2))
+   (clobber (match_operand 6 "" ""))
    (clobber (reg:CC 17))]
   "SSE_REG_P (operands[0]) && reload_completed"
   [(set (match_dup 4) (match_op_dup 1 [(match_dup 4) (match_dup 5)]))