diff options
Diffstat (limited to 'js/src/jit-test/tests/wasm/README-codegen.md')
-rw-r--r-- | js/src/jit-test/tests/wasm/README-codegen.md | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/js/src/jit-test/tests/wasm/README-codegen.md b/js/src/jit-test/tests/wasm/README-codegen.md new file mode 100644 index 0000000000..007063c20a --- /dev/null +++ b/js/src/jit-test/tests/wasm/README-codegen.md @@ -0,0 +1,36 @@ +About whitebox code generation tests (*-codegen.js) in this dir and +the simd subdir. + +Whitebox codegen tests test a couple of things: + +- that the best instructions are selected under ideal conditions: + showing that the instruction selector at least knows about these + instructions. + +- that extraneous moves are not inserted by the register allocator or + code generator under ideal conditions: when it is in principle + possible for the code generator and register allocator to use inputs + where they are and generate outputs directly in the target + registers. + +These tests are both limited in scope and brittle in the face of +changes to the register allocator and instruction selector, but how +else would we test that code generation and register allocation work +when presented with the easiest case? And if they don't work then, +when will they work? + +For a reliable test, the inputs must be known to be in the fixed +parameter registers and the result must be known to be desired in the +fixed function result register. + +Sometimes, to test optimal codegen, we need the inputs to be in +reversed or permuted locations so as to avoid generating moves that +are inserted by the regalloc to adapt to the function signature, or +there need to be some dummy parameter registers that are not used. + +In the test cases, the expected output is expressed as a multi-line +regular expression. The first line of each expected output is the +tail end of the prologue; subsequent lines comprise the operation; +finally there is the beginning of the epilogue. Sometimes there is +only the end of the prologue and the beginning of the operation, as +the operation is long and we don't care about its tail. |