-
Notifications
You must be signed in to change notification settings - Fork 215
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
Zalgo: synchronize syscalls when replaying in concurrent workers #6724
base: release-pismo
Are you sure you want to change the base?
Conversation
* @returns {T extends PromiseLike<any> ? Promise<Awaited<R>> : R} | ||
*/ | ||
export function maybeAsync(v, handle) { | ||
if (typeof v === 'object' && v !== null && 'then' in v) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Consider matching the rules for testing whether it is thenable. I'm not sure the following is exactly right, but it is closer.
if (typeof v === 'object' && v !== null && 'then' in v) { | |
if (!isPrimitive(v) && typeof v.then === 'function') { |
IOW the presence of then
is only disqualifying if its value is a function.
v is a candidate whether it is an object or a function.
I feel like I'm missing something fundamental about what's going on here. It's entirely possible I'm just not successfully following what this code is doing.
I'm not sure what this means, since IIUC there's no such thing as an async syscall. Enabling workers to run independently is a good long-term goal that we've mused about for ages, but I'm missing how this PR relates to that, since the big issue that I see is interleaving crank starts and completions, releasing crank side effects (mostly message sends) from a vat in a batch at the end of the crank rather than incrementally during it. There's a bunch of voodoo involved that I've only pondered superficially but I can't find any intersection between that and this. On the other hand, supporting concurrent replays seems much more approachable in the nearer term, since replay is all about reconstructing the vat's internal memory state (i.e., it's the vat's business and nobody else's) and is side-effect free from the kernel's point of view (which is why we already get away with replaying vat cranks in a different order than they originally executed). Async replay seems like a small matter (heh) of telling the vat "here's the transcript; go to it" (which may become easier when/if we give each vat its own vatstore DB) and then coordinating the completion of all the vats that are replaying at the same time. But I don't think I see any of that here either. So what is this? |
We have 3 kind of worker types:
So I really meant worker manager that can handle syscalls asynchronously.
This is not parallel vat execution, and it's not really parallel replay. This is purely about allowing an externally provided The goal is to allow the replay tool to more precisely synchronize replay in parallel workers that should be identical, so that any behavioral difference can be noticed at the granularity of syscalls instead of deliveries. This only makes sense for in the context of the parallel replay of the same transcript into multiple workers, which is introduced by #6723. |
c068619
to
9a9ea0b
Compare
c3896c1
to
89ef9af
Compare
Use recursion in simulateSyscalls Split syscallFromWorker
Address feedback: better isThenable check
3de2ea5
to
34eb7cb
Compare
refs: #6588
Layered on top of #6723
As usual, better reviewed commit-by-commit.
Description
These are the changes required for the replay tool to synchronize the execution of multiple concurrent workers at the granularity of syscalls. Moddable expressed interest in being able to do this since a full delivery can be complex.
This effectively releases Zalgo onto the transcript syscall replay logic but contains it within the various worker managers, in a way that should be safe.
To be more specific, the transcript replay logic will detect a promise returned by
compareSyscalls
, in which case the worker manager will return a promise fromsyscallFromWorker
, but only if the worker supports async syscalls. This is the case for all workers butlocal
, which if it detects a promise will throw.It would be a mistake for the application to configure a local manager's options to try and use such a promise returning
compareSyscalls
.I am putting this PR up as draft to discuss the possibility of merge, but would be fine if we decide to never merge this.
Security Considerations
None I can think of.
Documentation Considerations
Types were updated to attempt to document the effects of releasing Zalgo. Unfortunately the type of
managerOptions
and worker kind are not currently threaded through sufficiently to surface an incompatibility in options (promise returningcompareSyscalls
used with alocal
worker type).Testing Considerations
Manually through the replay tool's new option.