<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=ISO-8859-1">
</head>
<body bgcolor="#FFFFFF" text="#000000">
<a class="moz-txt-link-freetext" href="http://cr.openjdk.java.net/~stefank/8013160/webrev.00/">http://cr.openjdk.java.net/~stefank/8013160/webrev.00/</a><br>
<br>
There's some remnants from the PermGen that's confusing in the class
unloading code. This patch removes the unnecessary code, cleans up
some comments and unifies the code structure over different GCs.<br>
<br>
From the Bug report:<br>
---<br>
<meta http-equiv="content-type" content="text/html;
charset=ISO-8859-1">
The PermGen Removal changed CompiledICHolders from being Java
objects to C++ objects.
<br>
<br>
CodeCache::do_unloading(...) used to take a keep_alive closure that
was applied to CompiledICHolders deep down in nmethod::do_unloading.
Since CompileICHolders don't move anymore, and we have other ways to
keep them alive, we don't use the keep_alive closures in these
functions anymore.
<br>
<br>
Because of this, CodeCache::do_unloading will not populate the
marking stacks, and we can remove the call to drain the stacks after
the calls to CodeCache::do_unloading.
<br>
<br>
This also has the neat effect that we now can verify that the
marking has really completed before we start unloading classes,
which makes the code easier to maintain/understand.<br>
---<br>
<br>
thanks,<br>
StefanK<br>
</body>
</html>