Rework static memory segment creation; Fix stdlib gc hooks not marking own fields; Align everything to 8 bytes that might be touched by GC

This commit is contained in:
dcodeIO
2018-08-04 00:36:59 +02:00
parent 61de7cf962
commit 631478c7c9
61 changed files with 11944 additions and 5286 deletions

View File

@ -16,11 +16,11 @@
(global $std/arraybuffer/buffer (mut i32) (i32.const 0))
(global $~argc (mut i32) (i32.const 0))
(global $std/arraybuffer/sliced (mut i32) (i32.const 0))
(global $HEAP_BASE i32 (i32.const 152))
(global $HEAP_BASE i32 (i32.const 160))
(memory $0 1)
(data (i32.const 8) "\13\00\00\00~\00l\00i\00b\00/\00a\00r\00r\00a\00y\00b\00u\00f\00f\00e\00r\00.\00t\00s\00")
(data (i32.const 52) "\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\00")
(data (i32.const 112) "\12\00\00\00s\00t\00d\00/\00a\00r\00r\00a\00y\00b\00u\00f\00f\00e\00r\00.\00t\00s\00")
(data (i32.const 56) "\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\00")
(data (i32.const 120) "\12\00\00\00s\00t\00d\00/\00a\00r\00r\00a\00y\00b\00u\00f\00f\00e\00r\00.\00t\00s\00")
(export "memory" (memory $0))
(start $start)
(func $~lib/internal/arraybuffer/computeSize (; 1 ;) (type $ii) (param $0 i32) (result i32)
@ -48,105 +48,108 @@
(local $5 i32)
(local $6 i32)
(if
(get_local $0)
(block
(if
(i32.gt_u
(get_local $0)
(get_global $~lib/internal/allocator/MAX_SIZE_32)
)
(unreachable)
)
(set_local $1
(get_global $~lib/allocator/arena/offset)
)
(set_local $2
(i32.and
(i32.add
(i32.add
(get_local $1)
(i32.gt_u
(get_local $0)
(get_global $~lib/internal/allocator/MAX_SIZE_32)
)
(unreachable)
)
(set_local $1
(get_global $~lib/allocator/arena/offset)
)
(set_local $4
(i32.and
(i32.add
(i32.add
(get_local $1)
(select
(tee_local $2
(get_local $0)
)
(get_global $~lib/internal/allocator/AL_MASK)
)
(i32.xor
(get_global $~lib/internal/allocator/AL_MASK)
(i32.const -1)
)
)
)
(set_local $3
(current_memory)
)
(if
(i32.gt_u
(get_local $2)
(i32.shl
(get_local $3)
(i32.const 16)
)
)
(block
(set_local $4
(i32.shr_u
(i32.and
(i32.add
(i32.sub
(get_local $2)
(get_local $1)
)
(i32.const 65535)
)
(i32.xor
(i32.const 65535)
(i32.const -1)
)
)
(i32.const 16)
(tee_local $3
(i32.const 1)
)
)
(set_local $5
(select
(tee_local $5
(get_local $3)
)
(tee_local $6
(get_local $4)
)
(i32.gt_s
(get_local $5)
(get_local $6)
)
)
)
(if
(i32.lt_s
(grow_memory
(get_local $5)
)
(i32.const 0)
)
(if
(i32.lt_s
(grow_memory
(get_local $4)
)
(i32.const 0)
)
(unreachable)
(i32.gt_u
(get_local $2)
(get_local $3)
)
)
)
(get_global $~lib/internal/allocator/AL_MASK)
)
(set_global $~lib/allocator/arena/offset
(get_local $2)
)
(return
(get_local $1)
(i32.xor
(get_global $~lib/internal/allocator/AL_MASK)
(i32.const -1)
)
)
)
(i32.const 0)
(set_local $5
(current_memory)
)
(if
(i32.gt_u
(get_local $4)
(i32.shl
(get_local $5)
(i32.const 16)
)
)
(block
(set_local $2
(i32.shr_u
(i32.and
(i32.add
(i32.sub
(get_local $4)
(get_local $1)
)
(i32.const 65535)
)
(i32.xor
(i32.const 65535)
(i32.const -1)
)
)
(i32.const 16)
)
)
(set_local $3
(select
(tee_local $3
(get_local $5)
)
(tee_local $6
(get_local $2)
)
(i32.gt_s
(get_local $3)
(get_local $6)
)
)
)
(if
(i32.lt_s
(grow_memory
(get_local $3)
)
(i32.const 0)
)
(if
(i32.lt_s
(grow_memory
(get_local $2)
)
(i32.const 0)
)
(unreachable)
)
)
)
)
(set_global $~lib/allocator/arena/offset
(get_local $4)
)
(get_local $1)
)
(func $~lib/internal/arraybuffer/allocateUnsafe (; 3 ;) (type $ii) (param $0 i32) (result i32)
(local $1 i32)
@ -161,7 +164,7 @@
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 52)
(i32.const 56)
(i32.const 23)
(i32.const 2)
)
@ -2901,7 +2904,7 @@
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 120)
(i32.const 5)
(i32.const 0)
)
@ -2932,7 +2935,7 @@
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 120)
(i32.const 9)
(i32.const 0)
)
@ -2949,7 +2952,7 @@
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 120)
(i32.const 10)
(i32.const 0)
)
@ -2980,7 +2983,7 @@
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 120)
(i32.const 14)
(i32.const 0)
)
@ -3011,7 +3014,7 @@
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 120)
(i32.const 18)
(i32.const 0)
)
@ -3037,7 +3040,7 @@
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 120)
(i32.const 22)
(i32.const 0)
)
@ -3063,7 +3066,7 @@
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 120)
(i32.const 26)
(i32.const 0)
)
@ -3089,7 +3092,7 @@
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 120)
(i32.const 30)
(i32.const 0)
)
@ -3115,7 +3118,7 @@
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 120)
(i32.const 34)
(i32.const 0)
)
@ -3146,7 +3149,7 @@
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 120)
(i32.const 38)
(i32.const 0)
)
@ -3163,7 +3166,7 @@
(block
(call $~lib/env/abort
(i32.const 0)
(i32.const 112)
(i32.const 120)
(i32.const 39)
(i32.const 0)
)