# HG changeset patch # User never # Date 1229140405 28800 # Node ID ae4d91125c2d37061fb9339d3112370c1d06c0d2 # Parent eb19833101adc2fdc1e341c21baed37991c75783 6767587: missing call to make_not_entrant after deoptimizing for patching volatiles Reviewed-by: rasbold, kvn diff -r eb19833101ad -r ae4d91125c2d hotspot/src/share/vm/c1/c1_Runtime1.cpp --- a/hotspot/src/share/vm/c1/c1_Runtime1.cpp Fri Dec 12 15:37:46 2008 -0800 +++ b/hotspot/src/share/vm/c1/c1_Runtime1.cpp Fri Dec 12 19:53:25 2008 -0800 @@ -842,6 +842,13 @@ if (TracePatching) { tty->print_cr("Deoptimizing for patching volatile field reference"); } + // It's possible the nmethod was invalidated in the last + // safepoint, but if it's still alive then make it not_entrant. + nmethod* nm = CodeCache::find_nmethod(caller_frame.pc()); + if (nm != NULL) { + nm->make_not_entrant(); + } + VM_DeoptimizeFrame deopt(thread, caller_frame.id()); VMThread::execute(&deopt);