src/share/vm/ci/ciEnv.cpp
Index Unified diffs Context diffs Sdiffs Wdiffs Patch New Old Previous File Next File 8031320_9 Cdiff src/share/vm/ci/ciEnv.cpp

src/share/vm/ci/ciEnv.cpp

Print this page

        

*** 959,969 **** ExceptionHandlerTable* handler_table, ImplicitExceptionTable* inc_table, AbstractCompiler* compiler, int comp_level, bool has_unsafe_access, ! bool has_wide_vectors) { VM_ENTRY_MARK; nmethod* nm = NULL; { // To prevent compile queue updates. MutexLocker locker(MethodCompileQueue_lock, THREAD); --- 959,970 ---- ExceptionHandlerTable* handler_table, ImplicitExceptionTable* inc_table, AbstractCompiler* compiler, int comp_level, bool has_unsafe_access, ! bool has_wide_vectors, ! RTMState rtm_state) { VM_ENTRY_MARK; nmethod* nm = NULL; { // To prevent compile queue updates. MutexLocker locker(MethodCompileQueue_lock, THREAD);
*** 1000,1009 **** --- 1001,1019 ---- validate_compile_task_dependencies(target); } methodHandle method(THREAD, target->get_Method()); + #if INCLUDE_RTM_OPT + if (!failing() && (rtm_state != NoRTM) && + (method()->method_data() != NULL) && + (method()->method_data()->rtm_state() != rtm_state)) { + // Preemptive decompile if rtm state was changed. + record_failure("RTM state change invalidated rtm code"); + } + #endif + if (failing()) { // While not a true deoptimization, it is a preemptive decompile. MethodData* mdo = method()->method_data(); if (mdo != NULL) { mdo->inc_decompile_count();
*** 1027,1036 **** --- 1037,1048 ---- debug_info(), dependencies(), code_buffer, frame_words, oop_map_set, handler_table, inc_table, compiler, comp_level); + nm->set_rtm_state(rtm_state); + // Free codeBlobs code_buffer->free_blob(); if (nm != NULL) { nm->set_has_unsafe_access(has_unsafe_access);
src/share/vm/ci/ciEnv.cpp
Index Unified diffs Context diffs Sdiffs Wdiffs Patch New Old Previous File Next File