i386-protos.h (ix86_expand_sse_movcc): New.
authorIlya Enkovich <enkovich.gnu@gmail.com>
Tue, 10 Nov 2015 12:15:42 +0000 (12:15 +0000)
committerIlya Enkovich <ienkovich@gcc.gnu.org>
Tue, 10 Nov 2015 12:15:42 +0000 (12:15 +0000)
gcc/

2015-11-10  Ilya Enkovich  <enkovich.gnu@gmail.com>

* config/i386/i386-protos.h (ix86_expand_sse_movcc): New.
* config/i386/i386.c (ix86_expand_sse_movcc): Make public.
Cast mask to FP mode if required.
* config/i386/sse.md (vcond_mask_<mode><avx512fmaskmodelower>): New.
(vcond_mask_<mode><avx512fmaskmodelower>): New.
(vcond_mask_<mode><sseintvecmodelower>): New.
(vcond_mask_<mode><sseintvecmodelower>): New.
(vcond_mask_v2div2di): New.
(vcond_mask_<mode><sseintvecmodelower>): New.
(vcond_mask_<mode><sseintvecmodelower>): New.

From-SVN: r230102

gcc/ChangeLog
gcc/config/i386/i386-protos.h
gcc/config/i386/i386.c
gcc/config/i386/sse.md

index 7b740a79430072613c4160ea16081590db130884..ade9a3b5832cd19cdd948d8e580ed1b7098c6906 100644 (file)
@@ -1,3 +1,16 @@
+2015-11-10  Ilya Enkovich  <enkovich.gnu@gmail.com>
+
+       * config/i386/i386-protos.h (ix86_expand_sse_movcc): New.
+       * config/i386/i386.c (ix86_expand_sse_movcc): Make public.
+       Cast mask to FP mode if required.
+       * config/i386/sse.md (vcond_mask_<mode><avx512fmaskmodelower>): New.
+       (vcond_mask_<mode><avx512fmaskmodelower>): New.
+       (vcond_mask_<mode><sseintvecmodelower>): New.
+       (vcond_mask_<mode><sseintvecmodelower>): New.
+       (vcond_mask_v2div2di): New.
+       (vcond_mask_<mode><sseintvecmodelower>): New.
+       (vcond_mask_<mode><sseintvecmodelower>): New.
+
 2015-11-10  Ilya Enkovich  <enkovich.gnu@gmail.com>
 
        * optabs-query.h (get_vcond_mask_icode): New.
index 9e20714099d8b1ef9cb4b1115894438e7b732d35..bd084dc9714204b7749d443dd5c125a77dc4bea0 100644 (file)
@@ -132,6 +132,7 @@ extern bool ix86_expand_vec_perm_const (rtx[]);
 extern bool ix86_expand_mask_vec_cmp (rtx[]);
 extern bool ix86_expand_int_vec_cmp (rtx[]);
 extern bool ix86_expand_fp_vec_cmp (rtx[]);
+extern void ix86_expand_sse_movcc (rtx, rtx, rtx, rtx);
 extern void ix86_expand_sse_unpack (rtx, rtx, bool, bool);
 extern bool ix86_expand_int_addcc (rtx[]);
 extern rtx ix86_expand_call (rtx, rtx, rtx, rtx, rtx, bool);
index f6c17dfd405924cdcadbb6066cf82c9725413d3f..b84a11d433feb01010e72f5d23d146358ecaf077 100644 (file)
@@ -22633,7 +22633,7 @@ ix86_expand_sse_cmp (rtx dest, enum rtx_code code, rtx cmp_op0, rtx cmp_op1,
 /* Expand DEST = CMP ? OP_TRUE : OP_FALSE into a sequence of logical
    operations.  This is used for both scalar and vector conditional moves.  */
 
-static void
+void
 ix86_expand_sse_movcc (rtx dest, rtx cmp, rtx op_true, rtx op_false)
 {
   machine_mode mode = GET_MODE (dest);
index f804255aedf2d3218e18e6b2d75660a9dd1e344a..452629fa0ca7cab5c78a32454adc4398549c5d4e 100644 (file)
   DONE;
 })
 
+(define_expand "vcond_mask_<mode><avx512fmaskmodelower>"
+  [(set (match_operand:V48_AVX512VL 0 "register_operand")
+       (vec_merge:V48_AVX512VL
+         (match_operand:V48_AVX512VL 1 "nonimmediate_operand")
+         (match_operand:V48_AVX512VL 2 "vector_move_operand")
+         (match_operand:<avx512fmaskmode> 3 "register_operand")))]
+  "TARGET_AVX512F")
+
+(define_expand "vcond_mask_<mode><avx512fmaskmodelower>"
+  [(set (match_operand:VI12_AVX512VL 0 "register_operand")
+       (vec_merge:VI12_AVX512VL
+         (match_operand:VI12_AVX512VL 1 "nonimmediate_operand")
+         (match_operand:VI12_AVX512VL 2 "vector_move_operand")
+         (match_operand:<avx512fmaskmode> 3 "register_operand")))]
+  "TARGET_AVX512BW")
+
+(define_expand "vcond_mask_<mode><sseintvecmodelower>"
+  [(set (match_operand:VI_256 0 "register_operand")
+       (vec_merge:VI_256
+         (match_operand:VI_256 1 "nonimmediate_operand")
+         (match_operand:VI_256 2 "vector_move_operand")
+         (match_operand:<sseintvecmode> 3 "register_operand")))]
+  "TARGET_AVX2"
+{
+  ix86_expand_sse_movcc (operands[0], operands[3],
+                        operands[1], operands[2]);
+  DONE;
+})
+
+(define_expand "vcond_mask_<mode><sseintvecmodelower>"
+  [(set (match_operand:VI124_128 0 "register_operand")
+       (vec_merge:VI124_128
+         (match_operand:VI124_128 1 "nonimmediate_operand")
+         (match_operand:VI124_128 2 "vector_move_operand")
+         (match_operand:<sseintvecmode> 3 "register_operand")))]
+  "TARGET_SSE2"
+{
+  ix86_expand_sse_movcc (operands[0], operands[3],
+                        operands[1], operands[2]);
+  DONE;
+})
+
+(define_expand "vcond_mask_v2div2di"
+  [(set (match_operand:V2DI 0 "register_operand")
+       (vec_merge:V2DI
+         (match_operand:V2DI 1 "nonimmediate_operand")
+         (match_operand:V2DI 2 "vector_move_operand")
+         (match_operand:V2DI 3 "register_operand")))]
+  "TARGET_SSE4_2"
+{
+  ix86_expand_sse_movcc (operands[0], operands[3],
+                        operands[1], operands[2]);
+  DONE;
+})
+
+(define_expand "vcond_mask_<mode><sseintvecmodelower>"
+  [(set (match_operand:VF_256 0 "register_operand")
+       (vec_merge:VF_256
+         (match_operand:VF_256 1 "nonimmediate_operand")
+         (match_operand:VF_256 2 "vector_move_operand")
+         (match_operand:<sseintvecmode> 3 "register_operand")))]
+  "TARGET_AVX"
+{
+  ix86_expand_sse_movcc (operands[0], operands[3],
+                        operands[1], operands[2]);
+  DONE;
+})
+
+(define_expand "vcond_mask_<mode><sseintvecmodelower>"
+  [(set (match_operand:VF_128 0 "register_operand")
+       (vec_merge:VF_128
+         (match_operand:VF_128 1 "nonimmediate_operand")
+         (match_operand:VF_128 2 "vector_move_operand")
+         (match_operand:<sseintvecmode> 3 "register_operand")))]
+  "TARGET_SSE"
+{
+  ix86_expand_sse_movcc (operands[0], operands[3],
+                        operands[1], operands[2]);
+  DONE;
+})
+
 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
 ;;
 ;; Parallel floating point logical operations