aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2017-03-07 08:04:38 +0000
committerJakub Jelinek <jakub@redhat.com>2017-03-07 08:04:38 +0000
commitb87c886afde4615fea7bdad399b58a0267ec1636 (patch)
tree5c0a6264e9bcf6fb5da8b83c4d77cd086033575d
parent913ca3e6cb5748b051064c285a283c7151202504 (diff)
PR rtl-optimization/79901
* expr.c (expand_expr_real_2): For vector MIN/MAX, if there is no min/max expander, expand it using expand_vec_cond_expr. git-svn-id: https://gcc.gnu.org/svn/gcc/trunk@245946 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/ChangeLog4
-rw-r--r--gcc/expr.c12
2 files changed, 16 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index eb06b5ab2eb..efeee1a1796 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,9 @@
2017-03-07 Jakub Jelinek <jakub@redhat.com>
+ PR rtl-optimization/79901
+ * expr.c (expand_expr_real_2): For vector MIN/MAX, if there is no
+ min/max expander, expand it using expand_vec_cond_expr.
+
PR sanitizer/79897
* ubsan.c (ubsan_encode_value): Call mark_addressable on the
temporary.
diff --git a/gcc/expr.c b/gcc/expr.c
index 34bbf3d7b47..91d7ea21722 100644
--- a/gcc/expr.c
+++ b/gcc/expr.c
@@ -8943,6 +8943,18 @@ expand_expr_real_2 (sepops ops, rtx target, machine_mode tmode,
if (temp != 0)
return temp;
+ /* For vector MIN <x, y>, expand it a VEC_COND_EXPR <x <= y, x, y>
+ and similarly for MAX <x, y>. */
+ if (VECTOR_TYPE_P (type))
+ {
+ tree t0 = make_tree (type, op0);
+ tree t1 = make_tree (type, op1);
+ tree comparison = build2 (code == MIN_EXPR ? LE_EXPR : GE_EXPR,
+ type, t0, t1);
+ return expand_vec_cond_expr (type, comparison, t0, t1,
+ original_target);
+ }
+
/* At this point, a MEM target is no longer useful; we will get better
code without it. */