backport tlsf fixes, add asrt allocator test

This commit is contained in:
dcode
2019-04-15 12:41:29 +02:00
parent c13f4db641
commit 586ca8b580
11 changed files with 2179 additions and 81 deletions

View File

@ -31,7 +31,7 @@
if
i32.const 0
i32.const 24
i32.const 167
i32.const 165
i32.const 13
call $~lib/builtins/abort
unreachable
@ -57,7 +57,7 @@
if
i32.const 0
i32.const 24
i32.const 181
i32.const 179
i32.const 13
call $~lib/builtins/abort
unreachable
@ -115,7 +115,7 @@
if
i32.const 0
i32.const 24
i32.const 467
i32.const 465
i32.const 13
call $~lib/builtins/abort
unreachable
@ -138,7 +138,7 @@
if
i32.const 0
i32.const 24
i32.const 172
i32.const 170
i32.const 13
call $~lib/builtins/abort
unreachable
@ -161,7 +161,7 @@
if
i32.const 0
i32.const 24
i32.const 162
i32.const 160
i32.const 13
call $~lib/builtins/abort
unreachable
@ -187,7 +187,7 @@
if
i32.const 0
i32.const 24
i32.const 262
i32.const 260
i32.const 13
call $~lib/builtins/abort
unreachable
@ -209,7 +209,7 @@
if
i32.const 0
i32.const 24
i32.const 264
i32.const 262
i32.const 13
call $~lib/builtins/abort
unreachable
@ -341,7 +341,7 @@
if
i32.const 0
i32.const 24
i32.const 197
i32.const 195
i32.const 13
call $~lib/builtins/abort
unreachable
@ -355,7 +355,7 @@
if
i32.const 0
i32.const 24
i32.const 199
i32.const 197
i32.const 13
call $~lib/builtins/abort
unreachable
@ -402,7 +402,7 @@
if
i32.const 0
i32.const 24
i32.const 217
i32.const 215
i32.const 15
call $~lib/builtins/abort
unreachable
@ -443,7 +443,7 @@
if
i32.const 0
i32.const 24
i32.const 230
i32.const 228
i32.const 13
call $~lib/builtins/abort
unreachable
@ -458,7 +458,7 @@
if
i32.const 0
i32.const 24
i32.const 231
i32.const 229
i32.const 13
call $~lib/builtins/abort
unreachable
@ -555,7 +555,7 @@
if
i32.const 0
i32.const 24
i32.const 374
i32.const 372
i32.const 4
call $~lib/builtins/abort
unreachable
@ -579,7 +579,7 @@
else
i32.const 0
i32.const 24
i32.const 391
i32.const 389
i32.const 6
call $~lib/builtins/abort
unreachable
@ -594,7 +594,7 @@
if
i32.const 0
i32.const 24
i32.const 395
i32.const 393
i32.const 4
call $~lib/builtins/abort
unreachable
@ -718,7 +718,7 @@
if
i32.const 0
i32.const 24
i32.const 461
i32.const 459
i32.const 13
call $~lib/builtins/abort
unreachable
@ -801,7 +801,7 @@
if
i32.const 0
i32.const 24
i32.const 331
i32.const 329
i32.const 17
call $~lib/builtins/abort
unreachable
@ -873,7 +873,7 @@
if
i32.const 0
i32.const 24
i32.const 346
i32.const 344
i32.const 4
call $~lib/builtins/abort
unreachable
@ -976,7 +976,7 @@
if
i32.const 0
i32.const 24
i32.const 490
i32.const 488
i32.const 15
call $~lib/builtins/abort
unreachable
@ -991,7 +991,7 @@
if
i32.const 0
i32.const 24
i32.const 492
i32.const 490
i32.const 13
call $~lib/builtins/abort
unreachable
@ -1020,7 +1020,7 @@
if
i32.const 0
i32.const 24
i32.const 454
i32.const 452
i32.const 13
call $~lib/builtins/abort
unreachable
@ -1044,7 +1044,7 @@
if
i32.const 0
i32.const 24
i32.const 503
i32.const 501
i32.const 4
call $~lib/builtins/abort
unreachable
@ -1078,7 +1078,7 @@
if
i32.const 0
i32.const 24
i32.const 642
i32.const 640
i32.const 15
call $~lib/builtins/abort
unreachable
@ -1184,7 +1184,7 @@
if
i32.const 0
i32.const 24
i32.const 597
i32.const 595
i32.const 17
call $~lib/builtins/abort
unreachable
@ -1232,7 +1232,7 @@
if
i32.const 0
i32.const 24
i32.const 608
i32.const 606
i32.const 6
call $~lib/builtins/abort
unreachable
@ -1262,7 +1262,7 @@
end
i32.const 0
i32.const 24
i32.const 619
i32.const 617
i32.const 24
call $~lib/builtins/abort
unreachable
@ -1284,7 +1284,7 @@
if
i32.const 0
i32.const 24
i32.const 626
i32.const 624
i32.const 2
call $~lib/builtins/abort
unreachable

View File

@ -125,16 +125,17 @@ function getRight(block: Block): Block {
// ├───────────────────────────────────────────────────────────────┤ │ │
// │ slMap[1] │ ◄─┤ │
// ├───────────────────────────────────────────────────────────────┤ u32 │
// │ slMap[22] P │ ◄─┘ │
// │ slMap[21] │ ◄─┘ │
// ╞═══════════════════════════════════════════════════════════════╡ usize
// │ head[0] │ ◄────┤
// ├───────────────────────────────────────────────────────────────┤ │
// │ ... │ ◄────┤
// ├───────────────────────────────────────────────────────────────┤ │
// │ head[736] │ ◄────┤
// │ head[703] │ ◄────┤
// ╞═══════════════════════════════════════════════════════════════╡ │
// │ tailRef │ ◄────┘
// └───────────────────────────────────────────────────────────────┘ SIZE ┘
// S: Small blocks map
@unmanaged class Root {
/** First level bitmap. */
flMap: usize;
@ -146,9 +147,6 @@ function getRight(block: Block): Block {
@inline const SL_START = sizeof<usize>();
// @ts-ignore: decorator
@inline const SL_END = SL_START + (FL_BITS << alignof<u32>());
// ^
// FIXME: 22 slMaps, what about SB? is it included in 22 or actually 23?
// @ts-ignore: decorator
@inline const HL_START = (SL_END + AL_MASK) & ~AL_MASK;
// @ts-ignore: decorator
@ -381,14 +379,16 @@ function addMemory(root: Root, start: usize, end: usize): bool {
var tail = getTail(root);
var tailInfo: usize = 0;
if (tail) { // more memory
// assert(start >= changetype<usize>(tail) + BLOCK_OVERHEAD); // starts after tail (zero-sized used block)
assert(start >= changetype<usize>(tail) + BLOCK_OVERHEAD);
// merge with current tail if adjacent
if (start - BLOCK_OVERHEAD == changetype<usize>(tail)) {
start -= BLOCK_OVERHEAD;
tailInfo = tail.mmInfo;
} else if (DEBUG) {
assert(false); // make sure we don't do this, even though possible
} else {
// We don't do this, but a user might `memory.grow` manually
// leading to non-adjacent pages managed by TLSF.
if (DEBUG) assert(false); // FIXME: remove me
}
} else if (DEBUG) { // first memory

View File

@ -40,7 +40,7 @@
if
i32.const 0
i32.const 24
i32.const 167
i32.const 165
i32.const 13
call $~lib/builtins/abort
unreachable
@ -68,7 +68,7 @@
if
i32.const 0
i32.const 24
i32.const 181
i32.const 179
i32.const 13
call $~lib/builtins/abort
unreachable
@ -139,7 +139,7 @@
if
i32.const 0
i32.const 24
i32.const 467
i32.const 465
i32.const 13
call $~lib/builtins/abort
unreachable
@ -164,7 +164,7 @@
if
i32.const 0
i32.const 24
i32.const 172
i32.const 170
i32.const 13
call $~lib/builtins/abort
unreachable
@ -188,7 +188,7 @@
if
i32.const 0
i32.const 24
i32.const 162
i32.const 160
i32.const 13
call $~lib/builtins/abort
unreachable
@ -218,7 +218,7 @@
if
i32.const 0
i32.const 24
i32.const 262
i32.const 260
i32.const 13
call $~lib/builtins/abort
unreachable
@ -243,7 +243,7 @@
if
i32.const 0
i32.const 24
i32.const 264
i32.const 262
i32.const 13
call $~lib/builtins/abort
unreachable
@ -391,7 +391,7 @@
if
i32.const 0
i32.const 24
i32.const 197
i32.const 195
i32.const 13
call $~lib/builtins/abort
unreachable
@ -406,7 +406,7 @@
if
i32.const 0
i32.const 24
i32.const 199
i32.const 197
i32.const 13
call $~lib/builtins/abort
unreachable
@ -460,7 +460,7 @@
if
i32.const 0
i32.const 24
i32.const 217
i32.const 215
i32.const 15
call $~lib/builtins/abort
unreachable
@ -510,7 +510,7 @@
if
i32.const 0
i32.const 24
i32.const 230
i32.const 228
i32.const 13
call $~lib/builtins/abort
unreachable
@ -526,7 +526,7 @@
if
i32.const 0
i32.const 24
i32.const 231
i32.const 229
i32.const 13
call $~lib/builtins/abort
unreachable
@ -637,7 +637,7 @@
if
i32.const 0
i32.const 24
i32.const 374
i32.const 372
i32.const 4
call $~lib/builtins/abort
unreachable
@ -668,7 +668,7 @@
if
i32.const 0
i32.const 24
i32.const 391
i32.const 389
i32.const 6
call $~lib/builtins/abort
unreachable
@ -684,7 +684,7 @@
if
i32.const 0
i32.const 24
i32.const 395
i32.const 393
i32.const 4
call $~lib/builtins/abort
unreachable
@ -872,7 +872,7 @@
if
i32.const 0
i32.const 24
i32.const 461
i32.const 459
i32.const 13
call $~lib/builtins/abort
unreachable
@ -888,7 +888,7 @@
if
i32.const 0
i32.const 24
i32.const 461
i32.const 459
i32.const 13
call $~lib/builtins/abort
unreachable
@ -993,7 +993,7 @@
if
i32.const 0
i32.const 24
i32.const 331
i32.const 329
i32.const 17
call $~lib/builtins/abort
unreachable
@ -1092,7 +1092,7 @@
if
i32.const 0
i32.const 24
i32.const 346
i32.const 344
i32.const 4
call $~lib/builtins/abort
unreachable
@ -1214,7 +1214,7 @@
if
i32.const 0
i32.const 24
i32.const 490
i32.const 488
i32.const 15
call $~lib/builtins/abort
unreachable
@ -1232,7 +1232,7 @@
if
i32.const 0
i32.const 24
i32.const 492
i32.const 490
i32.const 13
call $~lib/builtins/abort
unreachable
@ -1264,7 +1264,7 @@
if
i32.const 0
i32.const 24
i32.const 454
i32.const 452
i32.const 13
call $~lib/builtins/abort
unreachable
@ -1290,7 +1290,7 @@
if
i32.const 0
i32.const 24
i32.const 503
i32.const 501
i32.const 4
call $~lib/builtins/abort
unreachable
@ -1636,7 +1636,7 @@
if
i32.const 0
i32.const 24
i32.const 642
i32.const 640
i32.const 15
call $~lib/builtins/abort
unreachable
@ -1834,7 +1834,7 @@
if
i32.const 0
i32.const 24
i32.const 597
i32.const 595
i32.const 17
call $~lib/builtins/abort
unreachable
@ -1881,7 +1881,7 @@
if
i32.const 0
i32.const 24
i32.const 608
i32.const 606
i32.const 6
call $~lib/builtins/abort
unreachable
@ -1918,7 +1918,7 @@
if
i32.const 0
i32.const 24
i32.const 619
i32.const 617
i32.const 24
call $~lib/builtins/abort
unreachable
@ -1947,7 +1947,7 @@
if
i32.const 0
i32.const 24
i32.const 626
i32.const 624
i32.const 2
call $~lib/builtins/abort
unreachable