Commit 994db732 authored by Ross McIlroy's avatar Ross McIlroy Committed by Commit Bot

[cleanup] Add missing %PrepareFunctionForOptimize in mjsunit tests

Bug: v8:8801,v8:8394,v8:9183
Change-Id: I55027b3ba0c78f40d82aaf2d160aaf957d02cab5
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1662292
Auto-Submit: Ross McIlroy <rmcilroy@chromium.org>
Commit-Queue: Mythri Alle <mythria@chromium.org>
Reviewed-by: 's avatarMythri Alle <mythria@chromium.org>
Cr-Commit-Position: refs/heads/master@{#62214}
parent df202cfe
...@@ -19,6 +19,7 @@ class B extends A { ...@@ -19,6 +19,7 @@ class B extends A {
} }
} }
} }
%PrepareFunctionForOptimization(B);
var thrower = new Proxy(A, { var thrower = new Proxy(A, {
get(target, property, receiver) { get(target, property, receiver) {
......
...@@ -18,6 +18,7 @@ class B extends A { ...@@ -18,6 +18,7 @@ class B extends A {
construction_counter++; construction_counter++;
} }
} }
%PrepareFunctionForOptimization(B);
var superclass_counter = 0; var superclass_counter = 0;
......
...@@ -7,5 +7,6 @@ ...@@ -7,5 +7,6 @@
"use strict"; "use strict";
eval(); eval();
var f = ({x}) => { }; var f = ({x}) => { };
%PrepareFunctionForOptimization(f);
%OptimizeFunctionOnNextCall(f); %OptimizeFunctionOnNextCall(f);
assertThrows(f); assertThrows(f);
...@@ -9,10 +9,12 @@ function foo(a) { ...@@ -9,10 +9,12 @@ function foo(a) {
if (a) return arguments[1]; if (a) return arguments[1];
} }
%PrepareFunctionForOptimization(foo);
foo(false); foo(false);
foo(false); foo(false);
%OptimizeFunctionOnNextCall(foo); %OptimizeFunctionOnNextCall(foo);
foo(true, 1); foo(true, 1);
%PrepareFunctionForOptimization(foo);
foo(true, 1); foo(true, 1);
%OptimizeFunctionOnNextCall(foo); %OptimizeFunctionOnNextCall(foo);
foo(false); foo(false);
......
...@@ -9,11 +9,13 @@ ...@@ -9,11 +9,13 @@
var o = { [Symbol.toPrimitive]: () => "o" }; var o = { [Symbol.toPrimitive]: () => "o" };
%PrepareFunctionForOptimization(eq);
assertTrue(eq(o, o)); assertTrue(eq(o, o));
assertTrue(eq(o, o)); assertTrue(eq(o, o));
%OptimizeFunctionOnNextCall(eq); %OptimizeFunctionOnNextCall(eq);
assertTrue(eq(o, o)); assertTrue(eq(o, o));
assertTrue(eq("o", o)); assertTrue(eq("o", o));
%PrepareFunctionForOptimization(eq);
assertTrue(eq(o, "o")); assertTrue(eq(o, "o"));
%OptimizeFunctionOnNextCall(eq); %OptimizeFunctionOnNextCall(eq);
assertTrue(eq(o, o)); assertTrue(eq(o, o));
...@@ -27,11 +29,13 @@ ...@@ -27,11 +29,13 @@
var o = { [Symbol.toPrimitive]: () => "o" }; var o = { [Symbol.toPrimitive]: () => "o" };
%PrepareFunctionForOptimization(ne);
assertFalse(ne(o, o)); assertFalse(ne(o, o));
assertFalse(ne(o, o)); assertFalse(ne(o, o));
%OptimizeFunctionOnNextCall(ne); %OptimizeFunctionOnNextCall(ne);
assertFalse(ne(o, o)); assertFalse(ne(o, o));
assertFalse(ne("o", o)); assertFalse(ne("o", o));
%PrepareFunctionForOptimization(ne);
assertFalse(ne(o, "o")); assertFalse(ne(o, "o"));
%OptimizeFunctionOnNextCall(ne); %OptimizeFunctionOnNextCall(ne);
assertFalse(ne(o, o)); assertFalse(ne(o, o));
...@@ -47,6 +51,7 @@ ...@@ -47,6 +51,7 @@
var b = {b}; var b = {b};
var u = %GetUndetectable(); var u = %GetUndetectable();
%PrepareFunctionForOptimization(eq);
assertTrue(eq(a, a)); assertTrue(eq(a, a));
assertTrue(eq(b, b)); assertTrue(eq(b, b));
assertFalse(eq(a, b)); assertFalse(eq(a, b));
...@@ -61,6 +66,7 @@ ...@@ -61,6 +66,7 @@
assertFalse(eq(a, b)); assertFalse(eq(a, b));
assertFalse(eq(b, a)); assertFalse(eq(b, a));
assertTrue(eq(null, u)); assertTrue(eq(null, u));
%PrepareFunctionForOptimization(eq);
assertTrue(eq(undefined, u)); assertTrue(eq(undefined, u));
assertTrue(eq(u, null)); assertTrue(eq(u, null));
assertTrue(eq(u, undefined)); assertTrue(eq(u, undefined));
...@@ -83,6 +89,7 @@ ...@@ -83,6 +89,7 @@
var b = {b}; var b = {b};
var u = %GetUndetectable(); var u = %GetUndetectable();
%PrepareFunctionForOptimization(ne);
assertFalse(ne(a, a)); assertFalse(ne(a, a));
assertFalse(ne(b, b)); assertFalse(ne(b, b));
assertTrue(ne(a, b)); assertTrue(ne(a, b));
...@@ -97,6 +104,7 @@ ...@@ -97,6 +104,7 @@
assertTrue(ne(a, b)); assertTrue(ne(a, b));
assertTrue(ne(b, a)); assertTrue(ne(b, a));
assertFalse(ne(null, u)); assertFalse(ne(null, u));
%PrepareFunctionForOptimization(ne);
assertFalse(ne(undefined, u)); assertFalse(ne(undefined, u));
assertFalse(ne(u, null)); assertFalse(ne(u, null));
assertFalse(ne(u, undefined)); assertFalse(ne(u, undefined));
......
...@@ -6,5 +6,6 @@ ...@@ -6,5 +6,6 @@
with ({}) {} with ({}) {}
f = ({x}) => { }; f = ({x}) => { };
%PrepareFunctionForOptimization(f);
%OptimizeFunctionOnNextCall(f); %OptimizeFunctionOnNextCall(f);
f({}); f({});
...@@ -14,6 +14,7 @@ function foo() { ...@@ -14,6 +14,7 @@ function foo() {
var f1 = foo(); var f1 = foo();
var f2 = foo(); var f2 = foo();
%PrepareFunctionForOptimization(f1);
// Both closures point to full code. // Both closures point to full code.
f1(false); f1(false);
......
...@@ -12,6 +12,7 @@ function foo(o) { ...@@ -12,6 +12,7 @@ function foo(o) {
return true; return true;
} }
} }
%PrepareFunctionForOptimization(foo);
var o = new Proxy({a:1},{ var o = new Proxy({a:1},{
getOwnPropertyDescriptor(target, property) { throw target; } getOwnPropertyDescriptor(target, property) { throw target; }
......
...@@ -16,6 +16,8 @@ class C extends Object { ...@@ -16,6 +16,8 @@ class C extends Object {
} }
} }
} }
%PrepareFunctionForOptimization(C);
Object.setPrototypeOf(C, parseInt); Object.setPrototypeOf(C, parseInt);
assertSame(sentinelObject, new C()); assertSame(sentinelObject, new C());
assertSame(sentinelObject, new C()); assertSame(sentinelObject, new C());
......
...@@ -5,6 +5,7 @@ ...@@ -5,6 +5,7 @@
// Flags: --allow-natives-syntax // Flags: --allow-natives-syntax
function test(f) { function test(f) {
%PrepareFunctionForOptimization(f);
f(0); f(0);
f(NaN); f(NaN);
%OptimizeFunctionOnNextCall(f); %OptimizeFunctionOnNextCall(f);
......
...@@ -8,6 +8,7 @@ ...@@ -8,6 +8,7 @@
var g = (async () => { return JSON.stringify() }); var g = (async () => { return JSON.stringify() });
%PrepareFunctionForOptimization(g);
g(); g();
g(); g();
%OptimizeFunctionOnNextCall(g); %OptimizeFunctionOnNextCall(g);
......
...@@ -16,6 +16,7 @@ class SubClass extends SuperClass { ...@@ -16,6 +16,7 @@ class SubClass extends SuperClass {
} }
} }
%PrepareFunctionForOptimization(SubClass);
new SubClass(); new SubClass();
new SubClass(); new SubClass();
%OptimizeFunctionOnNextCall(SubClass); %OptimizeFunctionOnNextCall(SubClass);
......
...@@ -13,6 +13,7 @@ function f(deopt) { ...@@ -13,6 +13,7 @@ function f(deopt) {
} }
} }
%PrepareFunctionForOptimization(f);
f(false); f(false);
f(false); f(false);
%OptimizeFunctionOnNextCall(f); %OptimizeFunctionOnNextCall(f);
......
...@@ -13,7 +13,8 @@ ...@@ -13,7 +13,8 @@
try { throw 0 } catch(e) { try { throw 0 } catch(e) {
return b.forEach(callback); return b.forEach(callback);
} }
} };
%PrepareFunctionForOptimization(f);
f(); f();
f(); f();
%OptimizeFunctionOnNextCall(f); %OptimizeFunctionOnNextCall(f);
......
...@@ -24,6 +24,7 @@ function TestDontSelfHealWithDeoptedCode(run_unoptimized, ClosureFactory) { ...@@ -24,6 +24,7 @@ function TestDontSelfHealWithDeoptedCode(run_unoptimized, ClosureFactory) {
// so that the closure doesn't leak in a dead register). // so that the closure doesn't leak in a dead register).
(() => { (() => {
var optimized_closure = ClosureFactory(); var optimized_closure = ClosureFactory();
%PrepareFunctionForOptimization(optimized_closure);
// Use .call to avoid the CallIC retaining the JSFunction in the // Use .call to avoid the CallIC retaining the JSFunction in the
// feedback vector via a weak map, which would mean it wouldn't be // feedback vector via a weak map, which would mean it wouldn't be
// collected in the minor gc below. // collected in the minor gc below.
...@@ -40,6 +41,7 @@ function TestDontSelfHealWithDeoptedCode(run_unoptimized, ClosureFactory) { ...@@ -40,6 +41,7 @@ function TestDontSelfHealWithDeoptedCode(run_unoptimized, ClosureFactory) {
// old->new remember set. // old->new remember set.
(() => { (() => {
var dummy = function() { return 1; }; var dummy = function() { return 1; };
%PrepareFunctionForOptimization(dummy);
%OptimizeFunctionOnNextCall(dummy); %OptimizeFunctionOnNextCall(dummy);
dummy(); dummy();
})(); })();
......
...@@ -7,5 +7,6 @@ ...@@ -7,5 +7,6 @@
function f() {} function f() {}
var src = 'f(' + '0,'.repeat(0x201f) + ')'; var src = 'f(' + '0,'.repeat(0x201f) + ')';
var boom = new Function(src); var boom = new Function(src);
%PrepareFunctionForOptimization(boom);
%OptimizeFunctionOnNextCall(boom); %OptimizeFunctionOnNextCall(boom);
boom(); boom();
...@@ -12,6 +12,7 @@ function f() { ...@@ -12,6 +12,7 @@ function f() {
g(r); g(r);
} }
%PrepareFunctionForOptimization(f);
f(); f(); %OptimizeFunctionOnNextCall(f); // Warm-up. f(); f(); %OptimizeFunctionOnNextCall(f); // Warm-up.
var re; var re;
......
...@@ -10,10 +10,12 @@ function foo(a) { ...@@ -10,10 +10,12 @@ function foo(a) {
} }
} }
%PrepareFunctionForOptimization(foo);
foo([1]); foo([1]);
foo([1]); foo([1]);
%OptimizeFunctionOnNextCall(foo); %OptimizeFunctionOnNextCall(foo);
foo([1]); foo([1]);
%PrepareFunctionForOptimization(foo);
%OptimizeFunctionOnNextCall(foo); %OptimizeFunctionOnNextCall(foo);
foo([1]); foo([1]);
assertOptimized(foo); assertOptimized(foo);
...@@ -14,6 +14,7 @@ function f(b) { ...@@ -14,6 +14,7 @@ function f(b) {
%_DeoptimizeNow(); %_DeoptimizeNow();
return o.t; return o.t;
} }
%PrepareFunctionForOptimization(f);
// Finish slack tracking for C. // Finish slack tracking for C.
for (var i = 0; i < 1000; i++) new C(); for (var i = 0; i < 1000; i++) new C();
......
...@@ -9,6 +9,7 @@ function f(a) { ...@@ -9,6 +9,7 @@ function f(a) {
} }
x = { [Symbol.toPrimitive]: () => FAIL }; x = { [Symbol.toPrimitive]: () => FAIL };
%PrepareFunctionForOptimization(f);
f(1); f(1);
f(1); f(1);
%OptimizeFunctionOnNextCall(f); %OptimizeFunctionOnNextCall(f);
...@@ -19,6 +20,7 @@ function f(a) { ...@@ -19,6 +20,7 @@ function f(a) {
} }
x = { [Symbol.toPrimitive]: () => FAIL }; x = { [Symbol.toPrimitive]: () => FAIL };
%PrepareFunctionForOptimization(f);
f(1); f(1);
f(1); f(1);
%OptimizeFunctionOnNextCall(f); %OptimizeFunctionOnNextCall(f);
...@@ -29,6 +31,7 @@ function f(a) { ...@@ -29,6 +31,7 @@ function f(a) {
} }
x = { [Symbol.toPrimitive]: () => FAIL }; x = { [Symbol.toPrimitive]: () => FAIL };
%PrepareFunctionForOptimization(f);
f(1); f(1);
f(1); f(1);
%OptimizeFunctionOnNextCall(f); %OptimizeFunctionOnNextCall(f);
......
...@@ -11,6 +11,7 @@ foo(1); ...@@ -11,6 +11,7 @@ foo(1);
foo(1); foo(1);
%OptimizeFunctionOnNextCall(foo); %OptimizeFunctionOnNextCall(foo);
foo(1); foo(1);
%PrepareFunctionForOptimization(foo);
%OptimizeFunctionOnNextCall(foo); %OptimizeFunctionOnNextCall(foo);
foo(1); foo(1);
assertOptimized(foo); assertOptimized(foo);
...@@ -52,6 +52,7 @@ F.prototype.foo = function () { ...@@ -52,6 +52,7 @@ F.prototype.foo = function () {
var ctx = new F; var ctx = new F;
%PrepareFunctionForOptimization(F.prototype.foo);
for (var i = 0; i < 5; i++) ctx.foo(); for (var i = 0; i < 5; i++) ctx.foo();
%OptimizeFunctionOnNextCall(F.prototype.foo); %OptimizeFunctionOnNextCall(F.prototype.foo);
ctx.foo(); ctx.foo();
...@@ -15,6 +15,7 @@ function f(a, i, bool) { ...@@ -15,6 +15,7 @@ function f(a, i, bool) {
} }
return result; return result;
} }
%PrepareFunctionForOptimization(f);
function f2(a, c, x, i, d) { function f2(a, c, x, i, d) {
return a[x + c] + a[x - 0] + a[i - d]; return a[x + c] + a[x - 0] + a[i - d];
......
...@@ -37,6 +37,7 @@ assertEquals(e31, -e31*(-1)); ...@@ -37,6 +37,7 @@ assertEquals(e31, -e31*(-1));
var x = {toString : function() {return 1}} var x = {toString : function() {return 1}}
function add(a,b){return a+b;} function add(a,b){return a+b;}
%PrepareFunctionForOptimization(add);
add(1,x); add(1,x);
add(1,x); add(1,x);
%OptimizeFunctionOnNextCall(add); %OptimizeFunctionOnNextCall(add);
...@@ -85,6 +86,7 @@ function test(fun,check_fun,a,b,does_throw) { ...@@ -85,6 +86,7 @@ function test(fun,check_fun,a,b,does_throw) {
function minus(a,b) { return a-b }; function minus(a,b) { return a-b };
function check_minus(a,b) { return a-b }; function check_minus(a,b) { return a-b };
function mod(a,b) { return a%b }; function mod(a,b) { return a%b };
%PrepareFunctionForOptimization(mod);
function check_mod(a,b) { return a%b }; function check_mod(a,b) { return a%b };
test(minus,check_minus,1,2); test(minus,check_minus,1,2);
...@@ -124,16 +126,20 @@ test(mod,check_mod,1,2); ...@@ -124,16 +126,20 @@ test(mod,check_mod,1,2);
test(mod,check_mod,1,2); test(mod,check_mod,1,2);
test(mod,check_mod,1<<30,1); test(mod,check_mod,1<<30,1);
%PrepareFunctionForOptimization(mod);
%OptimizeFunctionOnNextCall(mod); %OptimizeFunctionOnNextCall(mod);
test(mod,check_mod,1<<30,1); test(mod,check_mod,1<<30,1);
test(mod,check_mod,1,1<<30); test(mod,check_mod,1,1<<30);
%PrepareFunctionForOptimization(mod);
%OptimizeFunctionOnNextCall(mod); %OptimizeFunctionOnNextCall(mod);
test(mod,check_mod,1,1<<30); test(mod,check_mod,1,1<<30);
test(mod,check_mod,1<<30,-(1<<30)); test(mod,check_mod,1<<30,-(1<<30));
%PrepareFunctionForOptimization(mod);
%OptimizeFunctionOnNextCall(mod); %OptimizeFunctionOnNextCall(mod);
test(mod,check_mod,1<<30,-(1<<30)); test(mod,check_mod,1<<30,-(1<<30));
test(mod,check_mod,1,{},2); test(mod,check_mod,1,{},2);
%PrepareFunctionForOptimization(mod);
%OptimizeFunctionOnNextCall(mod); %OptimizeFunctionOnNextCall(mod);
test(mod,check_mod,1,{},2); test(mod,check_mod,1,{},2);
...@@ -172,6 +178,7 @@ function string_add(a,i) { ...@@ -172,6 +178,7 @@ function string_add(a,i) {
var d = [0.1, ,0.3]; var d = [0.1, ,0.3];
return a + d[i]; return a + d[i];
} }
%PrepareFunctionForOptimization(string_add);
string_add(1.1, 0); string_add(1.1, 0);
string_add("", 0); string_add("", 0);
......
...@@ -15,6 +15,7 @@ function f() { ...@@ -15,6 +15,7 @@ function f() {
return result; return result;
} }
%PrepareFunctionForOptimization(f);
f(); f();
f(); f();
%OptimizeFunctionOnNextCall(f); %OptimizeFunctionOnNextCall(f);
......
...@@ -51,6 +51,7 @@ function prepare(base) { ...@@ -51,6 +51,7 @@ function prepare(base) {
right = 0.5 * base; right = 0.5 * base;
} }
%PrepareFunctionForOptimization(foo);
prepare(21); prepare(21);
assertEquals("ok", foo()); assertEquals("ok", foo());
assertEquals("ok", foo()); assertEquals("ok", foo());
......
...@@ -43,6 +43,7 @@ function f_store(test, test2, a, i) { ...@@ -43,6 +43,7 @@ function f_store(test, test2, a, i) {
} }
var a1 = [0, 0, 0, {}]; var a1 = [0, 0, 0, {}];
%PrepareFunctionForOptimization(f_store);
f_store(true, false, a1, 0); f_store(true, false, a1, 0);
f_store(true, true, a1, 0); f_store(true, true, a1, 0);
f_store(false, false, a1, 1); f_store(false, false, a1, 1);
...@@ -72,6 +73,7 @@ function f_call(f, test, test2, i) { ...@@ -72,6 +73,7 @@ function f_call(f, test, test2, i) {
return d; return d;
} }
%PrepareFunctionForOptimization(f_call);
f_call(test_arg(1.5), true, false, 0); f_call(test_arg(1.5), true, false, 0);
f_call(test_arg(2.5), true, true, 0); f_call(test_arg(2.5), true, true, 0);
f_call(test_arg(1), false, false, 1); f_call(test_arg(1), false, false, 1);
...@@ -100,6 +102,7 @@ function f_external(test, test2, test3, a, i) { ...@@ -100,6 +102,7 @@ function f_external(test, test2, test3, a, i) {
} }
var a2 = new Int32Array(10); var a2 = new Int32Array(10);
%PrepareFunctionForOptimization(f_external);
f_external(true, false, true, a2, 0); f_external(true, false, true, a2, 0);
f_external(true, true, true, a2, 0); f_external(true, true, true, a2, 0);
f_external(false, false, true, a2, 1); f_external(false, false, true, a2, 1);
......
...@@ -34,6 +34,7 @@ function f(a, i, l) { ...@@ -34,6 +34,7 @@ function f(a, i, l) {
return l + v; return l + v;
} }
%PrepareFunctionForOptimization(f);
assertEquals("test1.5", f(a, 0, "test")); assertEquals("test1.5", f(a, 0, "test"));
assertEquals("test1.5", f(a, 0, "test")); assertEquals("test1.5", f(a, 0, "test"));
%OptimizeFunctionOnNextCall(f); %OptimizeFunctionOnNextCall(f);
...@@ -51,6 +52,7 @@ function f2(b, a1, a2) { ...@@ -51,6 +52,7 @@ function f2(b, a1, a2) {
return "test" + v + x; return "test" + v + x;
} }
%PrepareFunctionForOptimization(f2);
f2(true, [1.4,1.8,,1.9], [1.4,1.8,,1.9]); f2(true, [1.4,1.8,,1.9], [1.4,1.8,,1.9]);
f2(true, [1.4,1.8,,1.9], [1.4,1.8,,1.9]); f2(true, [1.4,1.8,,1.9], [1.4,1.8,,1.9]);
f2(false, [1.4,1.8,,1.9], [1.4,1.8,,1.9]); f2(false, [1.4,1.8,,1.9], [1.4,1.8,,1.9]);
...@@ -63,6 +65,7 @@ function t_smi(a) { ...@@ -63,6 +65,7 @@ function t_smi(a) {
a[0] = 1.5; a[0] = 1.5;
} }
%PrepareFunctionForOptimization(t_smi);
t_smi([1,,3]); t_smi([1,,3]);
t_smi([1,,3]); t_smi([1,,3]);
t_smi([1,,3]); t_smi([1,,3]);
...@@ -77,6 +80,7 @@ function t(b) { ...@@ -77,6 +80,7 @@ function t(b) {
b[1] = {}; b[1] = {};
} }
%PrepareFunctionForOptimization(t);
t([1.4, 1.6,,1.8, NaN]); t([1.4, 1.6,,1.8, NaN]);
t([1.4, 1.6,,1.8, NaN]); t([1.4, 1.6,,1.8, NaN]);
%OptimizeFunctionOnNextCall(t); %OptimizeFunctionOnNextCall(t);
......
...@@ -44,6 +44,7 @@ C = Object.create(B); ...@@ -44,6 +44,7 @@ C = Object.create(B);
function bar(x) { return x.foo(); } function bar(x) { return x.foo(); }
%PrepareFunctionForOptimization(bar);
assertEquals(111, bar(C)); assertEquals(111, bar(C));
assertEquals(111, bar(C)); assertEquals(111, bar(C));
ToDictionaryMode(B); ToDictionaryMode(B);
...@@ -61,6 +62,7 @@ C = Object.create(B); ...@@ -61,6 +62,7 @@ C = Object.create(B);
function boo(x) { return x.baz; } function boo(x) { return x.baz; }
%PrepareFunctionForOptimization(boo);
assertEquals(111, boo(C)); assertEquals(111, boo(C));
assertEquals(111, boo(C)); assertEquals(111, boo(C));
ToDictionaryMode(B); ToDictionaryMode(B);
...@@ -83,6 +85,7 @@ function fuu(x) { ...@@ -83,6 +85,7 @@ function fuu(x) {
return setterValue; return setterValue;
} }
%PrepareFunctionForOptimization(fuu);
assertEquals(111, fuu(C)); assertEquals(111, fuu(C));
assertEquals(111, fuu(C)); assertEquals(111, fuu(C));
ToDictionaryMode(B); ToDictionaryMode(B);
......
...@@ -40,6 +40,8 @@ function factory(worker) { ...@@ -40,6 +40,8 @@ function factory(worker) {
var f1 = factory(worker1); var f1 = factory(worker1);
var f2 = factory(f1); var f2 = factory(f1);
%PrepareFunctionForOptimization(f1);
%PrepareFunctionForOptimization(f2);
assertEquals(11, f2(1)); // Result: 1 + f1(0) == 1 + 10. assertEquals(11, f2(1)); // Result: 1 + f1(0) == 1 + 10.
assertEquals(11, f2(1)); assertEquals(11, f2(1));
%OptimizeFunctionOnNextCall(f1); %OptimizeFunctionOnNextCall(f1);
......
...@@ -40,6 +40,8 @@ function factory(worker) { ...@@ -40,6 +40,8 @@ function factory(worker) {
var f1 = factory(worker1); var f1 = factory(worker1);
var f2 = factory(f1); var f2 = factory(f1);
%PrepareFunctionForOptimization(f1);
%PrepareFunctionForOptimization(f2);
assertEquals(11, f2(1)); assertEquals(11, f2(1));
%OptimizeFunctionOnNextCall(f1); %OptimizeFunctionOnNextCall(f1);
assertEquals(10, f1(0)); assertEquals(10, f1(0));
......
...@@ -44,6 +44,7 @@ ...@@ -44,6 +44,7 @@
return arguments.length; return arguments.length;
}; };
%PrepareFunctionForOptimization(object.a);
assertSame(0, object.a()); assertSame(0, object.a());
assertSame(0, object.a()); assertSame(0, object.a());
%OptimizeFunctionOnNextCall(object.a); %OptimizeFunctionOnNextCall(object.a);
...@@ -71,6 +72,7 @@ ...@@ -71,6 +72,7 @@
return arguments.length; return arguments.length;
}; };
%PrepareFunctionForOptimization(object.a);
assertSame(8, object.a()); assertSame(8, object.a());
assertSame(8, object.a()); assertSame(8, object.a());
%OptimizeFunctionOnNextCall(object.a); %OptimizeFunctionOnNextCall(object.a);
......
...@@ -40,6 +40,7 @@ function foo(x, fun) { ...@@ -40,6 +40,7 @@ function foo(x, fun) {
return 0; return 0;
} }
%PrepareFunctionForOptimization(foo);
assertEquals(0, foo(1, funky)); assertEquals(0, foo(1, funky));
assertEquals(0, foo(1, funky)); assertEquals(0, foo(1, funky));
%OptimizeFunctionOnNextCall(foo); %OptimizeFunctionOnNextCall(foo);
......
...@@ -32,6 +32,7 @@ function f(o) { ...@@ -32,6 +32,7 @@ function f(o) {
if (true) return o.v && a; if (true) return o.v && a;
} }
%PrepareFunctionForOptimization(f);
f({}); f({});
f({}); f({});
%OptimizeFunctionOnNextCall(f); %OptimizeFunctionOnNextCall(f);
...@@ -43,6 +44,8 @@ function f2() { return 1 || 2; }; ...@@ -43,6 +44,8 @@ function f2() { return 1 || 2; };
function f3() { return 0 && 2; }; function f3() { return 0 && 2; };
function f4() { return 0 || 2; }; function f4() { return 0 || 2; };
[f1, f2, f3, f4].forEach(function(f) { %PrepareFunctionForOptimization(f); });
function test() { function test() {
assertEquals(2, f1()); assertEquals(2, f1());
assertEquals(1, f2()); assertEquals(1, f2());
......
...@@ -27,6 +27,7 @@ function g() { ...@@ -27,6 +27,7 @@ function g() {
return h(b); return h(b);
} }
%PrepareFunctionForOptimization(g);
g(); g();
g(); g();
%OptimizeFunctionOnNextCall(g); %OptimizeFunctionOnNextCall(g);
......
...@@ -10,6 +10,7 @@ function f(foo) { ...@@ -10,6 +10,7 @@ function f(foo) {
if (null != g) {} if (null != g) {}
}; };
%PrepareFunctionForOptimization(f);
f(1.4); f(1.4);
f(1.4); f(1.4);
%OptimizeFunctionOnNextCall(f); %OptimizeFunctionOnNextCall(f);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment