<div dir="ltr"><div>I cannot contribute much to the discussion, but I think this is a valuable effort. These broad exports from hotspot have always bemused me.</div><div><br></div><div>It is probably safe to hide C++ mangled symbols since those decorations are compiler-specific anyway, no? So they cannot have worked in a reliable fashion?<br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, Feb 14, 2024 at 11:06 AM Magnus Ihse Bursie <<a href="mailto:magnus.ihse.bursie@oracle.com">magnus.ihse.bursie@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">I am currently pursuing improved build functionality for static <br>
libraries. One of the issues with static libraries are name collisions, <br>
which led me back to an old discussion about which symbols are exported <br>
from Hotspot, and how this is achieved. A long discussion is available <br>
in JDK-8017234 [1], which was created in 2013 and has been on the back <br>
burner ever since, coming back to life every now and then.<br>
<br>
There are basically two different problems here. They are both distinct <br>
and interrelated, and we likely need to solve both in tandem.<br>
<br>
The first problem is how Hotspot should say which symbols (functions) <br>
that should be exported from libjvm.so. The historical, and still used, <br>
system is to have a mapfile. In the "new" (not so new anymore) build <br>
system, this was simplified to a list of function names in <br>
make/data/hotspot-symbols, from which a mapfile is built.<br>
<br>
This is in contrast with how all other libraries in the JDK are built, <br>
and also with modern best practices. A better approach would be to <br>
annotate the functions that should be exported in the source code. In <br>
fact, such annotation already exists, even in Hotspot, as JNIEXPORT, but <br>
this is currently not used in the compilation of Hotspot.<br>
<br>
The second problem is that in addition to these explicitly exported <br>
functions, we also export basically all other functions as well in <br>
Hotspot. (So currently we could basically just forgo this complicated <br>
machinery and just export everything by default...)<br>
<br>
The reason for this seem somewhat unclear. The specifics are probably <br>
forever lost in the mists of time past, but the essential point is that <br>
these symbols are needed for SA to do it's job.<br>
<br>
So what we do is that we list all symbols in hotspot after compiling <br>
(but before linking), and selects some (most, I think) of them using <br>
regexp patterns, and add these to the mapfile.<br>
<br>
As long as we're doing this, we cannot stop using a mapfile, and we're <br>
stuck from progressing on point 1.<br>
<br>
My takeaway from the discussions is that we are most likely exporting a <br>
way too broad set of symbols to SA. It seems likely that this set can be <br>
drastically cut down. Actually getting an understanding of exactly which <br>
symbols SA need seem like a very good first step.<br>
<br>
So, is this a journey anyone would be interested in embarkering on? I <br>
will help as much as I can from a build PoV, but I have no clue <br>
whatsoever about what SA needs.<br>
<br>
/Magnus<br>
<br>
[1] <a href="https://bugs.openjdk.org/browse/JDK-8017234" rel="noreferrer" target="_blank">https://bugs.openjdk.org/browse/JDK-8017234</a><br>
<br>
</blockquote></div>