Initial GC integration (#196)

This commit is contained in:
Daniel Wirtz
2018-08-02 18:23:02 +02:00
committed by GitHub
parent 671121bf70
commit dc0f271fc2
139 changed files with 7370 additions and 5016 deletions

View File

@ -25,12 +25,12 @@
(data (i32.const 212) "\1c\00\00\00~\00l\00i\00b\00/\00i\00n\00t\00e\00r\00n\00a\00l\00/\00a\00r\00r\00a\00y\00b\00u\00f\00f\00e\00r\00.\00t\00s")
(export "memory" (memory $0))
(start $start)
(func $~lib/array/Array<i32>#get:length (; 1 ;) (type $ii) (param $0 i32) (result i32)
(func $~lib/array/Array<i32>#get:length (; 1 ;) (; has Stack IR ;) (type $ii) (param $0 i32) (result i32)
(i32.load offset=4
(get_local $0)
)
)
(func $~lib/array/Array<i32>#__get (; 2 ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(func $~lib/array/Array<i32>#__get (; 2 ;) (; has Stack IR ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(tee_local $0
(if (result i32)
(i32.lt_u
@ -59,7 +59,7 @@
)
)
)
(func $~lib/internal/arraybuffer/computeSize (; 3 ;) (type $ii) (param $0 i32) (result i32)
(func $~lib/internal/arraybuffer/computeSize (; 3 ;) (; has Stack IR ;) (type $ii) (param $0 i32) (result i32)
(i32.shl
(i32.const 1)
(i32.sub
@ -73,7 +73,7 @@
)
)
)
(func $~lib/memory/memset (; 4 ;) (type $iiiv) (param $0 i32) (param $1 i32) (param $2 i32)
(func $~lib/internal/memory/memset (; 4 ;) (; has Stack IR ;) (type $iiiv) (param $0 i32) (param $1 i32) (param $2 i32)
(local $3 i32)
(local $4 i64)
(if
@ -403,14 +403,7 @@
)
)
)
(func $~lib/memory/memory.fill (; 5 ;) (type $iiiv) (param $0 i32) (param $1 i32) (param $2 i32)
(call $~lib/memory/memset
(get_local $0)
(get_local $1)
(get_local $2)
)
)
(func $~lib/allocator/arena/__memory_allocate (; 6 ;) (type $ii) (param $0 i32) (result i32)
(func $~lib/allocator/arena/__memory_allocate (; 5 ;) (; has Stack IR ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(local $2 i32)
(local $3 i32)
@ -496,12 +489,7 @@
)
(i32.const 0)
)
(func $~lib/memory/memory.allocate (; 7 ;) (type $ii) (param $0 i32) (result i32)
(call $~lib/allocator/arena/__memory_allocate
(get_local $0)
)
)
(func $~lib/internal/arraybuffer/allocUnsafe (; 8 ;) (type $ii) (param $0 i32) (result i32)
(func $~lib/internal/arraybuffer/allocateUnsafe (; 6 ;) (; has Stack IR ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
(if
(i32.gt_u
@ -512,7 +500,7 @@
(call $~lib/env/abort
(i32.const 0)
(i32.const 212)
(i32.const 22)
(i32.const 23)
(i32.const 2)
)
(unreachable)
@ -520,7 +508,7 @@
)
(i32.store
(tee_local $1
(call $~lib/memory/memory.allocate
(call $~lib/allocator/arena/__memory_allocate
(call $~lib/internal/arraybuffer/computeSize
(get_local $0)
)
@ -530,7 +518,7 @@
)
(get_local $1)
)
(func $~lib/memory/memcpy (; 9 ;) (type $iiiv) (param $0 i32) (param $1 i32) (param $2 i32)
(func $~lib/internal/memory/memcpy (; 7 ;) (; has Stack IR ;) (type $iiiv) (param $0 i32) (param $1 i32) (param $2 i32)
(local $3 i32)
(local $4 i32)
(local $5 i32)
@ -1916,7 +1904,7 @@
)
)
)
(func $~lib/memory/memmove (; 10 ;) (type $iiiv) (param $0 i32) (param $1 i32) (param $2 i32)
(func $~lib/internal/memory/memmove (; 8 ;) (; has Stack IR ;) (type $iiiv) (param $0 i32) (param $1 i32) (param $2 i32)
(local $3 i32)
(local $4 i32)
(if
@ -1951,7 +1939,7 @@
(if
(get_local $3)
(block
(call $~lib/memory/memcpy
(call $~lib/internal/memory/memcpy
(get_local $0)
(get_local $1)
(get_local $2)
@ -2208,14 +2196,7 @@
)
)
)
(func $~lib/memory/memory.copy (; 11 ;) (type $iiiv) (param $0 i32) (param $1 i32) (param $2 i32)
(call $~lib/memory/memmove
(get_local $0)
(get_local $1)
(get_local $2)
)
)
(func $~lib/internal/arraybuffer/reallocUnsafe (; 12 ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(func $~lib/internal/arraybuffer/reallocateUnsafe (; 9 ;) (; has Stack IR ;) (type $iii) (param $0 i32) (param $1 i32) (result i32)
(local $2 i32)
(local $3 i32)
(if
@ -2237,7 +2218,7 @@
(call $~lib/env/abort
(i32.const 0)
(i32.const 212)
(i32.const 32)
(i32.const 37)
(i32.const 4)
)
(unreachable)
@ -2258,7 +2239,7 @@
(get_local $0)
(get_local $1)
)
(call $~lib/memory/memory.fill
(call $~lib/internal/memory/memset
(i32.add
(i32.add
(get_local $0)
@ -2274,10 +2255,10 @@
)
)
(block
(call $~lib/memory/memory.copy
(call $~lib/internal/memory/memmove
(i32.add
(tee_local $3
(call $~lib/internal/arraybuffer/allocUnsafe
(call $~lib/internal/arraybuffer/allocateUnsafe
(get_local $1)
)
)
@ -2289,7 +2270,7 @@
)
(get_local $2)
)
(call $~lib/memory/memory.fill
(call $~lib/internal/memory/memset
(i32.add
(i32.add
(get_local $3)
@ -2324,7 +2305,7 @@
(call $~lib/env/abort
(i32.const 0)
(i32.const 212)
(i32.const 56)
(i32.const 61)
(i32.const 4)
)
(unreachable)
@ -2339,7 +2320,7 @@
)
(get_local $0)
)
(func $~lib/array/Array<i32>#__set (; 13 ;) (type $iiiv) (param $0 i32) (param $1 i32) (param $2 i32)
(func $~lib/array/Array<i32>#__set (; 10 ;) (; has Stack IR ;) (type $iiiv) (param $0 i32) (param $1 i32) (param $2 i32)
(local $3 i32)
(local $4 i32)
(if
@ -2375,7 +2356,7 @@
(i32.store
(get_local $0)
(tee_local $3
(call $~lib/internal/arraybuffer/reallocUnsafe
(call $~lib/internal/arraybuffer/reallocateUnsafe
(get_local $3)
(i32.shl
(tee_local $4
@ -2406,7 +2387,7 @@
(get_local $2)
)
)
(func $~lib/array/Array<i64>#__get (; 14 ;) (type $iiI) (param $0 i32) (param $1 i32) (result i64)
(func $~lib/array/Array<i64>#__get (; 11 ;) (; has Stack IR ;) (type $iiI) (param $0 i32) (param $1 i32) (result i64)
(if (result i64)
(i32.lt_u
(get_local $1)
@ -2433,7 +2414,7 @@
(unreachable)
)
)
(func $~lib/array/Array<i64>#__set (; 15 ;) (type $iiIv) (param $0 i32) (param $1 i32) (param $2 i64)
(func $~lib/array/Array<i64>#__set (; 12 ;) (; has Stack IR ;) (type $iiIv) (param $0 i32) (param $1 i32) (param $2 i64)
(local $3 i32)
(local $4 i32)
(if
@ -2469,7 +2450,7 @@
(i32.store
(get_local $0)
(tee_local $3
(call $~lib/internal/arraybuffer/reallocUnsafe
(call $~lib/internal/arraybuffer/reallocateUnsafe
(get_local $3)
(i32.shl
(tee_local $4
@ -2500,7 +2481,7 @@
(get_local $2)
)
)
(func $~lib/array/Array<f32>#__get (; 16 ;) (type $iif) (param $0 i32) (param $1 i32) (result f32)
(func $~lib/array/Array<f32>#__get (; 13 ;) (; has Stack IR ;) (type $iif) (param $0 i32) (param $1 i32) (result f32)
(if (result f32)
(i32.lt_u
(get_local $1)
@ -2527,7 +2508,7 @@
(unreachable)
)
)
(func $~lib/array/Array<f32>#__set (; 17 ;) (type $iifv) (param $0 i32) (param $1 i32) (param $2 f32)
(func $~lib/array/Array<f32>#__set (; 14 ;) (; has Stack IR ;) (type $iifv) (param $0 i32) (param $1 i32) (param $2 f32)
(local $3 i32)
(local $4 i32)
(if
@ -2563,7 +2544,7 @@
(i32.store
(get_local $0)
(tee_local $3
(call $~lib/internal/arraybuffer/reallocUnsafe
(call $~lib/internal/arraybuffer/reallocateUnsafe
(get_local $3)
(i32.shl
(tee_local $4
@ -2594,7 +2575,7 @@
(get_local $2)
)
)
(func $~lib/array/Array<f64>#__get (; 18 ;) (type $iiF) (param $0 i32) (param $1 i32) (result f64)
(func $~lib/array/Array<f64>#__get (; 15 ;) (; has Stack IR ;) (type $iiF) (param $0 i32) (param $1 i32) (result f64)
(if (result f64)
(i32.lt_u
(get_local $1)
@ -2621,7 +2602,7 @@
(unreachable)
)
)
(func $~lib/array/Array<f64>#__set (; 19 ;) (type $iiFv) (param $0 i32) (param $1 i32) (param $2 f64)
(func $~lib/array/Array<f64>#__set (; 16 ;) (; has Stack IR ;) (type $iiFv) (param $0 i32) (param $1 i32) (param $2 f64)
(local $3 i32)
(local $4 i32)
(if
@ -2657,7 +2638,7 @@
(i32.store
(get_local $0)
(tee_local $3
(call $~lib/internal/arraybuffer/reallocUnsafe
(call $~lib/internal/arraybuffer/reallocateUnsafe
(get_local $3)
(i32.shl
(tee_local $4
@ -2688,7 +2669,7 @@
(get_local $2)
)
)
(func $start (; 20 ;) (type $v)
(func $start (; 17 ;) (; has Stack IR ;) (type $v)
(set_global $~lib/allocator/arena/startOffset
(i32.const 272)
)