8324667: fold Parse::seems_stable_comparison()
Reviewed-by: jkarthikeyan, chagedorn, xliu
This commit is contained in:
parent
fb07bbe7b2
commit
84deeb6cd5
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -564,7 +564,6 @@ class Parse : public GraphKit {
|
|||||||
float branch_prediction(float &cnt, BoolTest::mask btest, int target_bci, Node* test);
|
float branch_prediction(float &cnt, BoolTest::mask btest, int target_bci, Node* test);
|
||||||
bool seems_never_taken(float prob) const;
|
bool seems_never_taken(float prob) const;
|
||||||
bool path_is_suitable_for_uncommon_trap(float prob) const;
|
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);
|
||||||
|
@ -1354,21 +1354,6 @@ bool Parse::seems_never_taken(float prob) const {
|
|||||||
return prob < PROB_MIN;
|
return prob < PROB_MIN;
|
||||||
}
|
}
|
||||||
|
|
||||||
// True if the comparison seems to be the kind that will not change its
|
|
||||||
// statistics from true to false. See comments in adjust_map_after_if.
|
|
||||||
// This question is only asked along paths which are already
|
|
||||||
// classified as untaken (by seems_never_taken), so really,
|
|
||||||
// if a path is never taken, its controlling comparison is
|
|
||||||
// already acting in a stable fashion. If the comparison
|
|
||||||
// seems stable, we will put an expensive uncommon trap
|
|
||||||
// on the untaken path.
|
|
||||||
bool Parse::seems_stable_comparison() const {
|
|
||||||
if (C->too_many_traps(method(), bci(), Deoptimization::Reason_unstable_if)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
//-------------------------------repush_if_args--------------------------------
|
//-------------------------------repush_if_args--------------------------------
|
||||||
// Push arguments of an "if" bytecode back onto the stack by adjusting _sp.
|
// Push arguments of an "if" bytecode back onto the stack by adjusting _sp.
|
||||||
inline int Parse::repush_if_args() {
|
inline int Parse::repush_if_args() {
|
||||||
@ -1572,7 +1557,8 @@ bool Parse::path_is_suitable_for_uncommon_trap(float prob) const {
|
|||||||
if (!UseInterpreter) {
|
if (!UseInterpreter) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return (seems_never_taken(prob) && seems_stable_comparison());
|
return seems_never_taken(prob) &&
|
||||||
|
!C->too_many_traps(method(), bci(), Deoptimization::Reason_unstable_if);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Parse::maybe_add_predicate_after_if(Block* path) {
|
void Parse::maybe_add_predicate_after_if(Block* path) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user