6805748: Assertion "don't reset to 0 -- could be mistaken for never-executed" in CompilationPolicy

Resetting the invocation counter for a method invocation event was setting count to zero for CompileThreshold=1, making it look like a never executed method.

Reviewed-by: phh, kamg, acorn, never
This commit is contained in:
Coleen Phillimore 2009-03-20 22:08:48 -04:00
parent fba4182589
commit c8da21faa9

View File

@ -47,6 +47,8 @@ void InvocationCounter::set_carry() {
// executed many more times before re-entering the VM.
int old_count = count();
int new_count = MIN2(old_count, (int) (CompileThreshold / 2));
// prevent from going to zero, to distinguish from never-executed methods
if (new_count == 0) new_count = 1;
if (old_count != new_count) set(state(), new_count);
}