Stream: git-wasmtime

Topic: wasmtime / PR #6835 Wasmtime: refactor the pooling alloca...


view this post on Zulip Wasmtime GitHub notifications bot (Aug 10 2023 at 22:54):

fitzgen opened PR #6835 from fitzgen:refactor-pooling-allocator to bytecodealliance:main:

We used to have one index allocator, an index per instance, and give out N
tables and M memories to every instance regardless how many tables and memories
they need.

Now we have an index allocator for memories and another for tables. An instance
isn't associated with a single instance, each of its memories and tables have an
index. We allocate exactly as many tables and memories as the instance actually
needs.

Ultimately, this gives us better component support, where a component instance
might have varying numbers of internal tables and memories.

Additionally, you can now limit the number of tables, memories, and core
instances a single component can allocate from the pooling allocator, even if
there is the capacity for that many available. This is to give embedders tools
to limit individual component instances and prevent them from hogging too much
of the pooling allocator's resources.


TODO before landing:

view this post on Zulip Wasmtime GitHub notifications bot (Aug 10 2023 at 22:54):

fitzgen requested alexcrichton for a review on PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 10 2023 at 22:54):

fitzgen requested wasmtime-core-reviewers for a review on PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 10 2023 at 22:56):

fitzgen submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 10 2023 at 22:56):

fitzgen submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 10 2023 at 22:56):

fitzgen created PR review comment:

Unsure whether this is better as-written, or if moving the MemoryAllocationIndex into wasmtime_runtime::Memory is better. Feel free to bike shed.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 11 2023 at 19:09):

fitzgen requested wasmtime-fuzz-reviewers for a review on PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 11 2023 at 19:09):

fitzgen updated PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 11 2023 at 19:09):

fitzgen requested wasmtime-default-reviewers for a review on PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 11 2023 at 20:17):

fitzgen edited PR #6835:

We used to have one index allocator, an index per instance, and give out N
tables and M memories to every instance regardless how many tables and memories
they need.

Now we have an index allocator for memories and another for tables. An instance
isn't associated with a single instance, each of its memories and tables have an
index. We allocate exactly as many tables and memories as the instance actually
needs.

Ultimately, this gives us better component support, where a component instance
might have varying numbers of internal tables and memories.

Additionally, you can now limit the number of tables, memories, and core
instances a single component can allocate from the pooling allocator, even if
there is the capacity for that many available. This is to give embedders tools
to limit individual component instances and prevent them from hogging too much
of the pooling allocator's resources.


TODO before landing:

view this post on Zulip Wasmtime GitHub notifications bot (Aug 11 2023 at 22:28):

fitzgen updated PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 11 2023 at 22:30):

fitzgen updated PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 14 2023 at 23:13):

fitzgen requested cfallin for a review on PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 20:22):

fitzgen submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 20:38):

fitzgen created PR review comment:

Note from Chris on zoom: can we RAII this stuff?

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 20:59):

fitzgen submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 20:59):

fitzgen created PR review comment:

hoist to avoid allocating code objects and things when validation will fail

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 20:59):

fitzgen created PR review comment:

note from chris: can we newtype this tuple? ModuleAndMemory or something like that

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 20:59):

fitzgen created PR review comment:

comment out of date

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:00):

fitzgen submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:02):

fitzgen created PR review comment:

note from Chris: seems like some abstraction here could maybe improve things but I don't know what it is.

for now can we have a comment about why we can't use associated types because of how this is used as a trait object

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:04):

fitzgen created PR review comment:

note from chris: diagram/comment need updates

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:07):

fitzgen created PR review comment:

leave a comment that we could keep track of how many memories we have per module instead of probing all possible indices if this ever shows up in a profile

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:12):

fitzgen created PR review comment:

Note: I am going to avoid an RAII type because

  1. we would need two types, one for core module instantiation and one for component instantiation, and
  2. only the error paths would be able to use these, not the success paths, because the RAII type would need to wrap self here, which isn't feasible once the instance is returned.

Therefore, I'll do the immediately-invoked closure thing instead.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:13):

fitzgen submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:14):

fitzgen created PR review comment:

request for comment: deallocation needs to be infallible, because if it wasn't we could leak if say the first of two memories failed to drop.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:15):

fitzgen created PR review comment:

or we can use an immediately-invoked closure so that we can ? inside it but still have only a single place for clean up on error

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:16):

fitzgen created PR review comment:

add comment about how this is needed for validation but does not factor into the pre-allocated pool size and its layout

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:46):

cfallin submitted PR review:

Together with earlier zoom review and associated comments, this overall looks great to me! High-quality implementation with good attention paid to safety (e.g. index newtypes). A few comments below as well but nothing too major.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:46):

cfallin submitted PR review:

Together with earlier zoom review and associated comments, this overall looks great to me! High-quality implementation with good attention paid to safety (e.g. index newtypes). A few comments below as well but nothing too major.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:46):

cfallin created PR review comment:

likewise here, and for stacks, total core instances, ... below

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:46):

cfallin created PR review comment:

should this be called max_... (in line with the other limits)?

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:46):

cfallin created PR review comment:

as above, max_... ?

view this post on Zulip Wasmtime GitHub notifications bot (Aug 15 2023 at 21:46):

cfallin created PR review comment:

here we're using the component-instance array just for its length -- could we store a counter rather than actual instance handles?

view this post on Zulip Wasmtime GitHub notifications bot (Aug 16 2023 at 18:42):

fitzgen submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 16 2023 at 18:42):

fitzgen created PR review comment:

This one isn't really a maximum, it is the exact number of memories we will have capacity for in the pool. So I'll leave it as-is.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 16 2023 at 18:42):

fitzgen submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 16 2023 at 18:42):

fitzgen created PR review comment:

Ditto.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 16 2023 at 18:48):

cfallin submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 16 2023 at 18:48):

cfallin created PR review comment:

Hmm, yeah, I guess it's kind of a matter of semantics -- it is the maximum number that we can allocate across the whole pool. ("Capacity" is another way of saying "maximum", I guess.) But I'll defer to your judgment here if you want to keep as-is.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 16 2023 at 21:43):

fitzgen updated PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 17 2023 at 16:00):

fitzgen updated PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 17 2023 at 16:00):

fitzgen has enabled auto merge for PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 17 2023 at 16:24):

fitzgen updated PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 17 2023 at 17:59):

fitzgen updated PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 17 2023 at 19:19):

fitzgen updated PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 17 2023 at 19:19):

fitzgen has enabled auto merge for PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 18 2023 at 19:52):

fitzgen updated PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 18 2023 at 19:52):

fitzgen has enabled auto merge for PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 18 2023 at 21:01):

fitzgen updated PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 18 2023 at 21:01):

fitzgen has enabled auto merge for PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 18 2023 at 22:04):

fitzgen merged PR #6835.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 21 2023 at 15:48):

alexcrichton submitted PR review:

This all looks great to me, thanks again for tackling this!

view this post on Zulip Wasmtime GitHub notifications bot (Aug 21 2023 at 15:48):

alexcrichton submitted PR review:

This all looks great to me, thanks again for tackling this!

view this post on Zulip Wasmtime GitHub notifications bot (Aug 21 2023 at 15:48):

alexcrichton created PR review comment:

Mind throwing in a debug assert here that the return value is not 0? (e.g. this never goes negative)

view this post on Zulip Wasmtime GitHub notifications bot (Aug 21 2023 at 15:48):

alexcrichton created PR review comment:

Would it be possible to keep this as one trait? Inferring why this was split into two it seems like it wants to guarantee that the default implementations of methods are used, but this is purely internal and it's already an unsafe trait, so I think that should be enough to cover the bases? (I don't think we're at risk of duplicating these default trait method implementations anywhere)

view this post on Zulip Wasmtime GitHub notifications bot (Aug 21 2023 at 15:48):

alexcrichton created PR review comment:

I mentioned this in person as well, but would it be possible to eschew this index (and the one above) and infer the index from an address in the pooling allocator?

view this post on Zulip Wasmtime GitHub notifications bot (Aug 21 2023 at 15:48):

alexcrichton created PR review comment:

(and the other decrement methods too)


Last updated: Jan 24 2025 at 00:11 UTC