diff options
author | Jakub Jelinek <jakub@redhat.com> | 2017-03-07 08:04:38 +0000 |
---|---|---|
committer | Jakub Jelinek <jakub@redhat.com> | 2017-03-07 08:04:38 +0000 |
commit | b87c886afde4615fea7bdad399b58a0267ec1636 (patch) | |
tree | 5c0a6264e9bcf6fb5da8b83c4d77cd086033575d | |
parent | 913ca3e6cb5748b051064c285a283c7151202504 (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/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/expr.c | 12 |
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. */ |