Wed, 31 Dec 2014 06:09:35 +0100
Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.
1 load(libdir + "asm.js");
3 setCachingEnabled(true);
4 if (!isAsmJSCompilationAvailable() || !isCachingEnabled())
5 quit();
7 var body1 = "'use asm'; function f() { return 42 } function ff() { return 43 } return f";
8 var m = new Function(body1);
9 assertEq(isAsmJSModule(m), true);
10 assertEq(m()(), 42);
11 var m = new Function(body1);
12 assertEq(isAsmJSModuleLoadedFromCache(m), true);
13 assertEq(m()(), 42);
14 var body2 = body1 + "f";
15 var m = new Function(body2);
16 assertEq(isAsmJSModuleLoadedFromCache(m), false);
17 assertEq(m()(), 43);
18 var evalStr1 = "(function() { " + body1 + "})";
19 var m = eval(evalStr1);
20 assertEq(isAsmJSModuleLoadedFromCache(m), false);
21 assertEq(m()(), 42);
22 var m = eval(evalStr1);
23 assertEq(isAsmJSModuleLoadedFromCache(m), true);
24 assertEq(m()(), 42);
25 var evalStr2 = "(function() { " + body2 + "})";
26 var m = eval(evalStr2);
27 assertEq(isAsmJSModuleLoadedFromCache(m), false);
28 assertEq(m()(), 43);
29 var m = eval(evalStr2);
30 assertEq(isAsmJSModuleLoadedFromCache(m), true);
31 assertEq(m()(), 43);
33 var evalStr3 = "(function(global) { 'use asm'; var sin=global.Math.sin; function g(d) { d=+d; return +sin(d) } return g })";
34 var m = eval(evalStr3);
35 assertEq(isAsmJSModule(m), true);
36 assertEq(m(this)(.3), Math.sin(.3));
37 var m = eval(evalStr3);
38 assertEq(isAsmJSModuleLoadedFromCache(m), true);
39 assertEq(m(this)(.3), Math.sin(.3));
40 var evalStr4 = "(function(gobal) { 'use asm'; var sin=global.Math.sin; function g(d) { d=+d; return +sin(d) } return g })";
41 var m = eval(evalStr4);
42 assertEq(isAsmJSModule(m), false);
43 var m = eval(evalStr3);
44 assertEq(isAsmJSModuleLoadedFromCache(m), true);
45 var evalStr5 = "(function(global,foreign) { 'use asm'; var sin=global.Math.sin; function g(d) { d=+d; return +sin(d) } return g })";
46 var m = eval(evalStr5);
47 assertEq(isAsmJSModuleLoadedFromCache(m), false);
49 var m = new Function(body1);
50 assertEq(isAsmJSModule(m), true);
51 var body3 = "'use asm'; var sin=global.Math.sin; function g(d) { d=+d; return +sin(d) } return g";
52 var m = new Function('global', body3);
53 assertEq(isAsmJSModuleLoadedFromCache(m), false);
54 assertEq(m(this)(.2), Math.sin(.2));
55 var m = new Function('gobal', body3);
56 assertEq(isAsmJSModule(m), false);
57 var m = new Function('global', body3);
58 assertEq(isAsmJSModuleLoadedFromCache(m), true);
59 var m = new Function('global','foreign', body3);
60 assertEq(isAsmJSModuleLoadedFromCache(m), false);
61 var m = new Function('global','foreign', body3);
62 assertEq(isAsmJSModuleLoadedFromCache(m), true);
63 var m = new Function('gobal','foreign', body3);
64 assertEq(isAsmJSModule(m), false);
65 var m = new Function('global','foreign', body3);
66 assertEq(isAsmJSModuleLoadedFromCache(m), true);
67 var m = new Function('global','foregn', body3);
68 assertEq(isAsmJSModuleLoadedFromCache(m), false);
69 var m = new Function('global','foreign', 'buffer', body3);
70 assertEq(isAsmJSModuleLoadedFromCache(m), false);
71 var m = new Function('global','foreign', 'buffer', 'foopy', body3);
72 assertEq(isAsmJSModule(m), false);
73 var m = new Function('global','foreign', 'buffer', body3);
74 assertEq(isAsmJSModuleLoadedFromCache(m), true);
75 var m = new Function('global','foreign', 'bffer', body3);
76 assertEq(isAsmJSModuleLoadedFromCache(m), false);
77 var m = new Function('global','foreign', 'foreign', body3);
78 assertEq(isAsmJSModule(m), false);
80 var body = "f() { 'use asm'; function g() {} return g }";
81 var evalStr6 = "(function " + body + ")";
82 var evalStr7 = "(function* " + body + ")";
83 var m = eval(evalStr6);
84 assertEq(isAsmJSModule(m), true);
85 var m = eval(evalStr6);
86 assertEq(isAsmJSModuleLoadedFromCache(m), true);
87 var m = eval(evalStr7);
88 assertEq(isAsmJSModule(m), false);
90 // Test caching using a separate process (which, with ASLR, should mean a
91 // separate address space) to compile/cache the code. Ideally, every asmCompile
92 // would do this, but that makes jit-tests run 100x slower. Do it here, for one
93 // of each feature. asm.js/testBullet.js should pound on everything.
94 assertEq(asmLink(asmCompileCached(USE_ASM + "function f(i) { i=i|0; return +((i+1)|0) } function g(d) { d=+d; return +(d + +f(42) + 1.5) } return g"))(.2), .2+43+1.5);
95 assertEq(asmLink(asmCompileCached(USE_ASM + "function f1() { return 1 } function f2() { return 2 } function f(i) { i=i|0; return T[i&1]()|0 } var T=[f1,f2]; return f"))(1), 2);
96 assertEq(asmLink(asmCompileCached("g", USE_ASM + "var s=g.Math.sin; function f(d) { d=+d; return +s(d) } return f"), this)(.3), Math.sin(.3));
97 assertEq(asmLink(asmCompileCached("g","ffis", USE_ASM + "var ffi=ffis.ffi; function f(i) { i=i|0; return ffi(i|0)|0 } return f"), null, {ffi:function(i){return i+2}})(1), 3);
98 assertEq(asmLink(asmCompileCached("g","ffis", USE_ASM + "var x=ffis.x|0; function f() { return x|0 } return f"), null, {x:43})(), 43);
99 var i32 = new Int32Array(4096);
100 i32[4] = 42;
101 assertEq(asmLink(asmCompileCached("g","ffis","buf", USE_ASM + "var i32=new g.Int32Array(buf); function f(i) { i=i|0; return i32[i>>2]|0 } return f"), this, null, i32.buffer)(4*4), 42);
102 assertEq(asmLink(asmCompileCached('glob', USE_ASM + 'var x=glob.Math.PI; function f() { return +x } return f'), this)(), Math.PI);