diff options
Diffstat (limited to 'test')
-rw-r--r-- | test/passes/emit-js-wrapper=a.js.txt | 72 | ||||
-rw-r--r-- | test/passes/emit-js-wrapper=a.js.wast.js | 28 | ||||
-rw-r--r-- | test/passes/translate-to-fuzz.txt | 5 |
3 files changed, 94 insertions, 11 deletions
diff --git a/test/passes/emit-js-wrapper=a.js.txt b/test/passes/emit-js-wrapper=a.js.txt index e390a8fbb..508b62f5b 100644 --- a/test/passes/emit-js-wrapper=a.js.txt +++ b/test/passes/emit-js-wrapper=a.js.txt @@ -4,25 +4,27 @@ (type $2 (func (param i32 i64 f32 f64))) (type $3 (func (param i32 f32 f64))) (type $4 (func (param i32 f32 f64) (result i64))) + (type $FUNCSIG$vi (func (param i32))) + (import "env" "setTempRet0" (func $setTempRet0 (param i32))) (memory $0 256 256) (export "add" (func $add)) (export "no_return" (func $no-return)) - (export "types" (func $types)) - (export "types2" (func $types2)) - (export "types3" (func $types3)) - (func $add (; 0 ;) (type $0) (param $x i32) (param $y i32) (result i32) + (export "types" (func $legalstub$types)) + (export "types2" (func $legalstub$types2)) + (export "types3" (func $legalstub$types3)) + (func $add (; 1 ;) (type $0) (param $x i32) (param $y i32) (result i32) (i32.add (get_local $x) (get_local $y) ) ) - (func $unexported (; 1 ;) (type $0) (param $x i32) (param $y i32) (result i32) + (func $unexported (; 2 ;) (type $0) (param $x i32) (param $y i32) (result i32) (i32.add (get_local $x) (get_local $y) ) ) - (func $no-return (; 2 ;) (type $1) (param $x i32) + (func $no-return (; 3 ;) (type $1) (param $x i32) (drop (i32.add (get_local $x) @@ -30,13 +32,65 @@ ) ) ) - (func $types (; 3 ;) (type $2) (param $x i32) (param $y i64) (param $z f32) (param $w f64) + (func $types (; 4 ;) (type $2) (param $x i32) (param $y i64) (param $z f32) (param $w f64) (nop) ) - (func $types2 (; 4 ;) (type $3) (param $x i32) (param $z f32) (param $w f64) + (func $types2 (; 5 ;) (type $3) (param $x i32) (param $z f32) (param $w f64) (nop) ) - (func $types3 (; 5 ;) (type $4) (param $x i32) (param $z f32) (param $w f64) (result i64) + (func $types3 (; 6 ;) (type $4) (param $x i32) (param $z f32) (param $w f64) (result i64) (i64.const 1) ) + (func $legalstub$types (; 7 ;) (param $0 i32) (param $1 i32) (param $2 i32) (param $3 f64) (param $4 f64) + (call $types + (get_local $0) + (i64.or + (i64.extend_u/i32 + (get_local $1) + ) + (i64.shl + (i64.extend_u/i32 + (get_local $2) + ) + (i64.const 32) + ) + ) + (f32.demote/f64 + (get_local $3) + ) + (get_local $4) + ) + ) + (func $legalstub$types2 (; 8 ;) (param $0 i32) (param $1 f64) (param $2 f64) + (call $types2 + (get_local $0) + (f32.demote/f64 + (get_local $1) + ) + (get_local $2) + ) + ) + (func $legalstub$types3 (; 9 ;) (param $0 i32) (param $1 f64) (param $2 f64) (result i32) + (local $3 i64) + (set_local $3 + (call $types3 + (get_local $0) + (f32.demote/f64 + (get_local $1) + ) + (get_local $2) + ) + ) + (call $setTempRet0 + (i32.wrap/i64 + (i64.shr_u + (get_local $3) + (i64.const 32) + ) + ) + ) + (i32.wrap/i64 + (get_local $3) + ) + ) ) diff --git a/test/passes/emit-js-wrapper=a.js.wast.js b/test/passes/emit-js-wrapper=a.js.wast.js index 778f43827..f2e828c2b 100644 --- a/test/passes/emit-js-wrapper=a.js.wast.js +++ b/test/passes/emit-js-wrapper=a.js.wast.js @@ -1,6 +1,7 @@ if (typeof console === 'undefined') { console = { log: print }; } +var tempRet0; var binary; if (typeof process === 'object' && typeof require === 'function' /* node.js detection */) { var args = process.argv.slice(2); @@ -19,7 +20,18 @@ if (typeof process === 'object' && typeof require === 'function' /* node.js dete binary = read(args[0], 'binary'); } } -var instance = new WebAssembly.Instance(new WebAssembly.Module(binary), {}); +var instance = new WebAssembly.Instance(new WebAssembly.Module(binary), { + 'fuzzing-support': { + 'log-i32': function(x) { console.log('i32: ' + x) }, + 'log-i64': function(x, y) { console.log('i64: ' + x + ', ' + y) }, + 'log-f32': function(x) { console.log('f32: ' + x) }, + 'log-f64': function(x) { console.log('f64: ' + x) } + }, + 'env': { + 'setTempRet0': function(x) { tempRet0 = x }, + 'getTempRet0': function() { return tempRet0 }, + }, +}); if (instance.exports.hangLimitInitializer) instance.exports.hangLimitInitializer(); try { console.log('calling: add'); @@ -36,9 +48,23 @@ instance.exports.no_return(0); } if (instance.exports.hangLimitInitializer) instance.exports.hangLimitInitializer(); try { + console.log('calling: types'); +instance.exports.types(0, 0, 0, 0, 0); +} catch (e) { + console.log(' exception: ' + e); +} +if (instance.exports.hangLimitInitializer) instance.exports.hangLimitInitializer(); +try { console.log('calling: types2'); instance.exports.types2(0, 0, 0); } catch (e) { console.log(' exception: ' + e); } +if (instance.exports.hangLimitInitializer) instance.exports.hangLimitInitializer(); +try { + console.log('calling: types3'); + console.log(' result: ' + instance.exports.types3(0, 0, 0)); +} catch (e) { + console.log(' exception: ' + e); +} console.log('done.') diff --git a/test/passes/translate-to-fuzz.txt b/test/passes/translate-to-fuzz.txt index c175193cd..32f3fabad 100644 --- a/test/passes/translate-to-fuzz.txt +++ b/test/passes/translate-to-fuzz.txt @@ -1,8 +1,11 @@ (module + (type $FUNCSIG$vi (func (param i32))) + (type $FUNCSIG$vj (func (param i64))) + (type $FUNCSIG$vf (func (param f32))) + (type $FUNCSIG$vd (func (param f64))) (type $FUNCSIG$v (func)) (type $FUNCSIG$jddfiV (func (param f64 f64 f32 i32 v128) (result i64))) (type $FUNCSIG$viViVjV (func (param i32 v128 i32 v128 i64 v128))) - (type $FUNCSIG$vd (func (param f64))) (type $FUNCSIG$VVVVVii (func (param v128 v128 v128 v128 i32 i32) (result v128))) (type $FUNCSIG$fddffj (func (param f64 f64 f32 f32 i64) (result f32))) (type $FUNCSIG$j (func (result i64))) |