From a67480f33da65c3e0d68bd5bca5572f47b11e365 Mon Sep 17 00:00:00 2001 From: Roland Westrelin Date: Tue, 24 Apr 2018 09:35:08 +0200 Subject: [PATCH] 8200477: Integer dot product no longer autovectorised Reviewed-by: kvn --- src/hotspot/share/opto/superword.cpp | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/src/hotspot/share/opto/superword.cpp b/src/hotspot/share/opto/superword.cpp index 295b69d4e10..f6c4162a60e 100644 --- a/src/hotspot/share/opto/superword.cpp +++ b/src/hotspot/share/opto/superword.cpp @@ -1943,9 +1943,14 @@ bool SuperWord::profitable(Node_List* p) { for (uint k = 0; k < use->req(); k++) { Node* n = use->in(k); if (def == n) { - // reductions can be loop carried dependences - if (def->is_reduction() && use->is_Phi()) + // reductions should only have a Phi use at the the loop + // head and out of loop uses + if (def->is_reduction() && + ((use->is_Phi() && use->in(0) == _lpt->_head) || + !_lpt->is_member(_phase->get_loop(_phase->ctrl_or_self(use))))) { + assert(i == p->size()-1, "must be last element of the pack"); continue; + } if (!is_vector_use(use, k)) { return false; }