From 3245582f7d5cf4a5f69218add91a15aa606e8822 Mon Sep 17 00:00:00 2001 From: Ilya Leoshkevich Date: Thu, 10 Oct 2019 17:00:29 +0000 Subject: [PATCH] [PATCH 1/3] S/390: Do not use signaling vector comparisons on z13 z13 supports only non-signaling vector comparisons. This means we cannot vectorize LT, LE, GT, GE and LTGT when compiling for z13. Notify middle-end about this by using more restrictive operator predicate in vcond. gcc/ChangeLog: 2019-10-10 Ilya Leoshkevich PR target/77918 * config/s390/vector.md (vcond_comparison_operator): New predicate. (vcond): Use vcond_comparison_operator. From-SVN: r276842 --- gcc/ChangeLog | 7 +++++++ gcc/config/s390/vector.md | 22 +++++++++++++++++++++- 2 files changed, 28 insertions(+), 1 deletion(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index e3c1a4f0717..9c34213997f 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2019-10-10 Ilya Leoshkevich + + PR target/77918 + * config/s390/vector.md (vcond_comparison_operator): New + predicate. + (vcond): Use vcond_comparison_operator. + 2019-10-10 David Malcolm PR 87488 diff --git a/gcc/config/s390/vector.md b/gcc/config/s390/vector.md index 127b75f63f1..e50047b96e4 100644 --- a/gcc/config/s390/vector.md +++ b/gcc/config/s390/vector.md @@ -614,10 +614,30 @@ operands[2] = GEN_INT (GET_MODE_NUNITS (mode) - 1); }) +(define_predicate "vcond_comparison_operator" + (match_operand 0 "comparison_operator") +{ + if (!HONOR_NANS (GET_MODE (XEXP (op, 0))) + && !HONOR_NANS (GET_MODE (XEXP (op, 1)))) + return true; + switch (GET_CODE (op)) + { + case LE: + case LT: + case GE: + case GT: + case LTGT: + /* Signaling vector comparisons are supported only on z14+. */ + return TARGET_Z14; + default: + return true; + } +}) + (define_expand "vcond" [(set (match_operand:V_HW 0 "register_operand" "") (if_then_else:V_HW - (match_operator 3 "comparison_operator" + (match_operator 3 "vcond_comparison_operator" [(match_operand:V_HW2 4 "register_operand" "") (match_operand:V_HW2 5 "nonmemory_operand" "")]) (match_operand:V_HW 1 "nonmemory_operand" "") -- 2.30.2