diff --git a/src/hotspot/share/code/codeCache.cpp b/src/hotspot/share/code/codeCache.cpp index 8d3395cdac4..5bd8e0d7b30 100644 --- a/src/hotspot/share/code/codeCache.cpp +++ b/src/hotspot/share/code/codeCache.cpp @@ -780,13 +780,14 @@ void CodeCache::increment_unloading_cycle() { CodeCache::UnloadingScope::UnloadingScope(BoolObjectClosure* is_alive) : _is_unloading_behaviour(is_alive) { + _saved_behaviour = IsUnloadingBehaviour::current(); IsUnloadingBehaviour::set_current(&_is_unloading_behaviour); increment_unloading_cycle(); DependencyContext::cleaning_start(); } CodeCache::UnloadingScope::~UnloadingScope() { - IsUnloadingBehaviour::set_current(NULL); + IsUnloadingBehaviour::set_current(_saved_behaviour); DependencyContext::cleaning_end(); } diff --git a/src/hotspot/share/code/codeCache.hpp b/src/hotspot/share/code/codeCache.hpp index eb6ebd59242..1013163c5ba 100644 --- a/src/hotspot/share/code/codeCache.hpp +++ b/src/hotspot/share/code/codeCache.hpp @@ -170,6 +170,7 @@ class CodeCache : AllStatic { // "unloading_occurred" controls whether metadata should be cleaned because of class unloading. class UnloadingScope: StackObj { ClosureIsUnloadingBehaviour _is_unloading_behaviour; + IsUnloadingBehaviour* _saved_behaviour; public: UnloadingScope(BoolObjectClosure* is_alive);