Unifying memory addresses and memory segments

Maurizio Cimadamore maurizio.cimadamore at oracle.com
Thu Sep 29 15:10:00 UTC 2022


Hi,
There are few things to be clarified here. Not all segments are created 
equals. If you create a segment and attach it to a "real" session, then 
escape analysis will fail (as the segment needs to be added to the 
session's list).

But the segments returned by the linker (which used to be MemoryAddress 
instances) are simpler segment instances, which are backed by the 
"global" session. These instances are routinely scalarized (I believe 
folks working on LWJGL did some experiments on this, and reported few 
issues, which have now been fixed).

Of course, if you take a zero-length memory segment, associated with the 
global session, and want to give it a size and a session (using 
MemorySegment::ofAddress), that's more expensive (but that is the same 
as before).

Lastly, I don't think there's anything preventing us from turning 
MemorySegment into value classes, on paper. The tricky thing of doing 
that move is to make sure that C2 can see "what kind of segment are you 
dealing with", so that the underlying Unsafe access (for memory 
operation) can be sharp. In other words, C2 needs to know if the segment 
has an associated "heap base" (and, if yes, what's the type of the base 
object) or not. Otherwise you end up with the so called "mixed access", 
where C2 wasn't able to prove that access was off-heap and extra 
barriers are inserted.

That is why, at the moment, we have different memory segment 
implementations, one per "kind". We have an abstract class, and many 
leaves. Valhalla supports abstract classes too, but abstract classes 
need to have no field (which is something we can easily fix when needed).

But I think the biggest gains would come from having a truly monomorphic 
memory segment implementation, although that requires some C2 
optimizations (such as speculating on the types of some fields) which we 
do not have yet (but which will likely get more attention once Valhalla 
lands, as monomorphi-zation will become a trick that many people will 
want to play).

So, in short - the proposed patch doesn't really alter performance 
characteristics (zero-length segments backed by global session are cheap 
to create and scalarize, like MemoryAddress). And I think there's no 
issue in making MemorySegment a value class, although, to fully reap 
benefits of Valhalla we might need more help from C2.

Maurizio


On 29/09/2022 15:13, Glavo wrote:
> Sorry for the late reply to the email. I am more concerned about the 
> following things:
>
> 1. I've asked about Panama's interaction with Valhalla in previous 
> emails. At the time you said that MemoryAddress might become a value 
> class in the future.
>     The value class as a field type may be able to be stored inline in 
> the future. However, this is not possible with MemorySegment.
> 2. MemorySegment as a function parameter may be more difficult to 
> stack allocated when the function cannot be inlined.
>
> I'd like to be able to make native calls through Valhalla with zero 
> allocation, but this change seems to be further away from my 
> expectations, so I'm skeptical.
> If I am wrong, I hope you can point it out for me, thanks!
>
> On Thu, Sep 1, 2022 at 5:04 AM Maurizio Cimadamore 
> <maurizio.cimadamore at oracle.com> wrote:
>
>     What Paul says is correct, the existing benchmark showed no
>     regression
>     before/after the change.
>
>     If you know of benchmarks that show a different picture now would
>     be the
>     ideal time to share them :-)
>
>     I also note that, in your original message you wrote about a
>     detrimental
>     effect on "memory management". What do you mean by that? Perhaps you
>     mean more objects being created on the heap?
>
>     In principle, you can view a MemoryAddress in the old API as a
>     MemorySegment backed by the global memory session, whose base
>     address is
>     a certain native address, and its size is zero. So, if clients
>     want to
>     use a segment just to communicate an address in the new API, and they
>     create such address-like segments with
>     `MemorySegment.ofLong(long)`, all
>     should be fine and escape analysis should work roughly the same as
>     before. But again, if you have evidence of the contrary, please
>     let us know.
>
>     Thanks
>     Maurizio
>
>     On 25/08/2022 21:59, Paul Sandoz wrote:
>     >
>     >> On Aug 25, 2022, at 12:51 AM, Glavo <zjx001202 at gmail.com> wrote:
>     >>
>     >> It looks good in terms of simplifying API design, but this
>     seems to have some detrimental effects on performance optimization
>     as well as memory management.
>     >>
>     > Can you please data you have on any performance regressions you
>     are observing?
>     >
>     >
>     >> Do we have some benchmarks to show changes in performance and
>     memory overhead (number of temporary objects created)?
>     >>
>     > I believe the existing micro benchmarks show no regressions:
>     >
>     >
>     https://github.com/openjdk/jdk/tree/master/test/micro/org/openjdk/bench/java/lang/foreign
>     <https://urldefense.com/v3/__https://github.com/openjdk/jdk/tree/master/test/micro/org/openjdk/bench/java/lang/foreign__;!!ACWV5N9M2RV99hQ!P9lRjFpp2u31-nTmHGkNuffRc8WTHIY7ky-3q570E60HzEm3JKxfI6EqGgQPSLDBEbqIm4qlgjF_sJ6vS5JXRh6N1Q$>
>     >
>     > Paul.
>     >
>     >
>     >> On Tue, Jul 19, 2022 at 10:05 PM Maurizio Cimadamore
>     <maurizio.cimadamore at oracle.com> wrote:
>     >> Hi,
>     >> The Java 19 Foreign Function and Memory API (FFM API) uses
>     zero-length
>     >> memory segments to encode pointers that are temporally safe (this
>     >> replaces the NativeSymbol abstraction that was available in
>     Java 18).
>     >> It turns out that there's more to this approach than meets the
>     eye, as
>     >> memory segments can (with few tweaks) be used as a replacement for
>     >> memory address everywhere in the FFM API, which leads to a
>     simpler and
>     >> more symmetric API.
>     >>
>     >> We have captured our findings in the following document:
>     >>
>     >> http://cr.openjdk.java.net/~mcimadamore/panama/segment_address.html
>     >>
>     >> Cheers
>     >> Maurizio
>     >>
>     >>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://mail.openjdk.org/pipermail/panama-dev/attachments/20220929/a4446927/attachment-0001.htm>


More information about the panama-dev mailing list