From ca29203cac651af295d78e6fff6dfdd8a614ff86 Mon Sep 17 00:00:00 2001 From: Patric Hedlin Date: Tue, 25 Jun 2019 11:43:36 +0200 Subject: [PATCH] 8225475: Node budget asserts on x86_32/64 Make the (ad-hoc) loop cloning size estimate more pessimistic. Reviewed-by: shade --- src/hotspot/share/opto/loopnode.cpp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/hotspot/share/opto/loopnode.cpp b/src/hotspot/share/opto/loopnode.cpp index d03bf22ee56..2394577f5b5 100644 --- a/src/hotspot/share/opto/loopnode.cpp +++ b/src/hotspot/share/opto/loopnode.cpp @@ -2494,9 +2494,11 @@ uint IdealLoopTree::est_loop_clone_sz(uint factor) const { } } } - // Add data (x1.5) and control (x1.0) count to estimate iff both are > 0. + // Add data and control count (x2.0) to estimate iff both are > 0. This is + // a rather pessimistic estimate for the most part, in particular for some + // complex loops, but still not enough to capture all loops. if (ctrl_edge_out_cnt > 0 && data_edge_out_cnt > 0) { - estimate += ctrl_edge_out_cnt + data_edge_out_cnt + data_edge_out_cnt / 2; + estimate += 2 * (ctrl_edge_out_cnt + data_edge_out_cnt); } return estimate;