<div dir="ltr"><div>Okay, we found a second reason why someone may choose -XX:-UseCompressedClassPointers, at least in theory. Using +CCP will, of course, increase the vsize of the process since we reserve the address space for class space up front; without CCP, we would not use as much address space.</div><div><br></div><div>Of course, vsize is pretty much free on modern Operating Systems, and therefore this metric does not matter much. Modern 64-bit apps have gigantic vsizes; java does too, the 1..3GB of class space are usually just a drop in the sea here. Therefore, on modern Linux distros, vsize is usually unlimited (ulimit -v).<br></div><div><br></div><div>And we talk not about 32-bit platforms, where class space does not exist, so we don't intent to change anything there. This proposal only affects 64-bit platforms.</div><div><br></div><div>Disabling compressed class space in order to save vsize seems a bad tradeoff to me: spending real physical memory (more heap) in order to reduce address space.<br></div><div><br></div><div>Cheers, Thomas<br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Feb 22, 2024 at 3:34 PM Thomas Stüfe <<a href="mailto:thomas.stuefe@gmail.com">thomas.stuefe@gmail.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="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>
</blockquote></div>