8255265: IdealLoopTree::iteration_split_impl does not use should_align
Reviewed-by: thartmann, kvn
This commit is contained in:
parent
c28b011121
commit
69188188f4
@ -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)) {
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user