Inline isNaN and isFinite

Looking at our existing tests it seems that inlining these can be performed by reusing locals most of the time, and sometimes enables erasing quite a bit of unnecessary code when optimizing.
This commit is contained in:
dcodeIO 2018-07-19 04:12:40 +02:00
parent cf8e3dfa12
commit 34839353fd
9 changed files with 570 additions and 625 deletions

View File

@ -12,8 +12,8 @@
@builtin export declare function isArray<T>(value?: T): bool;
@builtin export declare function isDefined(expression: void): bool;
@builtin export declare function isConstant(expression: void): bool;
export function isNaN<T>(value: T): bool { return value != value; }
export function isFinite<T>(value: T): bool { return value - value == 0; }
@inline export function isNaN<T>(value: T): bool { return value != value; }
@inline export function isFinite<T>(value: T): bool { return value - value == 0; }
@builtin export declare function clz<T>(value: T): T;
@builtin export declare function ctz<T>(value: T): T;

View File

@ -2,9 +2,7 @@
(type $FFF (func (param f64 f64) (result f64)))
(type $FiF (func (param f64 i32) (result f64)))
(type $fff (func (param f32 f32) (result f32)))
(type $fi (func (param f32) (result i32)))
(type $fif (func (param f32 i32) (result f32)))
(type $Fi (func (param f64) (result i32)))
(type $v (func))
(global $binary/b (mut i32) (i32.const 0))
(global $binary/i (mut i32) (i32.const 0))
@ -1555,13 +1553,7 @@
(f64.const 1.e+300)
)
)
(func $~lib/builtins/isNaN<f32> (; 2 ;) (type $fi) (param $0 f32) (result i32)
(f32.ne
(get_local $0)
(get_local $0)
)
)
(func $~lib/math/NativeMathf.mod (; 3 ;) (type $fff) (param $0 f32) (param $1 f32) (result f32)
(func $~lib/math/NativeMathf.mod (; 2 ;) (type $fff) (param $0 f32) (param $1 f32) (result f32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
@ -1613,14 +1605,18 @@
)
)
(set_local $3
(call $~lib/builtins/isNaN<f32>
(f32.ne
(get_local $1)
(get_local $1)
)
)
)
(if
(i32.eqz
(i32.and
(get_local $3)
(i32.const 1)
)
)
(set_local $3
(i32.eq
@ -1630,7 +1626,10 @@
)
)
(if
(i32.and
(get_local $3)
(i32.const 1)
)
(return
(f32.div
(tee_local $0
@ -1902,7 +1901,7 @@
(get_local $0)
)
)
(func $~lib/math/NativeMathf.scalbn (; 4 ;) (type $fif) (param $0 f32) (param $1 i32) (result f32)
(func $~lib/math/NativeMathf.scalbn (; 3 ;) (type $fif) (param $0 f32) (param $1 i32) (result f32)
(local $2 f32)
(set_local $2
(get_local $0)
@ -2014,7 +2013,7 @@
)
)
)
(func $~lib/math/NativeMathf.pow (; 5 ;) (type $fff) (param $0 f32) (param $1 f32) (result f32)
(func $~lib/math/NativeMathf.pow (; 4 ;) (type $fff) (param $0 f32) (param $1 f32) (result f32)
(local $2 f32)
(local $3 f32)
(local $4 i32)
@ -3201,13 +3200,7 @@
(f32.const 1.0000000031710769e-30)
)
)
(func $~lib/builtins/isNaN<f64> (; 6 ;) (type $Fi) (param $0 f64) (result i32)
(f64.ne
(get_local $0)
(get_local $0)
)
)
(func $~lib/math/NativeMath.mod (; 7 ;) (type $FFF) (param $0 f64) (param $1 f64) (result f64)
(func $~lib/math/NativeMath.mod (; 5 ;) (type $FFF) (param $0 f64) (param $1 f64) (result f64)
(local $2 i64)
(local $3 i32)
(local $4 i64)
@ -3267,7 +3260,8 @@
)
)
(set_local $7
(call $~lib/builtins/isNaN<f64>
(f64.ne
(get_local $1)
(get_local $1)
)
)
@ -3581,7 +3575,7 @@
(get_local $0)
)
)
(func $start (; 8 ;) (type $v)
(func $start (; 6 ;) (type $v)
(drop
(i32.rem_s
(get_global $binary/i)

View File

@ -2,9 +2,7 @@
(type $FFF (func (param f64 f64) (result f64)))
(type $FiF (func (param f64 i32) (result f64)))
(type $fff (func (param f32 f32) (result f32)))
(type $fi (func (param f32) (result i32)))
(type $fif (func (param f32 i32) (result f32)))
(type $Fi (func (param f64) (result i32)))
(type $v (func))
(global $binary/b (mut i32) (i32.const 0))
(global $binary/i (mut i32) (i32.const 0))
@ -1692,13 +1690,7 @@
(get_local $13)
)
)
(func $~lib/builtins/isNaN<f32> (; 2 ;) (type $fi) (param $0 f32) (result i32)
(f32.ne
(get_local $0)
(get_local $0)
)
)
(func $~lib/math/NativeMathf.mod (; 3 ;) (type $fff) (param $0 f32) (param $1 f32) (result f32)
(func $~lib/math/NativeMathf.mod (; 2 ;) (type $fff) (param $0 f32) (param $1 f32) (result f32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
@ -1741,7 +1733,9 @@
)
)
(if
(i32.and
(if (result i32)
(i32.and
(tee_local $7
(if (result i32)
(tee_local $7
@ -1754,17 +1748,24 @@
)
)
(get_local $7)
(call $~lib/builtins/isNaN<f32>
(block $~lib/builtins/isNaN<f32>|inlined.1 (result i32)
(f32.ne
(get_local $1)
(get_local $1)
)
)
)
)
(i32.const 1)
)
(get_local $7)
(i32.eq
(get_local $4)
(i32.const 255)
)
)
(i32.const 1)
)
(return
(f32.div
(f32.mul
@ -2119,7 +2120,7 @@
(get_local $2)
)
)
(func $~lib/math/NativeMathf.scalbn (; 4 ;) (type $fif) (param $0 f32) (param $1 i32) (result f32)
(func $~lib/math/NativeMathf.scalbn (; 3 ;) (type $fif) (param $0 f32) (param $1 i32) (result f32)
(local $2 f32)
(set_local $2
(get_local $0)
@ -2235,7 +2236,7 @@
)
)
)
(func $~lib/math/NativeMathf.pow (; 5 ;) (type $fff) (param $0 f32) (param $1 f32) (result f32)
(func $~lib/math/NativeMathf.pow (; 4 ;) (type $fff) (param $0 f32) (param $1 f32) (result f32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
@ -3550,13 +3551,7 @@
(get_local $11)
)
)
(func $~lib/builtins/isNaN<f64> (; 6 ;) (type $Fi) (param $0 f64) (result i32)
(f64.ne
(get_local $0)
(get_local $0)
)
)
(func $~lib/math/NativeMath.mod (; 7 ;) (type $FFF) (param $0 f64) (param $1 f64) (result f64)
(func $~lib/math/NativeMath.mod (; 5 ;) (type $FFF) (param $0 f64) (param $1 f64) (result f64)
(local $2 i64)
(local $3 i64)
(local $4 i32)
@ -3605,7 +3600,9 @@
)
)
(if
(i32.and
(if (result i32)
(i32.and
(tee_local $7
(if (result i32)
(tee_local $7
@ -3618,17 +3615,24 @@
)
)
(get_local $7)
(call $~lib/builtins/isNaN<f64>
(block $~lib/builtins/isNaN<f64>|inlined.1 (result i32)
(f64.ne
(get_local $1)
(get_local $1)
)
)
)
)
(i32.const 1)
)
(get_local $7)
(i32.eq
(get_local $4)
(i32.const 2047)
)
)
(i32.const 1)
)
(return
(f64.div
(f64.mul
@ -3996,7 +4000,7 @@
(get_local $2)
)
)
(func $start (; 8 ;) (type $v)
(func $start (; 6 ;) (type $v)
(drop
(i32.lt_s
(get_global $binary/i)

View File

@ -1,7 +1,5 @@
(module
(type $iiiiv (func (param i32 i32 i32 i32)))
(type $fi (func (param f32) (result i32)))
(type $Fi (func (param f64) (result i32)))
(type $iiv (func (param i32 i32)))
(type $v (func))
(import "env" "abort" (func $~lib/env/abort (param i32 i32 i32 i32)))
@ -23,43 +21,13 @@
(export "table" (table $0))
(export "test" (func $builtins/test))
(start $start)
(func $~lib/builtins/isNaN<f32> (; 1 ;) (type $fi) (param $0 f32) (result i32)
(f32.ne
(get_local $0)
(get_local $0)
)
)
(func $~lib/builtins/isFinite<f32> (; 2 ;) (type $fi) (param $0 f32) (result i32)
(f32.eq
(f32.sub
(get_local $0)
(get_local $0)
)
(f32.const 0)
)
)
(func $~lib/builtins/isNaN<f64> (; 3 ;) (type $Fi) (param $0 f64) (result i32)
(f64.ne
(get_local $0)
(get_local $0)
)
)
(func $~lib/builtins/isFinite<f64> (; 4 ;) (type $Fi) (param $0 f64) (result i32)
(f64.eq
(f64.sub
(get_local $0)
(get_local $0)
)
(f64.const 0)
)
)
(func $start~anonymous|0 (; 5 ;) (type $iiv) (param $0 i32) (param $1 i32)
(func $start~anonymous|0 (; 1 ;) (type $iiv) (param $0 i32) (param $1 i32)
(nop)
)
(func $builtins/test (; 6 ;) (type $v)
(func $builtins/test (; 2 ;) (type $v)
(nop)
)
(func $start (; 7 ;) (type $v)
(func $start (; 3 ;) (type $v)
(set_global $builtins/i
(i32.const 31)
)
@ -198,96 +166,6 @@
(unreachable)
)
)
(if
(call $~lib/builtins/isNaN<f32>
(f32.const 1.25)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 87)
(i32.const 0)
)
(unreachable)
)
)
(if
(i32.ne
(call $~lib/builtins/isNaN<f32>
(f32.const nan:0x400000)
)
(i32.const 1)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 88)
(i32.const 0)
)
(unreachable)
)
)
(if
(i32.ne
(call $~lib/builtins/isFinite<f32>
(f32.const 1.25)
)
(i32.const 1)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 89)
(i32.const 0)
)
(unreachable)
)
)
(if
(call $~lib/builtins/isFinite<f32>
(f32.const inf)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 90)
(i32.const 0)
)
(unreachable)
)
)
(if
(call $~lib/builtins/isFinite<f32>
(f32.const -inf)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 91)
(i32.const 0)
)
(unreachable)
)
)
(if
(call $~lib/builtins/isFinite<f32>
(f32.const nan:0x400000)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 92)
(i32.const 0)
)
(unreachable)
)
)
(set_global $builtins/f
(f32.const nan:0x400000)
)
@ -322,105 +200,11 @@
(f32.const 1)
)
(set_global $builtins/b
(call $~lib/builtins/isNaN<f32>
(f32.const 1.25)
)
(i32.const 0)
)
(set_global $builtins/b
(call $~lib/builtins/isFinite<f32>
(f32.const 1.25)
)
)
(if
(call $~lib/builtins/isNaN<f64>
(f64.const 1.25)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 123)
(i32.const 0)
)
(unreachable)
)
)
(if
(i32.ne
(call $~lib/builtins/isNaN<f64>
(f64.const nan:0x8000000000000)
)
(i32.const 1)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 124)
(i32.const 0)
)
(unreachable)
)
)
(if
(i32.ne
(call $~lib/builtins/isFinite<f64>
(f64.const 1.25)
)
(i32.const 1)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 125)
(i32.const 0)
)
(unreachable)
)
)
(if
(call $~lib/builtins/isFinite<f64>
(f64.const inf)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 126)
(i32.const 0)
)
(unreachable)
)
)
(if
(call $~lib/builtins/isFinite<f64>
(f64.const -inf)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 127)
(i32.const 0)
)
(unreachable)
)
)
(if
(call $~lib/builtins/isFinite<f64>
(f64.const nan:0x8000000000000)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 128)
(i32.const 0)
)
(unreachable)
)
)
(set_global $builtins/F
(f64.const nan:0x8000000000000)
)
@ -455,14 +239,10 @@
(f64.const 1)
)
(set_global $builtins/b
(call $~lib/builtins/isNaN<f64>
(f64.const 1.25)
)
(i32.const 0)
)
(set_global $builtins/b
(call $~lib/builtins/isFinite<f64>
(f64.const 1.25)
)
(i32.const 1)
)
(set_global $builtins/i
(i32.load
@ -767,126 +547,6 @@
(i32.const 2)
(get_global $builtins/fn)
)
(if
(i32.eqz
(call $~lib/builtins/isNaN<f32>
(f32.const nan:0x400000)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 271)
(i32.const 0)
)
(unreachable)
)
)
(if
(i32.eqz
(call $~lib/builtins/isNaN<f64>
(f64.const nan:0x8000000000000)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 272)
(i32.const 0)
)
(unreachable)
)
)
(if
(call $~lib/builtins/isFinite<f32>
(f32.const nan:0x400000)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 273)
(i32.const 0)
)
(unreachable)
)
)
(if
(call $~lib/builtins/isFinite<f32>
(f32.const inf)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 274)
(i32.const 0)
)
(unreachable)
)
)
(if
(call $~lib/builtins/isFinite<f64>
(f64.const nan:0x8000000000000)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 275)
(i32.const 0)
)
(unreachable)
)
)
(if
(call $~lib/builtins/isFinite<f64>
(f64.const inf)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 276)
(i32.const 0)
)
(unreachable)
)
)
(if
(i32.eqz
(call $~lib/builtins/isFinite<f32>
(f32.const 0)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 277)
(i32.const 0)
)
(unreachable)
)
)
(if
(i32.eqz
(call $~lib/builtins/isFinite<f64>
(f64.const 0)
)
)
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 8)
(i32.const 278)
(i32.const 0)
)
(unreachable)
)
)
(drop
(i32.load8_s
(i32.const 8)
@ -993,10 +653,5 @@
(i32.const 8)
(f64.const 1)
)
(drop
(call $~lib/builtins/isNaN<f64>
(f64.const 1)
)
)
)
)

View File

@ -1,7 +1,5 @@
(module
(type $iiiiv (func (param i32 i32 i32 i32)))
(type $fi (func (param f32) (result i32)))
(type $Fi (func (param f64) (result i32)))
(type $iiv (func (param i32 i32)))
(type $v (func))
(import "env" "abort" (func $~lib/env/abort (param i32 i32 i32 i32)))
@ -55,47 +53,19 @@
(export "table" (table $0))
(export "test" (func $builtins/test))
(start $start)
(func $~lib/builtins/isNaN<f32> (; 1 ;) (type $fi) (param $0 f32) (result i32)
(f32.ne
(get_local $0)
(get_local $0)
)
)
(func $~lib/builtins/isFinite<f32> (; 2 ;) (type $fi) (param $0 f32) (result i32)
(f32.eq
(f32.sub
(get_local $0)
(get_local $0)
)
(f32.const 0)
)
)
(func $~lib/builtins/isNaN<f64> (; 3 ;) (type $Fi) (param $0 f64) (result i32)
(f64.ne
(get_local $0)
(get_local $0)
)
)
(func $~lib/builtins/isFinite<f64> (; 4 ;) (type $Fi) (param $0 f64) (result i32)
(f64.eq
(f64.sub
(get_local $0)
(get_local $0)
)
(f64.const 0)
)
)
(func $start~anonymous|0 (; 5 ;) (type $iiv) (param $0 i32) (param $1 i32)
(func $start~anonymous|0 (; 1 ;) (type $iiv) (param $0 i32) (param $1 i32)
(nop)
)
(func $builtins/test (; 6 ;) (type $v)
(func $builtins/test (; 2 ;) (type $v)
(nop)
)
(func $start (; 7 ;) (type $v)
(func $start (; 3 ;) (type $v)
(local $0 i32)
(local $1 i32)
(local $2 i64)
(local $3 i64)
(local $4 f32)
(local $5 f64)
(if
(i32.eqz
(i32.const 1)
@ -837,9 +807,18 @@
(if
(i32.eqz
(i32.eq
(call $~lib/builtins/isNaN<f32>
(i32.and
(block $~lib/builtins/isNaN<f32>|inlined.0 (result i32)
(set_local $4
(f32.const 1.25)
)
(f32.ne
(get_local $4)
(get_local $4)
)
)
(i32.const 1)
)
(i32.const 0)
)
)
@ -856,9 +835,18 @@
(if
(i32.eqz
(i32.eq
(call $~lib/builtins/isNaN<f32>
(i32.and
(block $~lib/builtins/isNaN<f32>|inlined.1 (result i32)
(set_local $4
(f32.const nan:0x400000)
)
(f32.ne
(get_local $4)
(get_local $4)
)
)
(i32.const 1)
)
(i32.const 1)
)
)
@ -875,9 +863,21 @@
(if
(i32.eqz
(i32.eq
(call $~lib/builtins/isFinite<f32>
(i32.and
(block $~lib/builtins/isFinite<f32>|inlined.0 (result i32)
(set_local $4
(f32.const 1.25)
)
(f32.eq
(f32.sub
(get_local $4)
(get_local $4)
)
(f32.const 0)
)
)
(i32.const 1)
)
(i32.const 1)
)
)
@ -894,9 +894,21 @@
(if
(i32.eqz
(i32.eq
(call $~lib/builtins/isFinite<f32>
(i32.and
(block $~lib/builtins/isFinite<f32>|inlined.1 (result i32)
(set_local $4
(f32.const inf)
)
(f32.eq
(f32.sub
(get_local $4)
(get_local $4)
)
(f32.const 0)
)
)
(i32.const 1)
)
(i32.const 0)
)
)
@ -913,11 +925,23 @@
(if
(i32.eqz
(i32.eq
(call $~lib/builtins/isFinite<f32>
(i32.and
(block $~lib/builtins/isFinite<f32>|inlined.2 (result i32)
(set_local $4
(f32.neg
(f32.const inf)
)
)
(f32.eq
(f32.sub
(get_local $4)
(get_local $4)
)
(f32.const 0)
)
)
(i32.const 1)
)
(i32.const 0)
)
)
@ -934,9 +958,21 @@
(if
(i32.eqz
(i32.eq
(call $~lib/builtins/isFinite<f32>
(i32.and
(block $~lib/builtins/isFinite<f32>|inlined.3 (result i32)
(set_local $4
(f32.const nan:0x400000)
)
(f32.eq
(f32.sub
(get_local $4)
(get_local $4)
)
(f32.const 0)
)
)
(i32.const 1)
)
(i32.const 0)
)
)
@ -1005,14 +1041,35 @@
)
)
(set_global $builtins/b
(call $~lib/builtins/isNaN<f32>
(i32.and
(block $~lib/builtins/isNaN<f32>|inlined.2 (result i32)
(set_local $4
(f32.const 1.25)
)
(f32.ne
(get_local $4)
(get_local $4)
)
)
(i32.const 1)
)
)
(set_global $builtins/b
(call $~lib/builtins/isFinite<f32>
(i32.and
(block $~lib/builtins/isFinite<f32>|inlined.4 (result i32)
(set_local $4
(f32.const 1.25)
)
(f32.eq
(f32.sub
(get_local $4)
(get_local $4)
)
(f32.const 0)
)
)
(i32.const 1)
)
)
(drop
(f64.const nan:0x8000000000000)
@ -1077,9 +1134,18 @@
(if
(i32.eqz
(i32.eq
(call $~lib/builtins/isNaN<f64>
(i32.and
(block $~lib/builtins/isNaN<f64>|inlined.0 (result i32)
(set_local $5
(f64.const 1.25)
)
(f64.ne
(get_local $5)
(get_local $5)
)
)
(i32.const 1)
)
(i32.const 0)
)
)
@ -1096,9 +1162,18 @@
(if
(i32.eqz
(i32.eq
(call $~lib/builtins/isNaN<f64>
(i32.and
(block $~lib/builtins/isNaN<f64>|inlined.1 (result i32)
(set_local $5
(f64.const nan:0x8000000000000)
)
(f64.ne
(get_local $5)
(get_local $5)
)
)
(i32.const 1)
)
(i32.const 1)
)
)
@ -1115,9 +1190,21 @@
(if
(i32.eqz
(i32.eq
(call $~lib/builtins/isFinite<f64>
(i32.and
(block $~lib/builtins/isFinite<f64>|inlined.0 (result i32)
(set_local $5
(f64.const 1.25)
)
(f64.eq
(f64.sub
(get_local $5)
(get_local $5)
)
(f64.const 0)
)
)
(i32.const 1)
)
(i32.const 1)
)
)
@ -1134,9 +1221,21 @@
(if
(i32.eqz
(i32.eq
(call $~lib/builtins/isFinite<f64>
(i32.and
(block $~lib/builtins/isFinite<f64>|inlined.1 (result i32)
(set_local $5
(f64.const inf)
)
(f64.eq
(f64.sub
(get_local $5)
(get_local $5)
)
(f64.const 0)
)
)
(i32.const 1)
)
(i32.const 0)
)
)
@ -1153,11 +1252,23 @@
(if
(i32.eqz
(i32.eq
(call $~lib/builtins/isFinite<f64>
(i32.and
(block $~lib/builtins/isFinite<f64>|inlined.2 (result i32)
(set_local $5
(f64.neg
(f64.const inf)
)
)
(f64.eq
(f64.sub
(get_local $5)
(get_local $5)
)
(f64.const 0)
)
)
(i32.const 1)
)
(i32.const 0)
)
)
@ -1174,9 +1285,21 @@
(if
(i32.eqz
(i32.eq
(call $~lib/builtins/isFinite<f64>
(i32.and
(block $~lib/builtins/isFinite<f64>|inlined.3 (result i32)
(set_local $5
(f64.const nan:0x8000000000000)
)
(f64.eq
(f64.sub
(get_local $5)
(get_local $5)
)
(f64.const 0)
)
)
(i32.const 1)
)
(i32.const 0)
)
)
@ -1245,14 +1368,35 @@
)
)
(set_global $builtins/b
(call $~lib/builtins/isNaN<f64>
(i32.and
(block $~lib/builtins/isNaN<f64>|inlined.2 (result i32)
(set_local $5
(f64.const 1.25)
)
(f64.ne
(get_local $5)
(get_local $5)
)
)
(i32.const 1)
)
)
(set_global $builtins/b
(call $~lib/builtins/isFinite<f64>
(i32.and
(block $~lib/builtins/isFinite<f64>|inlined.4 (result i32)
(set_local $5
(f64.const 1.25)
)
(f64.eq
(f64.sub
(get_local $5)
(get_local $5)
)
(f64.const 0)
)
)
(i32.const 1)
)
)
(set_global $builtins/i
(i32.load
@ -1945,9 +2089,18 @@
)
(if
(i32.eqz
(call $~lib/builtins/isNaN<f32>
(i32.and
(block $~lib/builtins/isNaN<f32>|inlined.3 (result i32)
(set_local $4
(f32.const nan:0x400000)
)
(f32.ne
(get_local $4)
(get_local $4)
)
)
(i32.const 1)
)
)
(block
(call $~lib/env/abort
@ -1961,9 +2114,18 @@
)
(if
(i32.eqz
(call $~lib/builtins/isNaN<f64>
(i32.and
(block $~lib/builtins/isNaN<f64>|inlined.3 (result i32)
(set_local $5
(f64.const nan:0x8000000000000)
)
(f64.ne
(get_local $5)
(get_local $5)
)
)
(i32.const 1)
)
)
(block
(call $~lib/env/abort
@ -1978,9 +2140,21 @@
(if
(i32.eqz
(i32.eqz
(call $~lib/builtins/isFinite<f32>
(i32.and
(block $~lib/builtins/isFinite<f32>|inlined.5 (result i32)
(set_local $4
(f32.const nan:0x400000)
)
(f32.eq
(f32.sub
(get_local $4)
(get_local $4)
)
(f32.const 0)
)
)
(i32.const 1)
)
)
)
(block
@ -1996,9 +2170,21 @@
(if
(i32.eqz
(i32.eqz
(call $~lib/builtins/isFinite<f32>
(i32.and
(block $~lib/builtins/isFinite<f32>|inlined.6 (result i32)
(set_local $4
(f32.const inf)
)
(f32.eq
(f32.sub
(get_local $4)
(get_local $4)
)
(f32.const 0)
)
)
(i32.const 1)
)
)
)
(block
@ -2014,9 +2200,21 @@
(if
(i32.eqz
(i32.eqz
(call $~lib/builtins/isFinite<f64>
(i32.and
(block $~lib/builtins/isFinite<f64>|inlined.5 (result i32)
(set_local $5
(f64.const nan:0x8000000000000)
)
(f64.eq
(f64.sub
(get_local $5)
(get_local $5)
)
(f64.const 0)
)
)
(i32.const 1)
)
)
)
(block
@ -2032,9 +2230,21 @@
(if
(i32.eqz
(i32.eqz
(call $~lib/builtins/isFinite<f64>
(i32.and
(block $~lib/builtins/isFinite<f64>|inlined.6 (result i32)
(set_local $5
(f64.const inf)
)
(f64.eq
(f64.sub
(get_local $5)
(get_local $5)
)
(f64.const 0)
)
)
(i32.const 1)
)
)
)
(block
@ -2049,9 +2259,21 @@
)
(if
(i32.eqz
(call $~lib/builtins/isFinite<f32>
(i32.and
(block $~lib/builtins/isFinite<f32>|inlined.7 (result i32)
(set_local $4
(f32.const 0)
)
(f32.eq
(f32.sub
(get_local $4)
(get_local $4)
)
(f32.const 0)
)
)
(i32.const 1)
)
)
(block
(call $~lib/env/abort
@ -2065,9 +2287,21 @@
)
(if
(i32.eqz
(call $~lib/builtins/isFinite<f64>
(i32.and
(block $~lib/builtins/isFinite<f64>|inlined.7 (result i32)
(set_local $5
(f64.const 0)
)
(f64.eq
(f64.sub
(get_local $5)
(get_local $5)
)
(f64.const 0)
)
)
(i32.const 1)
)
)
(block
(call $~lib/env/abort
@ -2878,9 +3112,15 @@
)
)
(drop
(call $~lib/builtins/isNaN<f64>
(block $~lib/builtins/isNaN<f64>|inlined.4 (result i32)
(set_local $5
(f64.const 1)
)
(f64.ne
(get_local $5)
(get_local $5)
)
)
)
)
)

View File

@ -8598,7 +8598,8 @@
)
)
(set_local $7
(call $~lib/builtins/isNaN<f64>
(f64.ne
(get_local $1)
(get_local $1)
)
)
@ -8994,14 +8995,18 @@
)
)
(set_local $3
(call $~lib/builtins/isNaN<f32>
(f32.ne
(get_local $1)
(get_local $1)
)
)
)
(if
(i32.eqz
(i32.and
(get_local $3)
(i32.const 1)
)
)
(set_local $3
(i32.eq
@ -9011,7 +9016,10 @@
)
)
(if
(i32.and
(get_local $3)
(i32.const 1)
)
(return
(f32.div
(tee_local $0

View File

@ -9937,7 +9937,9 @@
)
)
(if
(i32.and
(if (result i32)
(i32.and
(tee_local $7
(if (result i32)
(tee_local $7
@ -9950,17 +9952,24 @@
)
)
(get_local $7)
(call $~lib/builtins/isNaN<f64>
(block $~lib/builtins/isNaN<f64>|inlined.1 (result i32)
(f64.ne
(get_local $1)
(get_local $1)
)
)
)
)
(i32.const 1)
)
(get_local $7)
(i32.eq
(get_local $4)
(i32.const 2047)
)
)
(i32.const 1)
)
(return
(f64.div
(f64.mul
@ -10405,7 +10414,9 @@
)
)
(if
(i32.and
(if (result i32)
(i32.and
(tee_local $7
(if (result i32)
(tee_local $7
@ -10418,17 +10429,24 @@
)
)
(get_local $7)
(call $~lib/builtins/isNaN<f32>
(block $~lib/builtins/isNaN<f32>|inlined.1 (result i32)
(f32.ne
(get_local $1)
(get_local $1)
)
)
)
)
(i32.const 1)
)
(get_local $7)
(i32.eq
(get_local $4)
(i32.const 255)
)
)
(i32.const 1)
)
(return
(f32.div
(f32.mul

View File

@ -1,13 +1,13 @@
(module
(type $FFFi (func (param f64 f64 f64) (result i32)))
(type $FFF (func (param f64 f64) (result f64)))
(type $Fi (func (param f64) (result i32)))
(type $FFi (func (param f64 f64) (result i32)))
(type $Fi (func (param f64) (result i32)))
(type $iiiiv (func (param i32 i32 i32 i32)))
(type $fffi (func (param f32 f32 f32) (result i32)))
(type $fff (func (param f32 f32) (result f32)))
(type $fi (func (param f32) (result i32)))
(type $ffi (func (param f32 f32) (result i32)))
(type $fi (func (param f32) (result i32)))
(type $v (func))
(import "JSOp" "mod" (func $std/mod/JSOp.mod (param f64 f64) (result f64)))
(import "env" "abort" (func $~lib/env/abort (param i32 i32 i32 i32)))
@ -15,13 +15,7 @@
(data (i32.const 8) "\n\00\00\00s\00t\00d\00/\00m\00o\00d\00.\00t\00s")
(export "memory" (memory $0))
(start $start)
(func $~lib/builtins/isNaN<f64> (; 2 ;) (type $Fi) (param $0 f64) (result i32)
(f64.ne
(get_local $0)
(get_local $0)
)
)
(func $~lib/math/NativeMath.mod (; 3 ;) (type $FFF) (param $0 f64) (param $1 f64) (result f64)
(func $~lib/math/NativeMath.mod (; 2 ;) (type $FFF) (param $0 f64) (param $1 f64) (result f64)
(local $2 i64)
(local $3 i32)
(local $4 i64)
@ -81,7 +75,8 @@
)
)
(set_local $7
(call $~lib/builtins/isNaN<f64>
(f64.ne
(get_local $1)
(get_local $1)
)
)
@ -395,6 +390,12 @@
(get_local $0)
)
)
(func $~lib/builtins/isNaN<f64> (; 3 ;) (type $Fi) (param $0 f64) (result i32)
(f64.ne
(get_local $0)
(get_local $0)
)
)
(func $std/mod/check<f64> (; 4 ;) (type $FFi) (param $0 f64) (param $1 f64) (result i32)
(if
(call $~lib/builtins/isNaN<f64>
@ -455,13 +456,7 @@
)
(get_local $3)
)
(func $~lib/builtins/isNaN<f32> (; 6 ;) (type $fi) (param $0 f32) (result i32)
(f32.ne
(get_local $0)
(get_local $0)
)
)
(func $~lib/math/NativeMathf.mod (; 7 ;) (type $fff) (param $0 f32) (param $1 f32) (result f32)
(func $~lib/math/NativeMathf.mod (; 6 ;) (type $fff) (param $0 f32) (param $1 f32) (result f32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
@ -513,14 +508,18 @@
)
)
(set_local $3
(call $~lib/builtins/isNaN<f32>
(f32.ne
(get_local $1)
(get_local $1)
)
)
)
(if
(i32.eqz
(i32.and
(get_local $3)
(i32.const 1)
)
)
(set_local $3
(i32.eq
@ -530,7 +529,10 @@
)
)
(if
(i32.and
(get_local $3)
(i32.const 1)
)
(return
(f32.div
(tee_local $0
@ -802,6 +804,12 @@
(get_local $0)
)
)
(func $~lib/builtins/isNaN<f32> (; 7 ;) (type $fi) (param $0 f32) (result i32)
(f32.ne
(get_local $0)
(get_local $0)
)
)
(func $std/mod/check<f32> (; 8 ;) (type $ffi) (param $0 f32) (param $1 f32) (result i32)
(if
(call $~lib/builtins/isNaN<f32>

View File

@ -1,13 +1,13 @@
(module
(type $FFFi (func (param f64 f64 f64) (result i32)))
(type $FFF (func (param f64 f64) (result f64)))
(type $Fi (func (param f64) (result i32)))
(type $FFi (func (param f64 f64) (result i32)))
(type $Fi (func (param f64) (result i32)))
(type $iiiiv (func (param i32 i32 i32 i32)))
(type $fffi (func (param f32 f32 f32) (result i32)))
(type $fff (func (param f32 f32) (result f32)))
(type $fi (func (param f32) (result i32)))
(type $ffi (func (param f32 f32) (result i32)))
(type $fi (func (param f32) (result i32)))
(type $v (func))
(import "JSOp" "mod" (func $std/mod/JSOp.mod (param f64 f64) (result f64)))
(import "env" "abort" (func $~lib/env/abort (param i32 i32 i32 i32)))
@ -19,13 +19,7 @@
(data (i32.const 8) "\n\00\00\00s\00t\00d\00/\00m\00o\00d\00.\00t\00s\00")
(export "memory" (memory $0))
(start $start)
(func $~lib/builtins/isNaN<f64> (; 2 ;) (type $Fi) (param $0 f64) (result i32)
(f64.ne
(get_local $0)
(get_local $0)
)
)
(func $~lib/math/NativeMath.mod (; 3 ;) (type $FFF) (param $0 f64) (param $1 f64) (result f64)
(func $~lib/math/NativeMath.mod (; 2 ;) (type $FFF) (param $0 f64) (param $1 f64) (result f64)
(local $2 i64)
(local $3 i64)
(local $4 i32)
@ -74,7 +68,9 @@
)
)
(if
(i32.and
(if (result i32)
(i32.and
(tee_local $7
(if (result i32)
(tee_local $7
@ -87,17 +83,24 @@
)
)
(get_local $7)
(call $~lib/builtins/isNaN<f64>
(block $~lib/builtins/isNaN<f64>|inlined.1 (result i32)
(f64.ne
(get_local $1)
(get_local $1)
)
)
)
)
(i32.const 1)
)
(get_local $7)
(i32.eq
(get_local $4)
(i32.const 2047)
)
)
(i32.const 1)
)
(return
(f64.div
(f64.mul
@ -465,6 +468,12 @@
(get_local $2)
)
)
(func $~lib/builtins/isNaN<f64> (; 3 ;) (type $Fi) (param $0 f64) (result i32)
(f64.ne
(get_local $0)
(get_local $0)
)
)
(func $std/mod/check<f64> (; 4 ;) (type $FFi) (param $0 f64) (param $1 f64) (result i32)
(if
(call $~lib/builtins/isNaN<f64>
@ -531,13 +540,7 @@
(get_local $3)
)
)
(func $~lib/builtins/isNaN<f32> (; 6 ;) (type $fi) (param $0 f32) (result i32)
(f32.ne
(get_local $0)
(get_local $0)
)
)
(func $~lib/math/NativeMathf.mod (; 7 ;) (type $fff) (param $0 f32) (param $1 f32) (result f32)
(func $~lib/math/NativeMathf.mod (; 6 ;) (type $fff) (param $0 f32) (param $1 f32) (result f32)
(local $2 i32)
(local $3 i32)
(local $4 i32)
@ -580,7 +583,9 @@
)
)
(if
(i32.and
(if (result i32)
(i32.and
(tee_local $7
(if (result i32)
(tee_local $7
@ -593,17 +598,24 @@
)
)
(get_local $7)
(call $~lib/builtins/isNaN<f32>
(block $~lib/builtins/isNaN<f32>|inlined.1 (result i32)
(f32.ne
(get_local $1)
(get_local $1)
)
)
)
)
(i32.const 1)
)
(get_local $7)
(i32.eq
(get_local $4)
(i32.const 255)
)
)
(i32.const 1)
)
(return
(f32.div
(f32.mul
@ -958,6 +970,12 @@
(get_local $2)
)
)
(func $~lib/builtins/isNaN<f32> (; 7 ;) (type $fi) (param $0 f32) (result i32)
(f32.ne
(get_local $0)
(get_local $0)
)
)
(func $std/mod/check<f32> (; 8 ;) (type $ffi) (param $0 f32) (param $1 f32) (result i32)
(if
(call $~lib/builtins/isNaN<f32>