Bug 261403

Summary: WASM should not depend on JIT
Product: WebKit Reporter: Ross Kirsling <ross.kirsling>
Component: JavaScriptCoreAssignee: Ross Kirsling <ross.kirsling>
Status: NEW    
Severity: Normal CC: Hironori.Fujii, justin_michaud, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Bug Depends on: 267481    
Bug Blocks:    
Attachments:
Description Flags
Minimal changes to build (without implementing replacement functionality) none

Ross Kirsling
Reported 2023-09-11 04:18:46 PDT
We need an actual interpreter, not a technicality.
Attachments
Minimal changes to build (without implementing replacement functionality) (23.60 KB, patch)
2023-09-11 04:34 PDT, Ross Kirsling
no flags
Ross Kirsling
Comment 1 2023-09-11 04:34:20 PDT
Created attachment 467638 [details] Minimal changes to build (without implementing replacement functionality) Here's a patch showing what it takes to build with !ENABLE(JIT) && ENABLE(WEBASSEMBLY) at current HEAD. Many of these changes really are places where we're assuming that ENABLE(WEBASSEMBLY) implies ENABLE(JIT) and thus could be landed separately if we wanted. (Note that IPInt is presently WIP so I have nothing I can say about it.) --- This patch is obviously not meant to be run; in order to make this actually work, we'll at a minimum need to migrate two JIT thunks to offlineasm: 1. "JS->WebAssembly entrypoint[i]" (which handles the args and result for each call) is the big daunting thing, since it amounts to all of JSToWasm.cpp. 2. "Wasm LLInt entry thunks" in LLIntPlan::didCompleteCompilation (a single thunk providing a jump label for each LLIntCallee) is much smaller to translate but less clear how to connect up. Presumably we still make our vector of callees as usual in WasmLLIntPlan.cpp (no JIT involved there), but there's an llint op which references the appropriate callee (somehow), stores a pointer to it on the stack, and jumps to wasm_function_prologue? There's also the IC stuff, but that can be safely postponed to a ticket beyond this one.
Radar WebKit Bug Importer
Comment 2 2023-09-18 04:19:13 PDT
Justin Michaud
Comment 3 2024-04-12 13:36:53 PDT
This patch does the first step to making this work, and can run some simple wasm in the no jit case: https://bugs.webkit.org/show_bug.cgi?id=267481
Justin Michaud
Comment 4 2024-04-12 13:38:36 PDT
I have assigned this to you Ross, since I think you should be able to land much of this and have it run now without too much work
Note You need to log in before you can comment on or make changes to this bug.