8046289: compiler/6340864/TestLongVect.java timeout with
Reviewed-by: iveresov, vlivanov
This commit is contained in:
parent
fa6b220619
commit
99ff96473e
@ -557,8 +557,9 @@ class Parse : public GraphKit {
|
|||||||
|
|
||||||
float dynamic_branch_prediction(float &cnt);
|
float dynamic_branch_prediction(float &cnt);
|
||||||
float branch_prediction(float &cnt, BoolTest::mask btest, int target_bci);
|
float branch_prediction(float &cnt, BoolTest::mask btest, int target_bci);
|
||||||
bool seems_never_taken(float prob);
|
bool seems_never_taken(float prob) const;
|
||||||
bool seems_stable_comparison(BoolTest::mask btest, Node* c);
|
bool path_is_suitable_for_uncommon_trap(float prob) const;
|
||||||
|
bool seems_stable_comparison() const;
|
||||||
|
|
||||||
void do_ifnull(BoolTest::mask btest, Node* c);
|
void do_ifnull(BoolTest::mask btest, Node* c);
|
||||||
void do_if(BoolTest::mask btest, Node* c);
|
void do_if(BoolTest::mask btest, Node* c);
|
||||||
|
@ -886,7 +886,7 @@ float Parse::branch_prediction(float& cnt,
|
|||||||
// some branches (e.g., _213_javac.Assembler.eliminate) validly produce
|
// some branches (e.g., _213_javac.Assembler.eliminate) validly produce
|
||||||
// very small but nonzero probabilities, which if confused with zero
|
// very small but nonzero probabilities, which if confused with zero
|
||||||
// counts would keep the program recompiling indefinitely.
|
// counts would keep the program recompiling indefinitely.
|
||||||
bool Parse::seems_never_taken(float prob) {
|
bool Parse::seems_never_taken(float prob) const {
|
||||||
return prob < PROB_MIN;
|
return prob < PROB_MIN;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -898,7 +898,7 @@ bool Parse::seems_never_taken(float prob) {
|
|||||||
// already acting in a stable fashion. If the comparison
|
// already acting in a stable fashion. If the comparison
|
||||||
// seems stable, we will put an expensive uncommon trap
|
// seems stable, we will put an expensive uncommon trap
|
||||||
// on the untaken path.
|
// on the untaken path.
|
||||||
bool Parse::seems_stable_comparison(BoolTest::mask btest, Node* cmp) {
|
bool Parse::seems_stable_comparison() const {
|
||||||
if (C->too_many_traps(method(), bci(), Deoptimization::Reason_unstable_if)) {
|
if (C->too_many_traps(method(), bci(), Deoptimization::Reason_unstable_if)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -1127,6 +1127,14 @@ void Parse::do_if(BoolTest::mask btest, Node* c) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Parse::path_is_suitable_for_uncommon_trap(float prob) const {
|
||||||
|
// Don't want to speculate on uncommon traps when running with -Xcomp
|
||||||
|
if (!UseInterpreter) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return (seems_never_taken(prob) && seems_stable_comparison());
|
||||||
|
}
|
||||||
|
|
||||||
//----------------------------adjust_map_after_if------------------------------
|
//----------------------------adjust_map_after_if------------------------------
|
||||||
// Adjust the JVM state to reflect the result of taking this path.
|
// Adjust the JVM state to reflect the result of taking this path.
|
||||||
// Basically, it means inspecting the CmpNode controlling this
|
// Basically, it means inspecting the CmpNode controlling this
|
||||||
@ -1140,7 +1148,7 @@ void Parse::adjust_map_after_if(BoolTest::mask btest, Node* c, float prob,
|
|||||||
|
|
||||||
bool is_fallthrough = (path == successor_for_bci(iter().next_bci()));
|
bool is_fallthrough = (path == successor_for_bci(iter().next_bci()));
|
||||||
|
|
||||||
if (seems_never_taken(prob) && seems_stable_comparison(btest, c)) {
|
if (path_is_suitable_for_uncommon_trap(prob)) {
|
||||||
repush_if_args();
|
repush_if_args();
|
||||||
uncommon_trap(Deoptimization::Reason_unstable_if,
|
uncommon_trap(Deoptimization::Reason_unstable_if,
|
||||||
Deoptimization::Action_reinterpret,
|
Deoptimization::Action_reinterpret,
|
||||||
|
Loading…
Reference in New Issue
Block a user