summaryrefslogtreecommitdiff
path: root/test/wasm2js/reinterpret.2asm.js
diff options
context:
space:
mode:
authorAlon Zakai <azakai@google.com>2019-04-30 20:30:03 -0700
committerGitHub <noreply@github.com>2019-04-30 20:30:03 -0700
commit8d4bcd6e02bb0df3ac87e4850896ba733525b055 (patch)
tree1f98b878c22fd23c918992b53fd8e9f4f78d3788 /test/wasm2js/reinterpret.2asm.js
parentfba743ca5bdfe4fb437a36503b8983c5f42e4575 (diff)
downloadbinaryen-8d4bcd6e02bb0df3ac87e4850896ba733525b055.tar.gz
binaryen-8d4bcd6e02bb0df3ac87e4850896ba733525b055.tar.bz2
binaryen-8d4bcd6e02bb0df3ac87e4850896ba733525b055.zip
wasm2js: run full optimizations during the pipeline (#2071)
We flatten for the i64 lowering etc. passes, and it is worth optimizing afterwards, to clean up stuff they created. That is run if the user ran wasm2js with an optimization level (like wasm2js -O3). Split the test files to check both optimized and unoptimized code.
Diffstat (limited to 'test/wasm2js/reinterpret.2asm.js')
-rw-r--r--test/wasm2js/reinterpret.2asm.js20
1 files changed, 11 insertions, 9 deletions
diff --git a/test/wasm2js/reinterpret.2asm.js b/test/wasm2js/reinterpret.2asm.js
index 478040d79..d53c50bab 100644
--- a/test/wasm2js/reinterpret.2asm.js
+++ b/test/wasm2js/reinterpret.2asm.js
@@ -63,15 +63,17 @@ function asmFunc(global, env, buffer) {
i64toi32_i32$0 = $0$hi;
wasm2js_scratch_store_i32(0 | 0, $0 | 0);
wasm2js_scratch_store_i32(1 | 0, i64toi32_i32$0 | 0);
- wasm2js_scratch_store_f64(+wasm2js_scratch_load_f64());
+ wasm2js_scratch_store_f64(+(+wasm2js_scratch_load_f64()));
i64toi32_i32$0 = wasm2js_scratch_load_i32(1 | 0) | 0;
$3$hi = i64toi32_i32$0;
i64toi32_i32$0 = $0$hi;
i64toi32_i32$0 = $3$hi;
- return (wasm2js_scratch_load_i32(0 | 0) | 0) == ($0 | 0) & (i64toi32_i32$0 | 0) == ($0$hi | 0);
+ return (wasm2js_scratch_load_i32(0 | 0) | 0 | 0) == ($0 | 0) & (i64toi32_i32$0 | 0) == ($0$hi | 0) | 0 | 0;
}
function legalstub$2($0, $1_1) {
+ $0 = $0 | 0;
+ $1_1 = $1_1 | 0;
var i64toi32_i32$2 = 0, i64toi32_i32$0 = 0, i64toi32_i32$1 = 0, i64toi32_i32$4 = 0, i64toi32_i32$3 = 0, $10 = 0, $3 = 0, $3$hi = 0, $6$hi = 0;
i64toi32_i32$0 = 0;
$3 = $0;
@@ -80,16 +82,16 @@ function asmFunc(global, env, buffer) {
i64toi32_i32$2 = $1_1;
i64toi32_i32$1 = 0;
i64toi32_i32$3 = 32;
- i64toi32_i32$4 = i64toi32_i32$3 & 31;
- if (32 >>> 0 <= (i64toi32_i32$3 & 63) >>> 0) {
+ i64toi32_i32$4 = i64toi32_i32$3 & 31 | 0;
+ if (32 >>> 0 <= (i64toi32_i32$3 & 63 | 0) >>> 0) {
{
- i64toi32_i32$1 = i64toi32_i32$2 << i64toi32_i32$4;
+ i64toi32_i32$1 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
$10 = 0;
}
} else {
{
- i64toi32_i32$1 = (1 << i64toi32_i32$4) - 1 & i64toi32_i32$2 >>> 32 - i64toi32_i32$4 | i64toi32_i32$0 << i64toi32_i32$4;
- $10 = i64toi32_i32$2 << i64toi32_i32$4;
+ i64toi32_i32$1 = ((1 << i64toi32_i32$4 | 0) - 1 | 0) & (i64toi32_i32$2 >>> (32 - i64toi32_i32$4 | 0) | 0) | 0 | (i64toi32_i32$0 << i64toi32_i32$4 | 0) | 0;
+ $10 = i64toi32_i32$2 << i64toi32_i32$4 | 0;
}
}
$6$hi = i64toi32_i32$1;
@@ -97,8 +99,8 @@ function asmFunc(global, env, buffer) {
i64toi32_i32$0 = $3;
i64toi32_i32$2 = $6$hi;
i64toi32_i32$3 = $10;
- i64toi32_i32$2 = i64toi32_i32$1 | i64toi32_i32$2;
- return $2(i64toi32_i32$0 | i64toi32_i32$3, i64toi32_i32$2);
+ i64toi32_i32$2 = i64toi32_i32$1 | i64toi32_i32$2 | 0;
+ return $2(i64toi32_i32$0 | i64toi32_i32$3 | 0 | 0, i64toi32_i32$2 | 0) | 0 | 0;
}
var FUNCTION_TABLE = [];