8255265: IdealLoopTree::iteration_split_impl does not use should_align

Reviewed-by: thartmann, kvn
This commit is contained in:
Aleksey Shipilev 2020-10-26 07:16:10 +00:00
parent c28b011121
commit 69188188f4
2 changed files with 10 additions and 35 deletions

View File

@ -1045,16 +1045,6 @@ void IdealLoopTree::policy_unroll_slp_analysis(CountedLoopNode *cl, PhaseIdealLo
} }
} }
//------------------------------policy_align-----------------------------------
// Return TRUE or FALSE if the loop should be cache-line aligned. Gather the
// expression that does the alignment. Note that only one array base can be
// aligned in a loop (unless the VM guarantees mutual alignment). Note that
// if we vectorize short memory ops into longer memory ops, we may want to
// increase alignment.
bool IdealLoopTree::policy_align(PhaseIdealLoop *phase) const {
return false;
}
//------------------------------policy_range_check----------------------------- //------------------------------policy_range_check-----------------------------
// Return TRUE or FALSE if the loop should be range-check-eliminated or not. // Return TRUE or FALSE if the loop should be range-check-eliminated or not.
// When TRUE, the estimated node budget is also requested. // When TRUE, the estimated node budget is also requested.
@ -3341,9 +3331,8 @@ bool IdealLoopTree::iteration_split_impl(PhaseIdealLoop *phase, Node_List &old_n
uint est_peeling = estimate_peeling(phase); uint est_peeling = estimate_peeling(phase);
bool should_peel = 0 < est_peeling; bool should_peel = 0 < est_peeling;
// Counted loops may be peeled, may need some iterations run up // Counted loops may be peeled, or may need some iterations run up
// front for RCE, and may want to align loop refs to a cache // front for RCE. Thus we clone a full loop up front whose trip count is
// line. Thus we clone a full loop up front whose trip count is
// at least 1 (if peeling), but may be several more. // at least 1 (if peeling), but may be several more.
// The main loop will start cache-line aligned with at least 1 // The main loop will start cache-line aligned with at least 1
@ -3355,27 +3344,25 @@ bool IdealLoopTree::iteration_split_impl(PhaseIdealLoop *phase, Node_List &old_n
bool should_unroll = policy_unroll(phase); bool should_unroll = policy_unroll(phase);
bool should_rce = policy_range_check(phase); bool should_rce = policy_range_check(phase);
// TODO: Remove align -- not used.
bool should_align = policy_align(phase);
// If not RCE'ing (iteration splitting) or Aligning, then we do not need a // If not RCE'ing (iteration splitting), then we do not need a pre-loop.
// pre-loop. We may still need to peel an initial iteration but we will not // We may still need to peel an initial iteration but we will not
// be needing an unknown number of pre-iterations. // be needing an unknown number of pre-iterations.
// //
// Basically, if may_rce_align reports FALSE first time through, we will not // Basically, if peel_only reports TRUE first time through, we will not
// be able to later do RCE or Aligning on this loop. // be able to later do RCE on this loop.
bool may_rce_align = !policy_peel_only(phase) || should_rce || should_align; bool peel_only = policy_peel_only(phase) && !should_rce;
// If we have any of these conditions (RCE, alignment, unrolling) met, then // If we have any of these conditions (RCE, unrolling) met, then
// we switch to the pre-/main-/post-loop model. This model also covers // we switch to the pre-/main-/post-loop model. This model also covers
// peeling. // peeling.
if (should_rce || should_align || should_unroll) { if (should_rce || should_unroll) {
if (cl->is_normal_loop()) { // Convert to 'pre/main/post' loops if (cl->is_normal_loop()) { // Convert to 'pre/main/post' loops
uint estimate = est_loop_clone_sz(3); uint estimate = est_loop_clone_sz(3);
if (!phase->may_require_nodes(estimate)) { if (!phase->may_require_nodes(estimate)) {
return false; return false;
} }
phase->insert_pre_post_loops(this, old_new, !may_rce_align); phase->insert_pre_post_loops(this, old_new, peel_only);
} }
// Adjust the pre- and main-loop limits to let the pre and post loops run // Adjust the pre- and main-loop limits to let the pre and post loops run
// with full checks, but the main-loop with no checks. Remove said checks // with full checks, but the main-loop with no checks. Remove said checks
@ -3406,11 +3393,6 @@ bool IdealLoopTree::iteration_split_impl(PhaseIdealLoop *phase, Node_List &old_n
} }
phase->do_unroll(this, old_new, true); phase->do_unroll(this, old_new, true);
} }
// Adjust the pre-loop limits to align the main body iterations.
if (should_align) {
Unimplemented();
}
} else { // Else we have an unchanged counted loop } else { // Else we have an unchanged counted loop
if (should_peel) { // Might want to peel but do nothing else if (should_peel) { // Might want to peel but do nothing else
if (phase->may_require_nodes(est_peeling)) { if (phase->may_require_nodes(est_peeling)) {

View File

@ -617,13 +617,6 @@ public:
// also gather the end of the first split and the start of the 2nd split. // also gather the end of the first split and the start of the 2nd split.
bool policy_range_check( PhaseIdealLoop *phase ) const; bool policy_range_check( PhaseIdealLoop *phase ) const;
// Return TRUE or FALSE if the loop should be cache-line aligned.
// Gather the expression that does the alignment. Note that only
// one array base can be aligned in a loop (unless the VM guarantees
// mutual alignment). Note that if we vectorize short memory ops
// into longer memory ops, we may want to increase alignment.
bool policy_align( PhaseIdealLoop *phase ) const;
// Return TRUE if "iff" is a range check. // Return TRUE if "iff" is a range check.
bool is_range_check_if(IfNode *iff, PhaseIdealLoop *phase, Invariance& invar) const; bool is_range_check_if(IfNode *iff, PhaseIdealLoop *phase, Invariance& invar) const;