<div dir="ltr"><div dir="ltr"></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Feb 23, 2024 at 8:25 AM Erik Osterlund <<a href="mailto:erik.osterlund@oracle.com">erik.osterlund@oracle.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">



<div dir="auto">
<div dir="ltr"></div>
<div dir="ltr">Hi Thomas,</div>
<div dir="ltr"><br>
</div>
<div dir="ltr">The use of UseCompressedClassPointers used to be intertwined weirdly with UseCompressedOops due to historic reasons. I broke that connection because we wanted compressed class pointers in ZGC, even though we don’t use compressed oops.</div>
<div dir="ltr"><br>
</div>
<div dir="ltr">After that was cleaned up I tend to think of -XX:-UseCompressedClassPointers in my head as some kind of alias for -XX:+WasteMemory which you would configure purely because you want to waste memory just for the sake of it.</div>
<div dir="ltr"><br></div></div></blockquote><div><br></div><div>Ha, beautiful. But let's see if someone else complains. I'll also ping the Jruby devs; they are the worst metaspace users I know.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="auto"><div dir="ltr">
</div>
<div dir="ltr">/Erik</div>
<div dir="ltr"><br>
<blockquote type="cite">On 22 Feb 2024, at 15:35, Thomas Stüfe <<a href="mailto:thomas.stuefe@gmail.com" target="_blank">thomas.stuefe@gmail.com</a>> wrote:<br>
<br>
</blockquote>
</div>
<blockquote type="cite">
<div dir="ltr">
<div dir="ltr">
<div>Greetings,</div>
<br>
<div>Are there any realistic scenarios that would require UseCompressedClassPointers=false? Or could we make it constant at some point or remove the switch altogether?</div>
<div><br>
</div>
<div>The only reason I can see for UseCompressedClassPointers=off would be if the maximum class space size of 3GB is not enough. But how realistic is this really? Some numbers:</div>
<div><br>
</div>
<div>On average, a Klass is ~600-700 bytes. Therefore, 3GB of class space would be enough for ~5 million classes. Note that the typical size ratio of Klass-to-non-class-metadata is 1:6 .. 1:10, which means that 3 GB class space come with ~18..30 GB of non-class
 metaspace (see [1]). I think these are outlandish numbers. Do we need to support these scenarios? Some weird class generator scenarios maybe?<br>
</div>
<div><br>
</div>
<div>Other than class space max size not being enough, are there any reasons for -UseCompressedClassPointers?<br>
</div>
<div><br>
</div>
<div>Thank you,</div>
<div><br>
</div>
<div>Thomas<br>
</div>
<div><br>
</div>
<div>[1] <a href="https://github.com/tstuefe/metaspace-statistics/blob/master/Histogram.svg" target="_blank">
https://github.com/tstuefe/metaspace-statistics/blob/master/Histogram.svg</a></div>
<div><br>
</div>
<div><br>
</div>
</div>
</div>
</blockquote>
</div>

</blockquote></div></div>