Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Can shared structs store SharedArrayBuffer? #16

Open
Jamesernator opened this issue Jun 15, 2022 · 6 comments
Open

Can shared structs store SharedArrayBuffer? #16

Jamesernator opened this issue Jun 15, 2022 · 6 comments

Comments

@Jamesernator
Copy link

Jamesernator commented Jun 15, 2022

So in the current proposal, shared structs can only have fields that are themselves primitives or other shared structs.

However SharedArrayBuffer feels like it should be sharable and is kind've important to be able to share as it the only mechanism through which Atomics instructions other than the four available to shared structs would be available. Of particular note is Atomics.wait and Atomics.notify which are important for implementing locks and such.

But currently SharedArrayBuffer probably couldn't be shared as it is an object, in fact the identity of the SharedArrayBuffer in general doesn't round trip as a new wrapper object is created everytime it's cloned.

Although having said that could we still set them anyway? There's a few possible strategies I could see:

  • Respec SharedArrayBuffer to be a shared struct so that it can be shared like any other shared struct
    • This means the SharedArrayBuffer would be a frozen object, so this might not be web compatible
  • Create wrappers when accessed on a shared struct, i.e. sharedStruct.someBuffer lazily creates a SharedArrayBuffer object wrapper when accessed
    • Two ways of doing this, either revive the same object identity each time, or everytime the field is accessed create a new object wrapper
  • Add a new shared struct object that can be transformed to and from a SharedArrayBuffer
    • i.e. Something like const sabSharedRef = sab.toSharedArrayBufferRef() / const sab = sharedStruct.sabRef.toSharedArrayBuffer()
@Jamesernator Jamesernator changed the title Can shared structs have SharedArrayBuffer properties? Can shared structs store SharedArrayBuffer? Jun 15, 2022
@syg
Copy link
Collaborator

syg commented Jun 15, 2022

It's a good point, and currently the answer is no. I haven't given it too much thought yet, but I agree we should do something here to be able to put SABs into shared structs. Do you think this is an important thing to have in the MVP?

An aside on locks: the explainer is terribly out of date and I haven't had the cycles to update. The current plan is to directly provide a Mutex and Condition instead of keep forcing folks to roll their own (which is hard to get right!).

@Jamesernator
Copy link
Author

Jamesernator commented Jun 16, 2022

The current plan is to directly provide a Mutex and Condition instead of keep forcing folks to roll their own (which is hard to get right!).

Condition and Mutex pretty much cover all the uses I've personally had with SABs.

Do you think this is an important thing to have in the MVP?

I'm not sure, being able to share chunks of binary data feels like it should be something that is supported. Like I could imagine something like having some image data on a shared struct that is replaced every frame. But I haven't personally hit any use cases that wouldn't be covered by the additional primitives.

@germtb
Copy link

germtb commented Nov 22, 2023

It would be valuable to add support for SharedArrayBuffer since one of the use cases would be to support parallel encryption which relies on bytes for keys and ciphertext. This would be valuable for any e2ee application (e.g. whatsapp web)

@xnimorz
Copy link

xnimorz commented Nov 24, 2023

I'd also say, that SharedArrayBuffer is highly beneficial. It solves many issues as such:

  1. Crypto keys sharing (as per @germtb point)
  2. Media processing, incl video (e.g. when we have heavy processing moved to worker, but want result to be displayed on client, and shared canvas context might not help)
  3. Any other binary formats

@bakkot
Copy link

bakkot commented Jan 21, 2025

I think this applies to regular structs wrt ArrayBuffers too, at least when reflecting WasmGC objects - see this post about trying to use WasmGC objects to drive WebGL (which is currently very expensive because you first have to copy all the data out of the WasmGC object into a Uint8Array).

In my ideal world a WasmGC array of i8 would somehow just be an Int8Array (backed by a SAB) in the JS reification. But that's tricky. An alternative is to make all the web APIs which accept ArrayBuffers or views thereon also accept restricted-type struct arrays.

@syg
Copy link
Collaborator

syg commented Jan 21, 2025

In my ideal world a WasmGC array of i8 would somehow just be an Int8Array (backed by a SAB) in the JS reification. But that's tricky. An alternative is to make all the web APIs which accept ArrayBuffers or views thereon also accept restricted-type struct arrays.

Thanks for the feedback. We should address this as part of the JS/WasmGC interop story.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants