<div dir="ltr">Hi Mike,<div><br></div><div>Although the goal wasn't written with that in mind (the compiler independence is for code produced by JVMCI compilers, most notably to help what Galahad intends to do with the Graal JIT by AOT compiling it, rather than only restricting such code to only use C1 and C2), I suppose you could indeed use this platform to execute any arbitrary language with HotSpot, much in the same way any language can compile to Java's bytecode and execute in the Java Virtual Machine currently. The ABI is very probably going to be the same as what C1, C2, and JVMCI use, so any language that respects the same ABI as a JVMCI compiler could probably run with HotSpot, but again I will mention that this is not what the JEP was written in mind with. See also non-goals, which mentions that this feature will only be applicable to Java code (or any language trying to use this platform to compile to native) that respects the constraints that Leyden normally applies to its closed world standalone binaries</div><div><br></div><div>best regards,</div><div>Julian</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Jul 28, 2023 at 3:26 PM Mike Hearn <mike@hydraulic.software> 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">Nice to see! <div><br></div><div>Presumably the concrete goal will be to nail down an ABI between compiled code and the HotSpot runtime services? The compiler independence of the goals is quite interesting. In theory if there's a precise ABI for accessing runtime services like the GC, reflection, deoptimization, TLS etc, then you could write a new non-Java language that compiles to native code ahead of time using some pre-existing compiler infrastructure (e.g. .NET?), which then uses HotSpot almost as a normal language runtime library. Minimal Java code would be executed in this model and you could theoretically even use LTO to get rid of the bits of the JVM you aren't using. So if you wanted to make a new GCd language but wanted to skip bytecode and Truffle then you could do so, with a Leyden of that form.</div><div><br></div><div>Or is the idea to go in some other direction?</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, 28 Jul 2023 at 04:41, Julian Waters <<a href="mailto:tanksherman27@gmail.com" target="_blank">tanksherman27@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 dir="ltr">Hi all,<div><br></div><div>A JEP draft regarding Leyden has been submitted at <a href="https://bugs.openjdk.org/browse/JDK-8313278" target="_blank">https://bugs.openjdk.org/browse/JDK-8313278</a>. Feedback is welcome</div><div><br></div><div>best regards,</div><div>Julian</div></div></div>
</blockquote></div>
</blockquote></div>