Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rework runtime #535

Closed
wants to merge 123 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
123 commits
Select commit Hold shift + click to select a range
80fb450
Runtime experiment
dcodeIO Mar 8, 2019
878ee3f
fix
dcodeIO Mar 8, 2019
979a0b8
simplify
dcodeIO Mar 8, 2019
dd5430a
simplify more
dcodeIO Mar 8, 2019
911a4bb
design
dcodeIO Mar 8, 2019
0ad9d56
integrate
dcodeIO Mar 8, 2019
4f1a971
make it test again
dcodeIO Mar 9, 2019
0c537c3
test a few things
dcodeIO Mar 9, 2019
661e239
refactor
dcodeIO Mar 9, 2019
5c25b0c
refactor
dcodeIO Mar 9, 2019
5a2ab3d
what std/string would look like
dcodeIO Mar 10, 2019
cb77760
unsafe, stub
dcodeIO Mar 10, 2019
85b740d
fix
dcodeIO Mar 10, 2019
f076826
update std/string
dcodeIO Mar 10, 2019
ce82e54
unshiftify padEnd
dcodeIO Mar 11, 2019
ebe92c6
untrampoline padEnd
dcodeIO Mar 11, 2019
1198e71
same for padStart
dcodeIO Mar 11, 2019
d9a5681
arraybufferview
dcodeIO Mar 11, 2019
146dfdb
it's all broken
dcodeIO Mar 11, 2019
8e95867
I'm lost
dcodeIO Mar 12, 2019
36d54d6
slowly but steadily
dcodeIO Mar 12, 2019
e78c4c7
more
dcodeIO Mar 13, 2019
37d361b
dataview
dcodeIO Mar 13, 2019
707f2da
more
dcodeIO Mar 13, 2019
e581f25
fix
dcodeIO Mar 13, 2019
6f70826
hmm
dcodeIO Mar 13, 2019
e38f627
more
dcodeIO Mar 13, 2019
6163a73
take a step back
dcodeIO Mar 14, 2019
a5e14a0
srsly
dcodeIO Mar 14, 2019
84ddd97
if that's what's necessary
dcodeIO Mar 14, 2019
3b8c233
symbols
dcodeIO Mar 14, 2019
ea43f9f
what's that btw
dcodeIO Mar 14, 2019
cdf3e2c
fixes
dcodeIO Mar 14, 2019
3a60638
simplify
dcodeIO Mar 14, 2019
d3ca06b
inline single-use implementations
dcodeIO Mar 14, 2019
139cec0
Merge branch 'master' into runtime
dcodeIO Mar 14, 2019
968b032
decisions
dcodeIO Mar 15, 2019
058dc8d
static array stuff
dcodeIO Mar 15, 2019
b8a08da
more static array
dcodeIO Mar 16, 2019
05a35f4
more
dcodeIO Mar 16, 2019
0c388ca
make std/string test ok again
dcodeIO Mar 16, 2019
2d76da9
alias locals when inlining a tail call
dcodeIO Mar 16, 2019
e63c6bd
local flow flags, see what works
dcodeIO Mar 17, 2019
f21b339
checked builtin array get, optimize abv layout
dcodeIO Mar 17, 2019
edb2299
fixes
dcodeIO Mar 17, 2019
ba4c00e
clean
dcodeIO Mar 17, 2019
c147e98
capabilities to detect half/full runtime header
dcodeIO Mar 18, 2019
0932cf1
use overloads for checked access
dcodeIO Mar 18, 2019
83566a5
eliminate unnecessary tee+drop in unchecked set
dcodeIO Mar 18, 2019
7693b54
optimize array literal init, warn on unsupported inlining
dcodeIO Mar 19, 2019
d42ef51
update n-body for comparison
dcodeIO Mar 19, 2019
74789c9
aliased makeCallInline, unmanaged rt alloc
dcodeIO Mar 19, 2019
81039c4
FixedArray experimentation
dcodeIO Mar 19, 2019
89b9d46
link on property assign
dcodeIO Mar 19, 2019
5fb3077
rt unlink
dcodeIO Mar 20, 2019
9b664dc
harden / elaborate on makeCallInline
dcodeIO Mar 20, 2019
952ac86
stdlib unlink wiring
dcodeIO Mar 20, 2019
f44dbf2
quick pure gc prototype
dcodeIO Mar 20, 2019
88a595f
some thoughts on pure gc
dcodeIO Mar 20, 2019
658a380
whoops
dcodeIO Mar 20, 2019
3fc9f55
more general gc hooks?
dcodeIO Mar 21, 2019
d4d5814
rt docs, initial itcm wiring
dcodeIO Mar 21, 2019
d9463c5
dummy gc
dcodeIO Mar 21, 2019
e57fa14
give it a shot
dcodeIO Mar 21, 2019
c2ac1a0
what if..
dcodeIO Mar 21, 2019
7c0dc66
guard, info on never null, more general array rt
dcodeIO Mar 22, 2019
3146f8f
use gc interface directly, document
dcodeIO Mar 26, 2019
bb1609c
baseline
dcodeIO Mar 27, 2019
f7ad5f8
fixes
dcodeIO Mar 27, 2019
a309547
Merge branch 'master' into runtime
dcodeIO Mar 27, 2019
e36722f
unify mem/ref interface
dcodeIO Mar 27, 2019
41abc01
readme [ci skip]
dcodeIO Mar 27, 2019
0dcfcc7
external gc interface
dcodeIO Mar 28, 2019
01fad52
fix allocator tests
dcodeIO Mar 29, 2019
97d1f6e
atomics option?
dcodeIO Mar 29, 2019
72c1dbf
maybe..
dcodeIO Mar 29, 2019
6911f9d
clear cache, revert
dcodeIO Mar 29, 2019
a3aa9a3
disable caching
dcodeIO Mar 29, 2019
6a79032
make ref_unlink optional and itcm pass a simple test again
dcodeIO Mar 29, 2019
3e3c393
finalize GC wiring
dcodeIO Mar 30, 2019
c4a5702
add binaryen fiddles for indirect to direct call optimization
dcodeIO Mar 31, 2019
27f1905
runtime integration and flag
dcodeIO Mar 31, 2019
7b99e44
update allocator tests
dcodeIO Mar 31, 2019
1ada854
some cleanup
dcodeIO Apr 1, 2019
3bcd32f
directize
dcodeIO Apr 2, 2019
6bf8276
Merge branch 'master' into runtime
dcodeIO Apr 2, 2019
e1bd005
directize more (eliminate table use)
dcodeIO Apr 2, 2019
d85a438
remove old traversal code
dcodeIO Apr 2, 2019
a639a42
initial __runtime_instanceof
dcodeIO Apr 2, 2019
b62927f
move runtime templates into stdlib for bundling with lib files
dcodeIO Apr 2, 2019
b58683a
wire __runtime_instanceof to 'instanceof' on upcasts
dcodeIO Apr 2, 2019
50c49e4
make it 'runtime.instanceof'
dcodeIO Apr 2, 2019
cc1e4cd
expose runtime id of exported class
dcodeIO Apr 3, 2019
85f3fc5
runtime api
dcodeIO Apr 3, 2019
25c5dfd
slim down runtime
dcodeIO Apr 4, 2019
ed32a4c
notes on gc.collect that I don't yet know how to work around
dcodeIO Apr 4, 2019
a9e4813
implement __runtime_flags
dcodeIO Apr 4, 2019
e1070ce
rtti & refactoring
dcodeIO Apr 6, 2019
57c8bd0
handle references externally assigned to fields
dcodeIO Apr 6, 2019
c3ff3f2
inherent acylic data structure detection
dcodeIO Apr 8, 2019
6f25642
add a note on acyclic detection
dcodeIO Apr 8, 2019
8ec5142
Merge branch 'master' into runtime
dcodeIO Apr 8, 2019
c16c19e
unify runtime header
dcodeIO Apr 8, 2019
da4a775
optimize logical and/or, initial null checking in flows
dcodeIO Apr 9, 2019
cd79376
null checking throughout logical and/or
dcodeIO Apr 9, 2019
eb6c4c0
possible-null assignment to non-null, notes
dcodeIO Apr 9, 2019
bb659bb
Runtime 'none' by default
dcodeIO Apr 9, 2019
8b5c629
reduce tlsf footprint
dcodeIO Apr 11, 2019
6b256be
asrt experiment
dcodeIO Apr 11, 2019
085e2db
asrt: derive constants
dcodeIO Apr 11, 2019
c13f4db
asrt: merge tlsf and purerc
dcodeIO Apr 15, 2019
586ca8b
backport tlsf fixes, add asrt allocator test
dcodeIO Apr 15, 2019
aee3a3e
16b alignment, cleanup
dcodeIO Apr 15, 2019
ceffc18
implications of 16b alignment
dcodeIO Apr 15, 2019
3e08e5c
asrt debugger, fixes
dcodeIO Apr 16, 2019
0ba0d8a
crunch functions
dcodeIO Apr 16, 2019
504e207
polish
dcodeIO Apr 17, 2019
ffdda4b
realloc on mm level
dcodeIO Apr 17, 2019
8216cf3
refactor into stdlib
dcodeIO Apr 18, 2019
18c3f0c
unify, stub impl
dcodeIO Apr 18, 2019
2b0a165
more
dcodeIO Apr 18, 2019
2dec529
fix export star module exports, shiftify
dcodeIO Apr 18, 2019
dd2bdd0
load/store Block
dcodeIO Apr 18, 2019
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
3 changes: 0 additions & 3 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,6 @@ notifications:
email: false
before_install: npm config set progress=false && npm i -g npm@latest --no-audit
install: npm ci --no-audit
cache:
directories:
- node_modules
jobs:
include:
- node_js: lts/*
Expand Down
43 changes: 32 additions & 11 deletions cli/asc.js
Original file line number Diff line number Diff line change
Expand Up @@ -387,11 +387,34 @@ exports.main = function main(argv, options, callback) {
stats.parseTime += measure(() => {
parser = assemblyscript.parseFile(sourceText, sourcePath, true, parser);
});
}

// Include runtime template
{
let templateName = String(args.runtime);
let templateText = exports.libraryFiles["runtime/" + templateName];
if (templateText == null) {
templateText = readFile(templateName + ".ts", baseDir);
if (templateText == null) {
return callback(Error("Runtime template '" + templateName + " not found."));
}
}
stats.parseCount++;
stats.parseTime += measure(() => {
parser = assemblyscript.parseFile(templateText, templateName, true, parser);
});
}

// Parse entry files
{
let code = parseBacklog();
if (code) return code;
}

// Call afterParse transform hook
applyTransform("afterParse", parser);

// Parse additional files, if any
{
let code = parseBacklog();
if (code) return code;
Expand Down Expand Up @@ -431,8 +454,8 @@ exports.main = function main(argv, options, callback) {
// Initialize default aliases
assemblyscript.setGlobalAlias(compilerOptions, "Math", "NativeMath");
assemblyscript.setGlobalAlias(compilerOptions, "Mathf", "NativeMathf");
assemblyscript.setGlobalAlias(compilerOptions, "abort", "~lib/env/abort");
assemblyscript.setGlobalAlias(compilerOptions, "trace", "~lib/env/trace");
assemblyscript.setGlobalAlias(compilerOptions, "abort", "~lib/builtins/abort");
assemblyscript.setGlobalAlias(compilerOptions, "trace", "~lib/builtins/trace");
}

// Add or override aliases if specified
Expand Down Expand Up @@ -463,15 +486,13 @@ exports.main = function main(argv, options, callback) {

var module;
stats.compileCount++;
(() => {
try {
stats.compileTime += measure(() => {
module = assemblyscript.compileProgram(program, compilerOptions);
});
} catch (e) {
return callback(e);
}
})();
try {
stats.compileTime += measure(() => {
module = assemblyscript.compileProgram(program, compilerOptions);
});
} catch (e) {
return callback(e);
}
if (checkDiagnostics(parser, stderr)) {
if (module) module.dispose();
return callback(Error("Compile error"));
Expand Down
12 changes: 12 additions & 0 deletions cli/asc.json
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,18 @@
],
"type": "s"
},
"runtime": {
"description": [
"Specifies the runtime template to include in the program.",
"",
" none No allocator/GC or compose your own. [default]",
" trace TLSF memory allocator and ITCM garbage collector.",
" arena Just the arena memory allocator. No free/GC.",
""
],
"type": "s",
"default": "none"
},
"debug": {
"description": "Enables debug information in emitted binaries.",
"type": "b",
Expand Down
Binary file modified examples/game-of-life/build/optimized.wasm
Binary file not shown.
15 changes: 6 additions & 9 deletions examples/game-of-life/build/optimized.wat
Original file line number Diff line number Diff line change
Expand Up @@ -8,13 +8,10 @@
(import "config" "BGR_ALIVE" (global $assembly/config/BGR_ALIVE i32))
(import "config" "BIT_ROT" (global $assembly/config/BIT_ROT i32))
(import "Math" "random" (func $~lib/bindings/Math/random (result f64)))
(table $0 1 funcref)
(elem (i32.const 0) $null)
(global $assembly/index/w (mut i32) (i32.const 0))
(global $assembly/index/h (mut i32) (i32.const 0))
(global $assembly/index/s (mut i32) (i32.const 0))
(export "memory" (memory $0))
(export "table" (table $0))
(export "init" (func $assembly/index/init))
(export "step" (func $assembly/index/step))
(export "fill" (func $assembly/index/fill))
Expand Down Expand Up @@ -136,7 +133,7 @@
local.get $7
local.get $1
select
local.tee $2
local.tee $3
global.get $assembly/index/w
local.get $4
i32.mul
Expand Down Expand Up @@ -165,7 +162,7 @@
local.get $7
i32.eq
select
local.tee $3
local.tee $2
global.get $assembly/index/w
local.get $4
i32.mul
Expand All @@ -179,7 +176,7 @@
global.get $assembly/index/w
local.get $0
i32.mul
local.get $2
local.get $3
i32.add
i32.const 2
i32.shl
Expand All @@ -190,7 +187,7 @@
global.get $assembly/index/w
local.get $0
i32.mul
local.get $3
local.get $2
i32.add
i32.const 2
i32.shl
Expand All @@ -201,7 +198,7 @@
global.get $assembly/index/w
local.get $5
i32.mul
local.get $2
local.get $3
i32.add
i32.const 2
i32.shl
Expand All @@ -223,7 +220,7 @@
global.get $assembly/index/w
local.get $5
i32.mul
local.get $3
local.get $2
i32.add
i32.const 2
i32.shl
Expand Down
Loading