summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/passes/alignment-lowering.txt544
-rw-r--r--test/passes/alignment-lowering.wast63
-rw-r--r--test/wasm2js/address.2asm.js13
-rw-r--r--test/wasm2js/unaligned.2asm.js76
-rw-r--r--test/wasm2js/unaligned.2asm.js.opt66
5 files changed, 711 insertions, 51 deletions
diff --git a/test/passes/alignment-lowering.txt b/test/passes/alignment-lowering.txt
new file mode 100644
index 000000000..fefb128f7
--- /dev/null
+++ b/test/passes/alignment-lowering.txt
@@ -0,0 +1,544 @@
+(module
+ (type $0 (func))
+ (memory $0 1 1)
+ (func $func_4 (; 0 ;) (type $0)
+ (local $0 i32)
+ (local $1 i32)
+ (local $2 i32)
+ (local $3 i32)
+ (local $4 i32)
+ (local $5 i32)
+ (local $6 i32)
+ (local $7 i32)
+ (local $8 i32)
+ (local $9 i32)
+ (local $10 i32)
+ (local $11 i32)
+ (drop
+ (i32.load
+ (i32.const 4)
+ )
+ )
+ (drop
+ (block (result i32)
+ (local.set $0
+ (i32.const 4)
+ )
+ (i32.or
+ (i32.or
+ (i32.load8_u
+ (local.get $0)
+ )
+ (i32.shl
+ (i32.load8_u offset=1
+ (local.get $0)
+ )
+ (i32.const 8)
+ )
+ )
+ (i32.or
+ (i32.shl
+ (i32.load8_u offset=2
+ (local.get $0)
+ )
+ (i32.const 16)
+ )
+ (i32.shl
+ (i32.load8_u offset=3
+ (local.get $0)
+ )
+ (i32.const 24)
+ )
+ )
+ )
+ )
+ )
+ (drop
+ (block (result i32)
+ (local.set $1
+ (i32.const 4)
+ )
+ (i32.or
+ (i32.load16_u
+ (local.get $1)
+ )
+ (i32.shl
+ (i32.load16_u offset=2
+ (local.get $1)
+ )
+ (i32.const 16)
+ )
+ )
+ )
+ )
+ (drop
+ (i32.load
+ (i32.const 4)
+ )
+ )
+ (drop
+ (i32.load offset=100
+ (i32.const 4)
+ )
+ )
+ (drop
+ (block (result i32)
+ (local.set $2
+ (i32.const 4)
+ )
+ (i32.or
+ (i32.or
+ (i32.load8_u offset=100
+ (local.get $2)
+ )
+ (i32.shl
+ (i32.load8_u offset=101
+ (local.get $2)
+ )
+ (i32.const 8)
+ )
+ )
+ (i32.or
+ (i32.shl
+ (i32.load8_u offset=102
+ (local.get $2)
+ )
+ (i32.const 16)
+ )
+ (i32.shl
+ (i32.load8_u offset=103
+ (local.get $2)
+ )
+ (i32.const 24)
+ )
+ )
+ )
+ )
+ )
+ (drop
+ (block (result i32)
+ (local.set $3
+ (i32.const 4)
+ )
+ (i32.or
+ (i32.load16_u offset=100
+ (local.get $3)
+ )
+ (i32.shl
+ (i32.load16_u offset=102
+ (local.get $3)
+ )
+ (i32.const 16)
+ )
+ )
+ )
+ )
+ (drop
+ (i32.load offset=100
+ (i32.const 4)
+ )
+ )
+ (drop
+ (unreachable)
+ )
+ (i32.store
+ (i32.const 4)
+ (i32.const 8)
+ )
+ (block
+ (local.set $4
+ (i32.const 4)
+ )
+ (local.set $5
+ (i32.const 8)
+ )
+ (i32.store8
+ (local.get $4)
+ (local.get $5)
+ )
+ (i32.store8 offset=1
+ (local.get $4)
+ (i32.shr_u
+ (local.get $5)
+ (i32.const 8)
+ )
+ )
+ (i32.store8 offset=2
+ (local.get $4)
+ (i32.shr_u
+ (local.get $5)
+ (i32.const 16)
+ )
+ )
+ (i32.store8 offset=3
+ (local.get $4)
+ (i32.shr_u
+ (local.get $5)
+ (i32.const 24)
+ )
+ )
+ )
+ (block
+ (local.set $6
+ (i32.const 4)
+ )
+ (local.set $7
+ (i32.const 8)
+ )
+ (i32.store16
+ (local.get $6)
+ (local.get $7)
+ )
+ (i32.store16 offset=2
+ (local.get $6)
+ (i32.shr_u
+ (local.get $7)
+ (i32.const 16)
+ )
+ )
+ )
+ (i32.store
+ (i32.const 4)
+ (i32.const 8)
+ )
+ (i32.store offset=100
+ (i32.const 4)
+ (i32.const 8)
+ )
+ (block
+ (local.set $8
+ (i32.const 4)
+ )
+ (local.set $9
+ (i32.const 8)
+ )
+ (i32.store8 offset=100
+ (local.get $8)
+ (local.get $9)
+ )
+ (i32.store8 offset=101
+ (local.get $8)
+ (i32.shr_u
+ (local.get $9)
+ (i32.const 8)
+ )
+ )
+ (i32.store8 offset=102
+ (local.get $8)
+ (i32.shr_u
+ (local.get $9)
+ (i32.const 16)
+ )
+ )
+ (i32.store8 offset=103
+ (local.get $8)
+ (i32.shr_u
+ (local.get $9)
+ (i32.const 24)
+ )
+ )
+ )
+ (block
+ (local.set $10
+ (i32.const 4)
+ )
+ (local.set $11
+ (i32.const 8)
+ )
+ (i32.store16 offset=100
+ (local.get $10)
+ (local.get $11)
+ )
+ (i32.store16 offset=102
+ (local.get $10)
+ (i32.shr_u
+ (local.get $11)
+ (i32.const 16)
+ )
+ )
+ )
+ (i32.store offset=100
+ (i32.const 4)
+ (i32.const 8)
+ )
+ (block
+ (drop
+ (unreachable)
+ )
+ (drop
+ (i32.const 8)
+ )
+ )
+ (block
+ (drop
+ (i32.const 4)
+ )
+ (drop
+ (unreachable)
+ )
+ )
+ )
+ (func $func_2 (; 1 ;) (type $0)
+ (local $0 i32)
+ (local $1 i32)
+ (local $2 i32)
+ (local $3 i32)
+ (local $4 i32)
+ (local $5 i32)
+ (drop
+ (i32.load16_u
+ (i32.const 4)
+ )
+ )
+ (drop
+ (block (result i32)
+ (local.set $0
+ (i32.const 4)
+ )
+ (i32.or
+ (i32.load8_u
+ (local.get $0)
+ )
+ (i32.shl
+ (i32.load8_u offset=1
+ (local.get $0)
+ )
+ (i32.const 8)
+ )
+ )
+ )
+ )
+ (drop
+ (i32.load16_u
+ (i32.const 4)
+ )
+ )
+ (drop
+ (i32.load16_u offset=100
+ (i32.const 4)
+ )
+ )
+ (drop
+ (block (result i32)
+ (local.set $1
+ (i32.const 4)
+ )
+ (i32.or
+ (i32.load8_u offset=100
+ (local.get $1)
+ )
+ (i32.shl
+ (i32.load8_u offset=101
+ (local.get $1)
+ )
+ (i32.const 8)
+ )
+ )
+ )
+ )
+ (drop
+ (i32.load16_u offset=100
+ (i32.const 4)
+ )
+ )
+ (drop
+ (unreachable)
+ )
+ (i32.store16
+ (i32.const 4)
+ (i32.const 8)
+ )
+ (block
+ (local.set $2
+ (i32.const 4)
+ )
+ (local.set $3
+ (i32.const 8)
+ )
+ (i32.store8
+ (local.get $2)
+ (local.get $3)
+ )
+ (i32.store8 offset=1
+ (local.get $2)
+ (i32.shr_u
+ (local.get $3)
+ (i32.const 8)
+ )
+ )
+ )
+ (i32.store16
+ (i32.const 4)
+ (i32.const 8)
+ )
+ (i32.store16 offset=100
+ (i32.const 4)
+ (i32.const 8)
+ )
+ (block
+ (local.set $4
+ (i32.const 4)
+ )
+ (local.set $5
+ (i32.const 8)
+ )
+ (i32.store8 offset=100
+ (local.get $4)
+ (local.get $5)
+ )
+ (i32.store8 offset=101
+ (local.get $4)
+ (i32.shr_u
+ (local.get $5)
+ (i32.const 8)
+ )
+ )
+ )
+ (i32.store16 offset=100
+ (i32.const 4)
+ (i32.const 8)
+ )
+ (block
+ (drop
+ (unreachable)
+ )
+ (drop
+ (i32.const 8)
+ )
+ )
+ (block
+ (drop
+ (i32.const 4)
+ )
+ (drop
+ (unreachable)
+ )
+ )
+ )
+ (func $func_1 (; 2 ;) (type $0)
+ (drop
+ (i32.load8_u
+ (i32.const 4)
+ )
+ )
+ (drop
+ (i32.load8_u
+ (i32.const 4)
+ )
+ )
+ (drop
+ (i32.load8_u offset=100
+ (i32.const 4)
+ )
+ )
+ (drop
+ (i32.load8_u offset=100
+ (i32.const 4)
+ )
+ )
+ (drop
+ (unreachable.load offset=100
+ (unreachable)
+ )
+ )
+ (i32.store8
+ (i32.const 4)
+ (i32.const 8)
+ )
+ (i32.store8
+ (i32.const 4)
+ (i32.const 8)
+ )
+ (i32.store8 offset=100
+ (i32.const 4)
+ (i32.const 8)
+ )
+ (i32.store8 offset=100
+ (i32.const 4)
+ (i32.const 8)
+ )
+ (i32.store8 offset=100
+ (unreachable)
+ (i32.const 8)
+ )
+ (i32.store8 offset=100
+ (i32.const 4)
+ (unreachable)
+ )
+ )
+ (func $func_signed (; 3 ;) (type $0)
+ (local $0 i32)
+ (local $1 i32)
+ (drop
+ (i32.load16_s
+ (i32.const 4)
+ )
+ )
+ (drop
+ (block (result i32)
+ (local.set $0
+ (i32.const 4)
+ )
+ (i32.shr_s
+ (i32.shl
+ (i32.or
+ (i32.load8_u
+ (local.get $0)
+ )
+ (i32.shl
+ (i32.load8_u offset=1
+ (local.get $0)
+ )
+ (i32.const 8)
+ )
+ )
+ (i32.const 16)
+ )
+ (i32.const 16)
+ )
+ )
+ )
+ (drop
+ (i32.load16_s
+ (i32.const 4)
+ )
+ )
+ (drop
+ (i32.load16_s offset=100
+ (i32.const 4)
+ )
+ )
+ (drop
+ (block (result i32)
+ (local.set $1
+ (i32.const 4)
+ )
+ (i32.shr_s
+ (i32.shl
+ (i32.or
+ (i32.load8_u offset=100
+ (local.get $1)
+ )
+ (i32.shl
+ (i32.load8_u offset=101
+ (local.get $1)
+ )
+ (i32.const 8)
+ )
+ )
+ (i32.const 16)
+ )
+ (i32.const 16)
+ )
+ )
+ )
+ (drop
+ (i32.load16_s offset=100
+ (i32.const 4)
+ )
+ )
+ (drop
+ (unreachable)
+ )
+ )
+)
diff --git a/test/passes/alignment-lowering.wast b/test/passes/alignment-lowering.wast
new file mode 100644
index 000000000..135fd281e
--- /dev/null
+++ b/test/passes/alignment-lowering.wast
@@ -0,0 +1,63 @@
+(module
+ (memory $0 1 1)
+ (func $func_4
+ (drop (i32.load (i32.const 4)))
+ (drop (i32.load align=1 (i32.const 4)))
+ (drop (i32.load align=2 (i32.const 4)))
+ (drop (i32.load align=4 (i32.const 4)))
+ (drop (i32.load offset=100 (i32.const 4)))
+ (drop (i32.load offset=100 align=1 (i32.const 4)))
+ (drop (i32.load offset=100 align=2 (i32.const 4)))
+ (drop (i32.load offset=100 align=4 (i32.const 4)))
+ (drop (i32.load offset=100 align=1 (unreachable)))
+ (i32.store (i32.const 4) (i32.const 8))
+ (i32.store align=1 (i32.const 4) (i32.const 8))
+ (i32.store align=2 (i32.const 4) (i32.const 8))
+ (i32.store align=4 (i32.const 4) (i32.const 8))
+ (i32.store offset=100 (i32.const 4) (i32.const 8))
+ (i32.store offset=100 align=1 (i32.const 4) (i32.const 8))
+ (i32.store offset=100 align=2 (i32.const 4) (i32.const 8))
+ (i32.store offset=100 align=4 (i32.const 4) (i32.const 8))
+ (i32.store offset=100 align=1 (unreachable) (i32.const 8))
+ (i32.store offset=100 align=1 (i32.const 4) (unreachable))
+ )
+ (func $func_2
+ (drop (i32.load16_u (i32.const 4)))
+ (drop (i32.load16_u align=1 (i32.const 4)))
+ (drop (i32.load16_u align=2 (i32.const 4)))
+ (drop (i32.load16_u offset=100 (i32.const 4)))
+ (drop (i32.load16_u offset=100 align=1 (i32.const 4)))
+ (drop (i32.load16_u offset=100 align=2 (i32.const 4)))
+ (drop (i32.load16_u offset=100 align=1 (unreachable)))
+ (i32.store16 (i32.const 4) (i32.const 8))
+ (i32.store16 align=1 (i32.const 4) (i32.const 8))
+ (i32.store16 align=2 (i32.const 4) (i32.const 8))
+ (i32.store16 offset=100 (i32.const 4) (i32.const 8))
+ (i32.store16 offset=100 align=1 (i32.const 4) (i32.const 8))
+ (i32.store16 offset=100 align=2 (i32.const 4) (i32.const 8))
+ (i32.store16 offset=100 align=1 (unreachable) (i32.const 8))
+ (i32.store16 offset=100 align=1 (i32.const 4) (unreachable))
+ )
+ (func $func_1
+ (drop (i32.load8_u (i32.const 4)))
+ (drop (i32.load8_u align=1 (i32.const 4)))
+ (drop (i32.load8_u offset=100 (i32.const 4)))
+ (drop (i32.load8_u offset=100 align=1 (i32.const 4)))
+ (drop (i32.load8_u offset=100 align=1 (unreachable)))
+ (i32.store8 (i32.const 4) (i32.const 8))
+ (i32.store8 align=1 (i32.const 4) (i32.const 8))
+ (i32.store8 offset=100 (i32.const 4) (i32.const 8))
+ (i32.store8 offset=100 align=1 (i32.const 4) (i32.const 8))
+ (i32.store8 offset=100 align=1 (unreachable) (i32.const 8))
+ (i32.store8 offset=100 align=1 (i32.const 4) (unreachable))
+ )
+ (func $func_signed
+ (drop (i32.load16_s (i32.const 4)))
+ (drop (i32.load16_s align=1 (i32.const 4)))
+ (drop (i32.load16_s align=2 (i32.const 4)))
+ (drop (i32.load16_s offset=100 (i32.const 4)))
+ (drop (i32.load16_s offset=100 align=1 (i32.const 4)))
+ (drop (i32.load16_s offset=100 align=2 (i32.const 4)))
+ (drop (i32.load16_s offset=100 align=1 (unreachable)))
+ )
+)
diff --git a/test/wasm2js/address.2asm.js b/test/wasm2js/address.2asm.js
index 3863702fd..fe8805d52 100644
--- a/test/wasm2js/address.2asm.js
+++ b/test/wasm2js/address.2asm.js
@@ -25,20 +25,19 @@ function asmFunc(global, env, buffer) {
var print = env.print;
function $0(i) {
i = i | 0;
- var wasm2js_i32$0 = 0;
print(HEAPU8[i >> 0] | 0 | 0);
print(HEAPU8[(i + 1 | 0) >> 0] | 0 | 0);
print(HEAPU8[(i + 2 | 0) >> 0] | 0 | 0);
print(HEAPU8[(i + 25 | 0) >> 0] | 0 | 0);
print(HEAPU16[i >> 1] | 0 | 0);
- print((wasm2js_i32$0 = i, HEAPU8[wasm2js_i32$0 >> 0] | 0 | 0 | (HEAPU8[(wasm2js_i32$0 + 1 | 0) >> 0] | 0 | 0) << 8) | 0);
- print((wasm2js_i32$0 = i, HEAPU8[(wasm2js_i32$0 + 1 | 0) >> 0] | 0 | 0 | (HEAPU8[(wasm2js_i32$0 + 2 | 0) >> 0] | 0 | 0) << 8) | 0);
+ print(HEAPU8[i >> 0] | 0 | ((HEAPU8[(i + 1 | 0) >> 0] | 0) << 8 | 0) | 0 | 0);
+ print(HEAPU8[(i + 1 | 0) >> 0] | 0 | ((HEAPU8[(i + 2 | 0) >> 0] | 0) << 8 | 0) | 0 | 0);
print(HEAPU16[(i + 2 | 0) >> 1] | 0 | 0);
- print((wasm2js_i32$0 = i, HEAPU8[(wasm2js_i32$0 + 25 | 0) >> 0] | 0 | 0 | (HEAPU8[(wasm2js_i32$0 + 26 | 0) >> 0] | 0 | 0) << 8) | 0);
+ print(HEAPU8[(i + 25 | 0) >> 0] | 0 | ((HEAPU8[(i + 26 | 0) >> 0] | 0) << 8 | 0) | 0 | 0);
print(HEAP32[i >> 2] | 0 | 0);
- print((wasm2js_i32$0 = i, HEAPU8[(wasm2js_i32$0 + 1 | 0) >> 0] | 0 | 0 | (HEAPU8[(wasm2js_i32$0 + 2 | 0) >> 0] | 0 | 0) << 8 | (HEAPU8[(wasm2js_i32$0 + 3 | 0) >> 0] | 0 | 0) << 16 | (HEAPU8[(wasm2js_i32$0 + 4 | 0) >> 0] | 0 | 0) << 24) | 0);
- print((wasm2js_i32$0 = i, HEAPU8[(wasm2js_i32$0 + 2 | 0) >> 0] | 0 | 0 | (HEAPU8[(wasm2js_i32$0 + 3 | 0) >> 0] | 0 | 0) << 8 | (HEAPU8[(wasm2js_i32$0 + 4 | 0) >> 0] | 0 | 0) << 16 | (HEAPU8[(wasm2js_i32$0 + 5 | 0) >> 0] | 0 | 0) << 24) | 0);
- print((wasm2js_i32$0 = i, HEAPU8[(wasm2js_i32$0 + 25 | 0) >> 0] | 0 | 0 | (HEAPU8[(wasm2js_i32$0 + 26 | 0) >> 0] | 0 | 0) << 8 | (HEAPU8[(wasm2js_i32$0 + 27 | 0) >> 0] | 0 | 0) << 16 | (HEAPU8[(wasm2js_i32$0 + 28 | 0) >> 0] | 0 | 0) << 24) | 0);
+ print(HEAPU8[(i + 1 | 0) >> 0] | 0 | ((HEAPU8[(i + 2 | 0) >> 0] | 0) << 8 | 0) | 0 | ((HEAPU8[(i + 3 | 0) >> 0] | 0) << 16 | 0 | ((HEAPU8[(i + 4 | 0) >> 0] | 0) << 24 | 0) | 0) | 0 | 0);
+ print(HEAPU16[(i + 2 | 0) >> 1] | 0 | ((HEAPU16[(i + 4 | 0) >> 1] | 0) << 16 | 0) | 0 | 0);
+ print(HEAPU8[(i + 25 | 0) >> 0] | 0 | ((HEAPU8[(i + 26 | 0) >> 0] | 0) << 8 | 0) | 0 | ((HEAPU8[(i + 27 | 0) >> 0] | 0) << 16 | 0 | ((HEAPU8[(i + 28 | 0) >> 0] | 0) << 24 | 0) | 0) | 0 | 0);
}
function $1(i) {
diff --git a/test/wasm2js/unaligned.2asm.js b/test/wasm2js/unaligned.2asm.js
index 1fd503ff9..be8c10320 100644
--- a/test/wasm2js/unaligned.2asm.js
+++ b/test/wasm2js/unaligned.2asm.js
@@ -55,57 +55,85 @@ function asmFunc(global, env, buffer) {
var setTempRet0 = env.setTempRet0;
var i64toi32_i32$HIGH_BITS = 0;
function $0() {
- var wasm2js_i32$0 = 0;
- return (wasm2js_i32$0 = 0, HEAPU8[wasm2js_i32$0 >> 0] | 0 | 0 | (HEAPU8[(wasm2js_i32$0 + 1 | 0) >> 0] | 0 | 0) << 8 | (HEAPU8[(wasm2js_i32$0 + 2 | 0) >> 0] | 0 | 0) << 16 | (HEAPU8[(wasm2js_i32$0 + 3 | 0) >> 0] | 0 | 0) << 24) | 0;
+ var $0_1 = 0;
+ $0_1 = 0;
+ return HEAPU8[$0_1 >> 0] | 0 | ((HEAPU8[($0_1 + 1 | 0) >> 0] | 0) << 8 | 0) | 0 | ((HEAPU8[($0_1 + 2 | 0) >> 0] | 0) << 16 | 0 | ((HEAPU8[($0_1 + 3 | 0) >> 0] | 0) << 24 | 0) | 0) | 0 | 0;
}
function $1() {
- var i64toi32_i32$2 = 0, i64toi32_i32$0 = 0, i64toi32_i32$1 = 0, wasm2js_i32$0 = 0;
- i64toi32_i32$2 = 0;
- i64toi32_i32$0 = (wasm2js_i32$0 = i64toi32_i32$2, HEAPU8[wasm2js_i32$0 >> 0] | 0 | 0 | (HEAPU8[(wasm2js_i32$0 + 1 | 0) >> 0] | 0 | 0) << 8 | (HEAPU8[(wasm2js_i32$0 + 2 | 0) >> 0] | 0 | 0) << 16 | (HEAPU8[(wasm2js_i32$0 + 3 | 0) >> 0] | 0 | 0) << 24);
- i64toi32_i32$1 = (wasm2js_i32$0 = i64toi32_i32$2, HEAPU8[(wasm2js_i32$0 + 4 | 0) >> 0] | 0 | 0 | (HEAPU8[(wasm2js_i32$0 + 5 | 0) >> 0] | 0 | 0) << 8 | (HEAPU8[(wasm2js_i32$0 + 6 | 0) >> 0] | 0 | 0) << 16 | (HEAPU8[(wasm2js_i32$0 + 7 | 0) >> 0] | 0 | 0) << 24);
+ var $2_1 = 0, i64toi32_i32$0 = 0, i64toi32_i32$1 = 0;
+ $2_1 = 0;
+ i64toi32_i32$0 = HEAPU8[$2_1 >> 0] | 0 | ((HEAPU8[($2_1 + 1 | 0) >> 0] | 0) << 8 | 0) | 0 | ((HEAPU8[($2_1 + 2 | 0) >> 0] | 0) << 16 | 0 | ((HEAPU8[($2_1 + 3 | 0) >> 0] | 0) << 24 | 0) | 0) | 0;
+ i64toi32_i32$1 = HEAPU8[($2_1 + 4 | 0) >> 0] | 0 | ((HEAPU8[($2_1 + 5 | 0) >> 0] | 0) << 8 | 0) | 0 | ((HEAPU8[($2_1 + 6 | 0) >> 0] | 0) << 16 | 0 | ((HEAPU8[($2_1 + 7 | 0) >> 0] | 0) << 24 | 0) | 0) | 0;
i64toi32_i32$HIGH_BITS = i64toi32_i32$1;
return i64toi32_i32$0 | 0;
}
function $2() {
- var wasm2js_i32$0 = 0;
- return Math_fround((wasm2js_scratch_store_i32(0, (wasm2js_i32$0 = 0, HEAPU8[wasm2js_i32$0 >> 0] | 0 | 0 | (HEAPU8[(wasm2js_i32$0 + 1 | 0) >> 0] | 0 | 0) << 8 | (HEAPU8[(wasm2js_i32$0 + 2 | 0) >> 0] | 0 | 0) << 16 | (HEAPU8[(wasm2js_i32$0 + 3 | 0) >> 0] | 0 | 0) << 24)), wasm2js_scratch_load_f32()));
+ var $0_1 = 0;
+ $0_1 = 0;
+ return Math_fround((wasm2js_scratch_store_i32(0, HEAPU8[$0_1 >> 0] | 0 | ((HEAPU8[($0_1 + 1 | 0) >> 0] | 0) << 8 | 0) | 0 | ((HEAPU8[($0_1 + 2 | 0) >> 0] | 0) << 16 | 0 | ((HEAPU8[($0_1 + 3 | 0) >> 0] | 0) << 24 | 0) | 0) | 0), wasm2js_scratch_load_f32()));
}
function $3() {
- var i64toi32_i32$2 = 0, i64toi32_i32$1 = 0, wasm2js_i32$0 = 0;
- i64toi32_i32$2 = 0;
- i64toi32_i32$1 = (wasm2js_i32$0 = i64toi32_i32$2, HEAPU8[(wasm2js_i32$0 + 4 | 0) >> 0] | 0 | 0 | (HEAPU8[(wasm2js_i32$0 + 5 | 0) >> 0] | 0 | 0) << 8 | (HEAPU8[(wasm2js_i32$0 + 6 | 0) >> 0] | 0 | 0) << 16 | (HEAPU8[(wasm2js_i32$0 + 7 | 0) >> 0] | 0 | 0) << 24);
- wasm2js_scratch_store_i32(0 | 0, (wasm2js_i32$0 = i64toi32_i32$2, HEAPU8[wasm2js_i32$0 >> 0] | 0 | 0 | (HEAPU8[(wasm2js_i32$0 + 1 | 0) >> 0] | 0 | 0) << 8 | (HEAPU8[(wasm2js_i32$0 + 2 | 0) >> 0] | 0 | 0) << 16 | (HEAPU8[(wasm2js_i32$0 + 3 | 0) >> 0] | 0 | 0) << 24) | 0);
+ var $1_1 = 0, i64toi32_i32$1 = 0;
+ $1_1 = 0;
+ i64toi32_i32$1 = HEAPU8[($1_1 + 4 | 0) >> 0] | 0 | ((HEAPU8[($1_1 + 5 | 0) >> 0] | 0) << 8 | 0) | 0 | ((HEAPU8[($1_1 + 6 | 0) >> 0] | 0) << 16 | 0 | ((HEAPU8[($1_1 + 7 | 0) >> 0] | 0) << 24 | 0) | 0) | 0;
+ wasm2js_scratch_store_i32(0 | 0, HEAPU8[$1_1 >> 0] | 0 | ((HEAPU8[($1_1 + 1 | 0) >> 0] | 0) << 8 | 0) | 0 | ((HEAPU8[($1_1 + 2 | 0) >> 0] | 0) << 16 | 0 | ((HEAPU8[($1_1 + 3 | 0) >> 0] | 0) << 24 | 0) | 0) | 0 | 0);
wasm2js_scratch_store_i32(1 | 0, i64toi32_i32$1 | 0);
return +(+wasm2js_scratch_load_f64());
}
function $4() {
- var wasm2js_i32$0 = 0, wasm2js_i32$1 = 0;
- (wasm2js_i32$0 = 0, wasm2js_i32$1 = 0), ((HEAP8[wasm2js_i32$0 >> 0] = wasm2js_i32$1 & 255 | 0, HEAP8[(wasm2js_i32$0 + 1 | 0) >> 0] = (wasm2js_i32$1 >>> 8 | 0) & 255 | 0), HEAP8[(wasm2js_i32$0 + 2 | 0) >> 0] = (wasm2js_i32$1 >>> 16 | 0) & 255 | 0), HEAP8[(wasm2js_i32$0 + 3 | 0) >> 0] = (wasm2js_i32$1 >>> 24 | 0) & 255 | 0;
+ var $0_1 = 0, $1_1 = 0;
+ $0_1 = 0;
+ $1_1 = 0;
+ HEAP8[$0_1 >> 0] = $1_1;
+ HEAP8[($0_1 + 1 | 0) >> 0] = $1_1 >>> 8 | 0;
+ HEAP8[($0_1 + 2 | 0) >> 0] = $1_1 >>> 16 | 0;
+ HEAP8[($0_1 + 3 | 0) >> 0] = $1_1 >>> 24 | 0;
}
function $5() {
- var i64toi32_i32$1 = 0, wasm2js_i32$0 = 0, wasm2js_i32$1 = 0;
- i64toi32_i32$1 = 0;
- (wasm2js_i32$0 = i64toi32_i32$1, wasm2js_i32$1 = 0), ((HEAP8[wasm2js_i32$0 >> 0] = wasm2js_i32$1 & 255 | 0, HEAP8[(wasm2js_i32$0 + 1 | 0) >> 0] = (wasm2js_i32$1 >>> 8 | 0) & 255 | 0), HEAP8[(wasm2js_i32$0 + 2 | 0) >> 0] = (wasm2js_i32$1 >>> 16 | 0) & 255 | 0), HEAP8[(wasm2js_i32$0 + 3 | 0) >> 0] = (wasm2js_i32$1 >>> 24 | 0) & 255 | 0;
- (wasm2js_i32$0 = i64toi32_i32$1, wasm2js_i32$1 = 0), ((HEAP8[(wasm2js_i32$0 + 4 | 0) >> 0] = wasm2js_i32$1 & 255 | 0, HEAP8[(wasm2js_i32$0 + 5 | 0) >> 0] = (wasm2js_i32$1 >>> 8 | 0) & 255 | 0), HEAP8[(wasm2js_i32$0 + 6 | 0) >> 0] = (wasm2js_i32$1 >>> 16 | 0) & 255 | 0), HEAP8[(wasm2js_i32$0 + 7 | 0) >> 0] = (wasm2js_i32$1 >>> 24 | 0) & 255 | 0;
+ var $0_1 = 0, $1_1 = 0, $2_1 = 0;
+ $0_1 = 0;
+ $1_1 = 0;
+ HEAP8[$0_1 >> 0] = $1_1;
+ HEAP8[($0_1 + 1 | 0) >> 0] = $1_1 >>> 8 | 0;
+ HEAP8[($0_1 + 2 | 0) >> 0] = $1_1 >>> 16 | 0;
+ HEAP8[($0_1 + 3 | 0) >> 0] = $1_1 >>> 24 | 0;
+ $2_1 = 0;
+ HEAP8[($0_1 + 4 | 0) >> 0] = $2_1;
+ HEAP8[($0_1 + 5 | 0) >> 0] = $2_1 >>> 8 | 0;
+ HEAP8[($0_1 + 6 | 0) >> 0] = $2_1 >>> 16 | 0;
+ HEAP8[($0_1 + 7 | 0) >> 0] = $2_1 >>> 24 | 0;
}
function $6() {
- var wasm2js_i32$0 = 0, wasm2js_i32$1 = 0;
- (wasm2js_i32$0 = 0, wasm2js_i32$1 = (wasm2js_scratch_store_f32(Math_fround(0.0)), wasm2js_scratch_load_i32(0))), ((HEAP8[wasm2js_i32$0 >> 0] = wasm2js_i32$1 & 255 | 0, HEAP8[(wasm2js_i32$0 + 1 | 0) >> 0] = (wasm2js_i32$1 >>> 8 | 0) & 255 | 0), HEAP8[(wasm2js_i32$0 + 2 | 0) >> 0] = (wasm2js_i32$1 >>> 16 | 0) & 255 | 0), HEAP8[(wasm2js_i32$0 + 3 | 0) >> 0] = (wasm2js_i32$1 >>> 24 | 0) & 255 | 0;
+ var $0_1 = 0, $1_1 = 0;
+ $0_1 = 0;
+ $1_1 = (wasm2js_scratch_store_f32(Math_fround(0.0)), wasm2js_scratch_load_i32(0));
+ HEAP8[$0_1 >> 0] = $1_1;
+ HEAP8[($0_1 + 1 | 0) >> 0] = $1_1 >>> 8 | 0;
+ HEAP8[($0_1 + 2 | 0) >> 0] = $1_1 >>> 16 | 0;
+ HEAP8[($0_1 + 3 | 0) >> 0] = $1_1 >>> 24 | 0;
}
function $7() {
- var i64toi32_i32$1 = 0, i64toi32_i32$0 = 0, wasm2js_i32$0 = 0, wasm2js_i32$1 = 0;
+ var $1_1 = 0, $2_1 = 0, $3_1 = 0, i64toi32_i32$0 = 0;
wasm2js_scratch_store_f64(+(0.0));
i64toi32_i32$0 = wasm2js_scratch_load_i32(1 | 0) | 0;
- i64toi32_i32$1 = 0;
- (wasm2js_i32$0 = i64toi32_i32$1, wasm2js_i32$1 = wasm2js_scratch_load_i32(0 | 0) | 0), ((HEAP8[wasm2js_i32$0 >> 0] = wasm2js_i32$1 & 255 | 0, HEAP8[(wasm2js_i32$0 + 1 | 0) >> 0] = (wasm2js_i32$1 >>> 8 | 0) & 255 | 0), HEAP8[(wasm2js_i32$0 + 2 | 0) >> 0] = (wasm2js_i32$1 >>> 16 | 0) & 255 | 0), HEAP8[(wasm2js_i32$0 + 3 | 0) >> 0] = (wasm2js_i32$1 >>> 24 | 0) & 255 | 0;
- (wasm2js_i32$0 = i64toi32_i32$1, wasm2js_i32$1 = i64toi32_i32$0), ((HEAP8[(wasm2js_i32$0 + 4 | 0) >> 0] = wasm2js_i32$1 & 255 | 0, HEAP8[(wasm2js_i32$0 + 5 | 0) >> 0] = (wasm2js_i32$1 >>> 8 | 0) & 255 | 0), HEAP8[(wasm2js_i32$0 + 6 | 0) >> 0] = (wasm2js_i32$1 >>> 16 | 0) & 255 | 0), HEAP8[(wasm2js_i32$0 + 7 | 0) >> 0] = (wasm2js_i32$1 >>> 24 | 0) & 255 | 0;
+ $1_1 = 0;
+ $2_1 = wasm2js_scratch_load_i32(0 | 0) | 0;
+ HEAP8[$1_1 >> 0] = $2_1;
+ HEAP8[($1_1 + 1 | 0) >> 0] = $2_1 >>> 8 | 0;
+ HEAP8[($1_1 + 2 | 0) >> 0] = $2_1 >>> 16 | 0;
+ HEAP8[($1_1 + 3 | 0) >> 0] = $2_1 >>> 24 | 0;
+ $3_1 = i64toi32_i32$0;
+ HEAP8[($1_1 + 4 | 0) >> 0] = $3_1;
+ HEAP8[($1_1 + 5 | 0) >> 0] = $3_1 >>> 8 | 0;
+ HEAP8[($1_1 + 6 | 0) >> 0] = $3_1 >>> 16 | 0;
+ HEAP8[($1_1 + 7 | 0) >> 0] = $3_1 >>> 24 | 0;
}
function legalstub$1() {
diff --git a/test/wasm2js/unaligned.2asm.js.opt b/test/wasm2js/unaligned.2asm.js.opt
index 448e35abd..8a069f083 100644
--- a/test/wasm2js/unaligned.2asm.js.opt
+++ b/test/wasm2js/unaligned.2asm.js.opt
@@ -51,48 +51,74 @@ function asmFunc(global, env, buffer) {
var setTempRet0 = env.setTempRet0;
var i64toi32_i32$HIGH_BITS = 0;
function $0() {
- var wasm2js_i32$0 = 0;
- return (wasm2js_i32$0 = 0, HEAPU8[wasm2js_i32$0 | 0] | HEAPU8[wasm2js_i32$0 + 1 | 0] << 8 | HEAPU8[wasm2js_i32$0 + 2 | 0] << 16 | HEAPU8[wasm2js_i32$0 + 3 | 0] << 24) | 0;
+ var $0_1 = 0;
+ return HEAPU8[0 | 0] | HEAPU8[$0_1 + 1 | 0] << 8 | (HEAPU8[$0_1 + 2 | 0] << 16 | HEAPU8[$0_1 + 3 | 0] << 24);
+ }
+
+ function $1() {
+ var $0_1 = 0, $1_1 = 0;
+ $0_1 = HEAPU8[0 | 0] | HEAPU8[$0_1 + 1 | 0] << 8 | (HEAPU8[$0_1 + 2 | 0] << 16 | HEAPU8[$0_1 + 3 | 0] << 24);
+ i64toi32_i32$HIGH_BITS = HEAPU8[$1_1 + 4 | 0] | HEAPU8[$1_1 + 5 | 0] << 8 | (HEAPU8[$1_1 + 6 | 0] << 16 | HEAPU8[$1_1 + 7 | 0] << 24);
+ return $0_1 | 0;
}
function $2() {
- var wasm2js_i32$0 = 0;
- return Math_fround((wasm2js_scratch_store_i32(0, (wasm2js_i32$0 = 0, HEAPU8[wasm2js_i32$0 | 0] | HEAPU8[wasm2js_i32$0 + 1 | 0] << 8 | HEAPU8[wasm2js_i32$0 + 2 | 0] << 16 | HEAPU8[wasm2js_i32$0 + 3 | 0] << 24)), wasm2js_scratch_load_f32()));
+ var $0_1 = 0;
+ return Math_fround((wasm2js_scratch_store_i32(0, HEAPU8[0 | 0] | HEAPU8[$0_1 + 1 | 0] << 8 | (HEAPU8[$0_1 + 2 | 0] << 16 | HEAPU8[$0_1 + 3 | 0] << 24)), wasm2js_scratch_load_f32()));
}
function $3() {
- var $0_1 = 0, wasm2js_i32$0 = 0;
- $0_1 = (wasm2js_i32$0 = $0_1, HEAPU8[wasm2js_i32$0 + 4 | 0] | HEAPU8[wasm2js_i32$0 + 5 | 0] << 8 | HEAPU8[wasm2js_i32$0 + 6 | 0] << 16 | HEAPU8[wasm2js_i32$0 + 7 | 0] << 24);
- wasm2js_scratch_store_i32(0 | 0, (wasm2js_i32$0 = 0, HEAPU8[wasm2js_i32$0 | 0] | HEAPU8[wasm2js_i32$0 + 1 | 0] << 8 | HEAPU8[wasm2js_i32$0 + 2 | 0] << 16 | HEAPU8[wasm2js_i32$0 + 3 | 0] << 24) | 0);
+ var $0_1 = 0, $1_1 = 0;
+ $1_1 = HEAPU8[0 | 0] | HEAPU8[$1_1 + 1 | 0] << 8 | (HEAPU8[$1_1 + 2 | 0] << 16 | HEAPU8[$1_1 + 3 | 0] << 24);
+ $0_1 = HEAPU8[$0_1 + 4 | 0] | HEAPU8[$0_1 + 5 | 0] << 8 | (HEAPU8[$0_1 + 6 | 0] << 16 | HEAPU8[$0_1 + 7 | 0] << 24);
+ wasm2js_scratch_store_i32(0 | 0, $1_1 | 0);
wasm2js_scratch_store_i32(1 | 0, $0_1 | 0);
return +wasm2js_scratch_load_f64();
}
function $4() {
- var wasm2js_i32$0 = 0, wasm2js_i32$1 = 0;
- (wasm2js_i32$0 = 0, wasm2js_i32$1 = 0), ((HEAP8[wasm2js_i32$0 | 0] = wasm2js_i32$1, HEAP8[wasm2js_i32$0 + 1 | 0] = wasm2js_i32$1 >>> 8), HEAP8[wasm2js_i32$0 + 2 | 0] = wasm2js_i32$1 >>> 16), HEAP8[wasm2js_i32$0 + 3 | 0] = wasm2js_i32$1 >>> 24;
+ var $0_1 = 0, $1_1 = 0;
+ HEAP8[0 | 0] = 0;
+ HEAP8[$0_1 + 1 | 0] = $1_1 >>> 8;
+ HEAP8[$0_1 + 2 | 0] = $1_1 >>> 16;
+ HEAP8[$0_1 + 3 | 0] = $1_1 >>> 24;
}
function $5() {
- var $0_1 = 0, wasm2js_i32$0 = 0, wasm2js_i32$1 = 0;
- (wasm2js_i32$0 = 0, wasm2js_i32$1 = 0), ((HEAP8[wasm2js_i32$0 | 0] = wasm2js_i32$1, HEAP8[wasm2js_i32$0 + 1 | 0] = wasm2js_i32$1 >>> 8), HEAP8[wasm2js_i32$0 + 2 | 0] = wasm2js_i32$1 >>> 16), HEAP8[wasm2js_i32$0 + 3 | 0] = wasm2js_i32$1 >>> 24;
- (wasm2js_i32$0 = $0_1, wasm2js_i32$1 = 0), ((HEAP8[wasm2js_i32$0 + 4 | 0] = wasm2js_i32$1, HEAP8[wasm2js_i32$0 + 5 | 0] = wasm2js_i32$1 >>> 8), HEAP8[wasm2js_i32$0 + 6 | 0] = wasm2js_i32$1 >>> 16), HEAP8[wasm2js_i32$0 + 7 | 0] = wasm2js_i32$1 >>> 24;
+ var $0_1 = 0, $1_1 = 0, $2_1 = 0;
+ HEAP8[0 | 0] = 0;
+ HEAP8[$0_1 + 1 | 0] = $2_1 >>> 8;
+ HEAP8[$0_1 + 2 | 0] = $2_1 >>> 16;
+ HEAP8[$0_1 + 3 | 0] = $2_1 >>> 24;
+ HEAP8[$1_1 + 4 | 0] = 0;
+ HEAP8[$1_1 + 5 | 0] = $0_1 >>> 8;
+ HEAP8[$1_1 + 6 | 0] = $0_1 >>> 16;
+ HEAP8[$1_1 + 7 | 0] = $0_1 >>> 24;
}
function $7() {
- var $0_1 = 0, $1 = 0, wasm2js_i32$0 = 0, wasm2js_i32$1 = 0;
+ var $0_1 = 0, $1_1 = 0, $2_1 = 0, $3_1 = 0;
wasm2js_scratch_store_f64(0.0);
$0_1 = wasm2js_scratch_load_i32(1 | 0) | 0;
- (wasm2js_i32$0 = 0, wasm2js_i32$1 = wasm2js_scratch_load_i32(0 | 0) | 0), ((HEAP8[wasm2js_i32$0 | 0] = wasm2js_i32$1, HEAP8[wasm2js_i32$0 + 1 | 0] = wasm2js_i32$1 >>> 8), HEAP8[wasm2js_i32$0 + 2 | 0] = wasm2js_i32$1 >>> 16), HEAP8[wasm2js_i32$0 + 3 | 0] = wasm2js_i32$1 >>> 24;
- (wasm2js_i32$0 = $1, wasm2js_i32$1 = $0_1), ((HEAP8[wasm2js_i32$0 + 4 | 0] = wasm2js_i32$1, HEAP8[wasm2js_i32$0 + 5 | 0] = wasm2js_i32$1 >>> 8), HEAP8[wasm2js_i32$0 + 6 | 0] = wasm2js_i32$1 >>> 16), HEAP8[wasm2js_i32$0 + 7 | 0] = wasm2js_i32$1 >>> 24;
+ $1_1 = wasm2js_scratch_load_i32(0 | 0) | 0;
+ HEAP8[0 | 0] = $1_1;
+ HEAP8[$3_1 + 1 | 0] = $1_1 >>> 8;
+ HEAP8[$3_1 + 2 | 0] = $1_1 >>> 16;
+ HEAP8[$3_1 + 3 | 0] = $1_1 >>> 24;
+ HEAP8[$2_1 + 4 | 0] = $0_1;
+ HEAP8[$2_1 + 5 | 0] = $0_1 >>> 8;
+ HEAP8[$2_1 + 6 | 0] = $0_1 >>> 16;
+ HEAP8[$2_1 + 7 | 0] = $0_1 >>> 24;
}
function legalstub$1() {
- var $0_1 = 0, wasm2js_i32$0 = 0;
- $0_1 = (wasm2js_i32$0 = 0, HEAPU8[wasm2js_i32$0 | 0] | HEAPU8[wasm2js_i32$0 + 1 | 0] << 8 | HEAPU8[wasm2js_i32$0 + 2 | 0] << 16 | HEAPU8[wasm2js_i32$0 + 3 | 0] << 24);
- i64toi32_i32$HIGH_BITS = (wasm2js_i32$0 = 4, HEAPU8[wasm2js_i32$0 | 0] | HEAPU8[wasm2js_i32$0 + 1 | 0] << 8 | HEAPU8[wasm2js_i32$0 + 2 | 0] << 16 | HEAPU8[wasm2js_i32$0 + 3 | 0] << 24);
- setTempRet0(i64toi32_i32$HIGH_BITS | 0);
- return $0_1;
+ var $0_1 = 0, $1_1 = 0, $2_1 = 0, $3_1 = 0;
+ $1_1 = $1();
+ $2_1 = i64toi32_i32$HIGH_BITS;
+ $3_1 = 32;
+ $0_1 = $3_1 & 31;
+ setTempRet0((32 >>> 0 <= $3_1 >>> 0 ? $2_1 >>> $0_1 : ((1 << $0_1) - 1 & $2_1) << 32 - $0_1 | $1_1 >>> $0_1) | 0);
+ return $1_1;
}
var FUNCTION_TABLE = [];