summaryrefslogtreecommitdiffstats
path: root/js/src/jit-test/lib/codegen-x86-test.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/src/jit-test/lib/codegen-x86-test.js')
-rw-r--r--js/src/jit-test/lib/codegen-x86-test.js84
1 files changed, 84 insertions, 0 deletions
diff --git a/js/src/jit-test/lib/codegen-x86-test.js b/js/src/jit-test/lib/codegen-x86-test.js
new file mode 100644
index 0000000000..edf3e916fb
--- /dev/null
+++ b/js/src/jit-test/lib/codegen-x86-test.js
@@ -0,0 +1,84 @@
+// Scaffolding for testing x86 Ion code generation patterns . See
+// codegen-x64-test.js in this directory for more information.
+
+load(libdir + "codegen-test-common.js");
+
+// Note that Zydis disassembles x86 absolute addresses as relative, so
+// the binary encoding and the text encoding may not correspond precisely.
+
+// Absolute address (disp32) following the instruction mnemonic.
+var ABS = `0x${HEXES}`;
+
+// Absolute address (disp32) in the binary encoding.
+var ABSADDR = `${HEX}{2} ${HEX}{2} ${HEX}{2} ${HEX}{2}`;
+
+// End of prologue. The mov to eax is debug code, inserted by the register
+// allocator to clobber eax before a move group. But it is only present if
+// there is a move group there.
+//
+// -0x21524111 is 0xDEADBEEF.
+var x86_prefix = `
+8b ec mov %esp, %ebp(
+b8 ef be ad de mov \\$-0x21524111, %eax)?
+`
+
+// `.bp` because zydis chooses 'rbp' even on 32-bit systems
+var x86_loadarg0 = `
+f3 0f 6f 45 ${HEX}{2} movdqux 0x${HEXES}\\(%.bp\\), %xmm0
+`;
+
+// Start of epilogue. `.bp` for the same reason as above.
+var x86_suffix = `5d pop %.bp`;
+
+// v128 OP literal -> v128
+// inputs: [[complete-opname, rhs-literal, expected-pattern], ...]
+function codegenTestX86_v128xLITERAL_v128(inputs, options = {}) {
+ for ( let [op, literal, expected] of inputs ) {
+ codegenTestX86_adhoc(wrap(options, `
+ (func (export "f") (param v128) (result v128)
+ (${op} (local.get 0) ${literal}))`),
+ 'f',
+ x86_loadarg0 + expected,
+ options)
+ }
+}
+
+// For when nothing else applies: `module_text` is the complete source text of
+// the module, `export_name` is the name of the function to be tested,
+// `expected` is the non-preprocessed pattern, and options is an options bag,
+// described above.
+function codegenTestX86_adhoc(module_text, export_name, expected, options = {}) {
+ assertEq(hasDisassembler(), true);
+
+ let ins = wasmEvalText(module_text);
+ let output = wasmDis(ins.exports[export_name], {tier:"ion", asString:true});
+
+ const expected_initial = expected;
+ if (!options.no_prefix)
+ expected = x86_prefix + '\n' + expected;
+ if (!options.no_suffix)
+ expected = expected + '\n' + x86_suffix;
+ expected = fixlines(expected);
+
+ const output_matches_expected = output.match(new RegExp(expected)) != null;
+ if (!output_matches_expected) {
+ print("---- codegen-x86-test.js: TEST FAILED ----");
+ }
+ if (options.log && output_matches_expected) {
+ print("---- codegen-x86-test.js: TEST PASSED ----");
+ }
+ if (options.log || !output_matches_expected) {
+ print("---- module text");
+ print(module_text);
+ print("---- actual");
+ print(output);
+ print("---- expected (initial)");
+ print(expected_initial);
+ print("---- expected (as used)");
+ print(expected);
+ print("----");
+ }
+
+ assertEq(output_matches_expected, true);
+}
+