This repository has been archived by the owner on Aug 2, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
B3 JIT (WebKit)
Kunshan Wang edited this page Feb 19, 2016
·
5 revisions
Original blog: https://webkit.org/blog/5852/introducing-the-b3-jit-compiler/
WebKit's FTL JIT now uses a new backend called B3 (Bare Bone Backend), which replaces LLVM as the low-level optimizer. This layer shares many principles with the Mu micro VM, most notably the role as a low-level substrate of a virtual machine.
This Wiki page will discuss the B3 JIT and its influence to the Mu micro VM.
motivation
- B3: LLVM is powerful but slow. It takes up 3/4 of the optimisation time. B3 should be 10 times faster than LLVM while still operate the same level of granularity as LLVM and do the same kind of optimisations LLVM does.
- Mu: Mu abstracts over concurrency, JIT and GC, but offloads most optimisations to the client.
size of the IR
- B3: Focus on the size (memory footprint) of the IRs, and the number of IRs (levels). Much effort is made to design a compact representation that is also fast to traverse and transform.
- Mu: Not designed with memory footprint in mind. The in-memory representation of the IR is an implementation detail.
type system
- B3 IR: void, int32, int64, float, double. No heap references. No aggregate types. Integers are used as addresses.
- Mu IR: Has object references, pointers, aggregate types, etc.
basic operations
- Both B3 and Mu IR have BinOps, Comparisons, Conversions, Branch and Switch. Both B3 and Mu use the goto-with-values form (B3 uses "Upsilon functions" to "assign" values to Phi-nodes.).
Function call
-
B3: Can only call C functions (
CCall
). Custom calling conventions are possible via Patchpoints. -
Mu: Can call both Mu functions (
CALL
) and C functions (CCALL
). Mu implementations may support more calling conventions in addition to the C callconv, but the client cannot customise it.
Memory operations
- B3: Load and Store with either Int32 or Int64 as addresses.
-
Mu: Load, Store, CmpXchg and AtomicRMW with
iref<T>
orptr<T>
.ptr<T>
can be converted fromint<n>
.
GC
- B3: Does not abstract over GC.
- Mu: It does.