From 417e1d1a4e05d9311aeca2904807e5f18eba8f6d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Roberto=20Casta=C3=B1eda=20Lozano?= Date: Wed, 13 Jan 2021 07:22:30 +0000 Subject: [PATCH] 8259061: C2: assert(found) failed: memory-writing node is not placed in its original loop or an ancestor of it Remove assertion that is too general, that is, it can fail on compilations where C2 generates correct code otherwise. Reviewed-by: chagedorn, thartmann, kvn --- src/hotspot/share/opto/block.cpp | 20 -------------------- 1 file changed, 20 deletions(-) diff --git a/src/hotspot/share/opto/block.cpp b/src/hotspot/share/opto/block.cpp index 943a2fb30ca..22e6d927c34 100644 --- a/src/hotspot/share/opto/block.cpp +++ b/src/hotspot/share/opto/block.cpp @@ -1221,26 +1221,6 @@ void PhaseCFG::verify() const { if (j >= 1 && n->is_Mach() && n->as_Mach()->ideal_Opcode() == Op_CreateEx) { assert(j == 1 || block->get_node(j-1)->is_Phi(), "CreateEx must be first instruction in block"); } - // Verify that memory-writing nodes (such as stores and calls) are placed - // in their original loop L (given by the control input) or in an ancestor - // of L. This is guaranteed by the freq. estimation model for reducible - // CFGs, and by special handling in PhaseCFG::schedule_late() otherwise. - if (n->is_Mach() && n->bottom_type()->has_memory() && n->in(0) != NULL) { - Block* original_block = find_block_for_node(n->in(0)); - assert(original_block != NULL, "missing block for memory-writing node"); - CFGLoop* original_or_ancestor = original_block->_loop; - assert(block->_loop != NULL && original_or_ancestor != NULL, "no loop"); - bool found = false; - do { - if (block->_loop == original_or_ancestor) { - found = true; - break; - } - original_or_ancestor = original_or_ancestor->parent(); - } while (original_or_ancestor != NULL); - assert(found, "memory-writing node is not placed in its original loop " - "or an ancestor of it"); - } if (n->needs_anti_dependence_check()) { verify_anti_dependences(block, n); }