7119730: Tiered: SIGSEGV in AdvancedThresholdPolicy::is_method_profiled(methodOop)

Added handles for references to methods in select_task()

Reviewed-by: twisti, kvn
This commit is contained in:
Igor Veresov 2011-12-12 12:44:08 -08:00
parent bb40d3f9f4
commit d447f02608

View File

@ -156,20 +156,19 @@ bool AdvancedThresholdPolicy::is_method_profiled(methodOop method) {
// Called with the queue locked and with at least one element // Called with the queue locked and with at least one element
CompileTask* AdvancedThresholdPolicy::select_task(CompileQueue* compile_queue) { CompileTask* AdvancedThresholdPolicy::select_task(CompileQueue* compile_queue) {
CompileTask *max_task = NULL; CompileTask *max_task = NULL;
methodOop max_method; methodHandle max_method;
jlong t = os::javaTimeMillis(); jlong t = os::javaTimeMillis();
// Iterate through the queue and find a method with a maximum rate. // Iterate through the queue and find a method with a maximum rate.
for (CompileTask* task = compile_queue->first(); task != NULL;) { for (CompileTask* task = compile_queue->first(); task != NULL;) {
CompileTask* next_task = task->next(); CompileTask* next_task = task->next();
methodOop method = (methodOop)JNIHandles::resolve(task->method_handle()); methodHandle method = (methodOop)JNIHandles::resolve(task->method_handle());
methodDataOop mdo = method->method_data(); update_rate(t, method());
update_rate(t, method);
if (max_task == NULL) { if (max_task == NULL) {
max_task = task; max_task = task;
max_method = method; max_method = method;
} else { } else {
// If a method has been stale for some time, remove it from the queue. // If a method has been stale for some time, remove it from the queue.
if (is_stale(t, TieredCompileTaskTimeout, method) && !is_old(method)) { if (is_stale(t, TieredCompileTaskTimeout, method()) && !is_old(method())) {
if (PrintTieredEvents) { if (PrintTieredEvents) {
print_event(REMOVE_FROM_QUEUE, method, method, task->osr_bci(), (CompLevel)task->comp_level()); print_event(REMOVE_FROM_QUEUE, method, method, task->osr_bci(), (CompLevel)task->comp_level());
} }
@ -181,7 +180,7 @@ CompileTask* AdvancedThresholdPolicy::select_task(CompileQueue* compile_queue) {
} }
// Select a method with a higher rate // Select a method with a higher rate
if (compare_methods(method, max_method)) { if (compare_methods(method(), max_method())) {
max_task = task; max_task = task;
max_method = method; max_method = method;
} }
@ -190,7 +189,7 @@ CompileTask* AdvancedThresholdPolicy::select_task(CompileQueue* compile_queue) {
} }
if (max_task->comp_level() == CompLevel_full_profile && TieredStopAtLevel > CompLevel_full_profile if (max_task->comp_level() == CompLevel_full_profile && TieredStopAtLevel > CompLevel_full_profile
&& is_method_profiled(max_method)) { && is_method_profiled(max_method())) {
max_task->set_comp_level(CompLevel_limited_profile); max_task->set_comp_level(CompLevel_limited_profile);
if (PrintTieredEvents) { if (PrintTieredEvents) {
print_event(UPDATE_IN_QUEUE, max_method, max_method, max_task->osr_bci(), (CompLevel)max_task->comp_level()); print_event(UPDATE_IN_QUEUE, max_method, max_method, max_task->osr_bci(), (CompLevel)max_task->comp_level());