<html><body><div style="font-family: arial, helvetica, sans-serif; font-size: 12pt; color: #000000"><div><br></div><div><br></div><hr id="zwchr" data-marker="__DIVIDER__"><div data-marker="__HEADERS__"><blockquote style="border-left:2px solid #1010FF;margin-left:5px;padding-left:5px;color:#000;font-weight:normal;font-style:normal;text-decoration:none;font-family:Helvetica,Arial,sans-serif;font-size:12pt;"><b>From: </b>"Ioi Lam" <ioi.lam@oracle.com><br><b>To: </b>"leyden-dev" <leyden-dev@openjdk.org><br><b>Sent: </b>Monday, August 28, 2023 11:12:56 PM<br><b>Subject: </b>Re: I don't understand the wording here.<br></blockquote></div><div data-marker="__QUOTED_TEXT__"><blockquote style="border-left:2px solid #1010FF;margin-left:5px;padding-left:5px;color:#000;font-weight:normal;font-style:normal;text-decoration:none;font-family:Helvetica,Arial,sans-serif;font-size:12pt;"><font face="monospace">On 8/27/2023 1:24 PM, Remi Forax wrote:<br></font>
<blockquote cite="mid:412970896.19581004.1693167840174.JavaMail.zimbra@univ-eiffel.fr">
<div style="font-size: 12pt; color: rgb(0, 0, 0);"><font face="monospace"><br></font>
<div>
<div><font face="monospace">If you play with the premain
prototype of Leyden [2], there is a global option
-XX:+ArchiveInvokeDynamic that stores all the callsite
targets of the first run (training run) inside the CDS
archive.</font></div>
<div><font face="monospace">Here is an example of how to use
the prototype to run maven [3], the first run of maven
keep the dynamic information into a CDS archive and a code
archive so the next runs re-use those informations to get
a faster warmup time.<br></font></div>
<font face="monospace"><br></font>
<div><font face="monospace">[1] <a href="https://openjdk.org/projects/leyden/notes/03-toward-condensers" class="moz-txt-link-freetext" target="_blank">https://openjdk.org/projects/leyden/notes/03-toward-condensers</a><br></font></div>
<div><font face="monospace">[2] <a href="https://github.com/openjdk/leyden/tree/premain" class="moz-txt-link-freetext" target="_blank">https://github.com/openjdk/leyden/tree/premain</a><br></font></div>
<div><font face="monospace">[3] <a href="https://github.com/forax/computed-constant/blob/master/mvn-leyden.bash" class="moz-txt-link-freetext" target="_blank">https://github.com/forax/computed-constant/blob/master/mvn-leyden.bash</a><br></font></div>
</div>
</div>
</blockquote>
<font face="monospace"><br>
Hi Remi,<br><br>
Thanks for trying the premain prototype. It's in very rough shape
so it will probably cause many surprises ...</font></blockquote><div><br></div><div>Not a lot, my main issue was having a training too short so a lot a compiled methods were not reaching the state 4.<br data-mce-bogus="1"></div><div><br data-mce-bogus="1"></div><blockquote style="border-left:2px solid #1010FF;margin-left:5px;padding-left:5px;color:#000;font-weight:normal;font-style:normal;text-decoration:none;font-family:Helvetica,Arial,sans-serif;font-size:12pt;"><font face="monospace"><br>
One thing I want to point out is that the
-XX:+ArchiveInvokeDynamic option works only with "static CDS
dump", e.g., -Xshare:dump.<br><br>
It has no effect with "dynamic CDS dump", e.g., the
-XX:ArchiveClassesAtExit option used by your script in [3] above.</font></blockquote><div><br></div><div>Ahh, thanks for the info,</div><div>My first version had the 3 passes, static CDS -> dynamic CDS -> replay, but I wrongly supposed that using 2 passes, dynamic CDS -> replay was possible and I did not checked if the Indy CP rentries were stored in the dynamic CDS.<br data-mce-bogus="1"></div><div><br data-mce-bogus="1"></div><blockquote style="border-left:2px solid #1010FF;margin-left:5px;padding-left:5px;color:#000;font-weight:normal;font-style:normal;text-decoration:none;font-family:Helvetica,Arial,sans-serif;font-size:12pt;"><font face="monospace"><br>
I have some docs about using the -XX:+ArchiveInvokeDynamic flag
and checking its effects:<br><br><a class="moz-txt-link-freetext" href="https://github.com/openjdk/leyden/blob/premain/test/hotspot/jtreg/premain/InvokeDynamic.md" target="_blank">https://github.com/openjdk/leyden/blob/premain/test/hotspot/jtreg/premain/InvokeDynamic.md</a></font><br data-mce-bogus="1"></blockquote><div><br></div><div>Interresting,<br data-mce-bogus="1"></div><div>(BTW, The link to the prelinker is broken, it is in "src" not "test").</div><div><br data-mce-bogus="1"></div><blockquote style="border-left:2px solid #1010FF;margin-left:5px;padding-left:5px;color:#000;font-weight:normal;font-style:normal;text-decoration:none;font-family:Helvetica,Arial,sans-serif;font-size:12pt;"><font face="monospace"><br>
You can also see some stats like:<br><br>
$ java -Xshare:dump -Xlog:cds -XX:+ArchiveInvokeDynamic<br>
[...]<br>
[4.209s][info ][cds ] Class CP entries = 19623, archived
= 6600 ( 33.6%)<br>
[4.209s][info ][cds ] Field CP entries = 7867, archived
= 2481 ( 31.5%)<br>
[4.209s][info ][cds ] Method CP entries = 32366, archived
= 3354 ( 10.4%)<br>
[4.209s][info ][cds ] Indy CP entries = 729, archived
= 56 ( 7.7%)<br><br>
Thanks<br>
- Ioi<br></font></blockquote><div><br></div><div>Regards,<br data-mce-bogus="1"></div><div>RĂ©mi<br data-mce-bogus="1"></div><div><br data-mce-bogus="1"></div></div></div></body></html>