Commit 9ee6ca75 authored by mstarzinger's avatar mstarzinger Committed by Commit bot

[turbofan] Switch inlining tests to global scope.

This switches our inlining tests (i.e. cctest/test-run-inlining) to rely
on global object instead of function context specialization, which is
more in sync with what we are actually shipping. It will also allow us
to test inlining with the BytecodeGraphBuilder without having to add
support for function context specialization just for testing purposes.

R=bmeurer@chromium.org
TEST=cctest/test-run-inlining
BUG=v8:5251

Review-Url: https://codereview.chromium.org/2200673002
Cr-Commit-Position: refs/heads/master@{#38209}
parent 061d082d
...@@ -405,9 +405,7 @@ ...@@ -405,9 +405,7 @@
############################################################################## ##############################################################################
['ignition_turbofan', { ['ignition_turbofan', {
# TODO(rmcilroy,4837): Inlining is currently disabled for the BytecodeGraphBuilder # TODO(5251): Inlining is currently disabled for the BytecodeGraphBuilder.
# (see InliningPhase::Run). Also, we don't set a LoadContextSlot for a function as
# immutable in the BytecodeGraphBuilder, therefore no inlining happens.
'test-run-inlining/InlineLoopGuardedTwice': [FAIL], 'test-run-inlining/InlineLoopGuardedTwice': [FAIL],
'test-run-inlining/InlineSurplusArgumentsDeopt': [FAIL], 'test-run-inlining/InlineSurplusArgumentsDeopt': [FAIL],
'test-run-inlining/InlineTwice': [FAIL], 'test-run-inlining/InlineTwice': [FAIL],
......
...@@ -30,7 +30,7 @@ class FunctionTester : public InitializedHandleScope { ...@@ -30,7 +30,7 @@ class FunctionTester : public InitializedHandleScope {
flags_(flags) { flags_(flags) {
Compile(function); Compile(function);
const uint32_t supported_flags = const uint32_t supported_flags =
CompilationInfo::kFunctionContextSpecializing | CompilationInfo::kNativeContextSpecializing |
CompilationInfo::kInliningEnabled; CompilationInfo::kInliningEnabled;
CHECK_EQ(0u, flags_ & ~supported_flags); CHECK_EQ(0u, flags_ & ~supported_flags);
} }
...@@ -212,8 +212,8 @@ class FunctionTester : public InitializedHandleScope { ...@@ -212,8 +212,8 @@ class FunctionTester : public InitializedHandleScope {
CHECK(Parser::ParseStatic(info.parse_info())); CHECK(Parser::ParseStatic(info.parse_info()));
} }
info.SetOptimizing(); info.SetOptimizing();
if (flags_ & CompilationInfo::kFunctionContextSpecializing) { if (flags_ & CompilationInfo::kNativeContextSpecializing) {
info.MarkAsFunctionContextSpecializing(); info.MarkAsNativeContextSpecializing();
} }
if (flags_ & CompilationInfo::kInliningEnabled) { if (flags_ & CompilationInfo::kInliningEnabled) {
info.MarkAsInliningEnabled(); info.MarkAsInliningEnabled();
......
...@@ -48,21 +48,19 @@ void InstallAssertInlineCountHelper(v8::Isolate* isolate) { ...@@ -48,21 +48,19 @@ void InstallAssertInlineCountHelper(v8::Isolate* isolate) {
} }
const uint32_t kRestrictedInliningFlags = const uint32_t kRestrictedInliningFlags =
CompilationInfo::kFunctionContextSpecializing; CompilationInfo::kNativeContextSpecializing;
const uint32_t kInlineFlags = CompilationInfo::kInliningEnabled | const uint32_t kInlineFlags = CompilationInfo::kInliningEnabled |
CompilationInfo::kFunctionContextSpecializing; CompilationInfo::kNativeContextSpecializing;
} // namespace } // namespace
TEST(SimpleInlining) { TEST(SimpleInlining) {
FunctionTester T( FunctionTester T(
"(function(){" "function foo(s) { AssertInlineCount(2); return s; };"
" function foo(s) { AssertInlineCount(2); return s; };" "function bar(s, t) { return foo(s); };"
" function bar(s, t) { return foo(s); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -72,11 +70,9 @@ TEST(SimpleInlining) { ...@@ -72,11 +70,9 @@ TEST(SimpleInlining) {
TEST(SimpleInliningDeopt) { TEST(SimpleInliningDeopt) {
FunctionTester T( FunctionTester T(
"(function(){" "function foo(s) { %DeoptimizeFunction(bar); return s; };"
" function foo(s) { %DeoptimizeFunction(bar); return s; };" "function bar(s, t) { return foo(s); };"
" function bar(s, t) { return foo(s); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -86,11 +82,9 @@ TEST(SimpleInliningDeopt) { ...@@ -86,11 +82,9 @@ TEST(SimpleInliningDeopt) {
TEST(SimpleInliningDeoptSelf) { TEST(SimpleInliningDeoptSelf) {
FunctionTester T( FunctionTester T(
"(function(){" "function foo(s) { %_DeoptimizeNow(); return s; };"
" function foo(s) { %_DeoptimizeNow(); return s; };" "function bar(s, t) { return foo(s); };"
" function bar(s, t) { return foo(s); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -100,11 +94,9 @@ TEST(SimpleInliningDeoptSelf) { ...@@ -100,11 +94,9 @@ TEST(SimpleInliningDeoptSelf) {
TEST(SimpleInliningContext) { TEST(SimpleInliningContext) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(s) { AssertInlineCount(2); var x = 12; return s + x; };"
" function foo(s) { AssertInlineCount(2); var x = 12; return s + x; };" "function bar(s, t) { return foo(s); };"
" function bar(s, t) { return foo(s); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -114,14 +106,12 @@ TEST(SimpleInliningContext) { ...@@ -114,14 +106,12 @@ TEST(SimpleInliningContext) {
TEST(SimpleInliningContextDeopt) { TEST(SimpleInliningContextDeopt) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(s) {"
" function foo(s) {" " AssertInlineCount(2); %DeoptimizeFunction(bar); var x = 12;"
" AssertInlineCount(2); %DeoptimizeFunction(bar); var x = 12;" " return s + x;"
" return s + x;" "};"
" };" "function bar(s, t) { return foo(s); };"
" function bar(s, t) { return foo(s); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -149,10 +139,8 @@ TEST(CaptureContext) { ...@@ -149,10 +139,8 @@ TEST(CaptureContext) {
TEST(DontInlineEval) { TEST(DontInlineEval) {
FunctionTester T( FunctionTester T(
"var x = 42;" "var x = 42;"
"(function () {" "function bar(s, t) { return eval(\"AssertInlineCount(1); x\") };"
" function bar(s, t) { return eval(\"AssertInlineCount(1); x\") };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -162,12 +150,10 @@ TEST(DontInlineEval) { ...@@ -162,12 +150,10 @@ TEST(DontInlineEval) {
TEST(InlineOmitArguments) { TEST(InlineOmitArguments) {
FunctionTester T( FunctionTester T(
"(function () {" "var x = 42;"
" var x = 42;" "function bar(s, t, u, v) { AssertInlineCount(2); return x + s; };"
" function bar(s, t, u, v) { AssertInlineCount(2); return x + s; };" "function foo(s, t) { return bar(s); };"
" function foo(s, t) { return bar(s); };" "foo;",
" return foo;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -177,13 +163,11 @@ TEST(InlineOmitArguments) { ...@@ -177,13 +163,11 @@ TEST(InlineOmitArguments) {
TEST(InlineOmitArgumentsObject) { TEST(InlineOmitArgumentsObject) {
FunctionTester T( FunctionTester T(
"(function () {" "function bar(s, t, u, v) { AssertInlineCount(2); return arguments; };"
" function bar(s, t, u, v) { AssertInlineCount(2); return arguments; };" "function foo(s, t) { var args = bar(s);"
" function foo(s, t) { var args = bar(s);" " return args.length == 1 &&"
" return args.length == 1 &&" " args[0] == 11; };"
" args[0] == 11; };" "foo;",
" return foo;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -193,14 +177,12 @@ TEST(InlineOmitArgumentsObject) { ...@@ -193,14 +177,12 @@ TEST(InlineOmitArgumentsObject) {
TEST(InlineOmitArgumentsDeopt) { TEST(InlineOmitArgumentsDeopt) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(s,t,u,v) { AssertInlineCount(2);"
" function foo(s,t,u,v) { AssertInlineCount(2);" " %DeoptimizeFunction(bar); return baz(); };"
" %DeoptimizeFunction(bar); return baz(); };" "function bar() { return foo(11); };"
" function bar() { return foo(11); };" "function baz() { return foo.arguments.length == 1 &&"
" function baz() { return foo.arguments.length == 1 &&" " foo.arguments[0] == 11; }"
" foo.arguments[0] == 11; }" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -210,12 +192,10 @@ TEST(InlineOmitArgumentsDeopt) { ...@@ -210,12 +192,10 @@ TEST(InlineOmitArgumentsDeopt) {
TEST(InlineSurplusArguments) { TEST(InlineSurplusArguments) {
FunctionTester T( FunctionTester T(
"(function () {" "var x = 42;"
" var x = 42;" "function foo(s) { AssertInlineCount(2); return x + s; };"
" function foo(s) { AssertInlineCount(2); return x + s; };" "function bar(s, t) { return foo(s, t, 13); };"
" function bar(s, t) { return foo(s, t, 13); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -225,15 +205,13 @@ TEST(InlineSurplusArguments) { ...@@ -225,15 +205,13 @@ TEST(InlineSurplusArguments) {
TEST(InlineSurplusArgumentsObject) { TEST(InlineSurplusArgumentsObject) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(s) { AssertInlineCount(2); return arguments; };"
" function foo(s) { AssertInlineCount(2); return arguments; };" "function bar(s, t) { var args = foo(s, t, 13);"
" function bar(s, t) { var args = foo(s, t, 13);" " return args.length == 3 &&"
" return args.length == 3 &&" " args[0] == 11 &&"
" args[0] == 11 &&" " args[1] == 12 &&"
" args[1] == 12 &&" " args[2] == 13; };"
" args[2] == 13; };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -243,16 +221,14 @@ TEST(InlineSurplusArgumentsObject) { ...@@ -243,16 +221,14 @@ TEST(InlineSurplusArgumentsObject) {
TEST(InlineSurplusArgumentsDeopt) { TEST(InlineSurplusArgumentsDeopt) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(s) { AssertInlineCount(2); %DeoptimizeFunction(bar);"
" function foo(s) { AssertInlineCount(2); %DeoptimizeFunction(bar);" " return baz(); };"
" return baz(); };" "function bar() { return foo(13, 14, 15); };"
" function bar() { return foo(13, 14, 15); };" "function baz() { return foo.arguments.length == 3 &&"
" function baz() { return foo.arguments.length == 3 &&" " foo.arguments[0] == 13 &&"
" foo.arguments[0] == 13 &&" " foo.arguments[1] == 14 &&"
" foo.arguments[1] == 14 &&" " foo.arguments[2] == 15; }"
" foo.arguments[2] == 15; }" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -262,12 +238,10 @@ TEST(InlineSurplusArgumentsDeopt) { ...@@ -262,12 +238,10 @@ TEST(InlineSurplusArgumentsDeopt) {
TEST(InlineTwice) { TEST(InlineTwice) {
FunctionTester T( FunctionTester T(
"(function () {" "var x = 42;"
" var x = 42;" "function bar(s) { AssertInlineCount(2); return x + s; };"
" function bar(s) { AssertInlineCount(2); return x + s; };" "function foo(s, t) { return bar(s) + bar(t); };"
" function foo(s, t) { return bar(s) + bar(t); };" "foo;",
" return foo;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -277,12 +251,10 @@ TEST(InlineTwice) { ...@@ -277,12 +251,10 @@ TEST(InlineTwice) {
TEST(InlineTwiceDependent) { TEST(InlineTwiceDependent) {
FunctionTester T( FunctionTester T(
"(function () {" "var x = 42;"
" var x = 42;" "function foo(s) { AssertInlineCount(2); return x + s; };"
" function foo(s) { AssertInlineCount(2); return x + s; };" "function bar(s,t) { return foo(foo(s)); };"
" function bar(s,t) { return foo(foo(s)); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -292,13 +264,11 @@ TEST(InlineTwiceDependent) { ...@@ -292,13 +264,11 @@ TEST(InlineTwiceDependent) {
TEST(InlineTwiceDependentDiamond) { TEST(InlineTwiceDependentDiamond) {
FunctionTester T( FunctionTester T(
"(function () {" "var x = 41;"
" var x = 41;" "function foo(s) { AssertInlineCount(2); if (s % 2 == 0) {"
" function foo(s) { AssertInlineCount(2); if (s % 2 == 0) {" " return x - s } else { return x + s; } };"
" return x - s } else { return x + s; } };" "function bar(s,t) { return foo(foo(s)); };"
" function bar(s,t) { return foo(foo(s)); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -308,13 +278,11 @@ TEST(InlineTwiceDependentDiamond) { ...@@ -308,13 +278,11 @@ TEST(InlineTwiceDependentDiamond) {
TEST(InlineTwiceDependentDiamondDifferent) { TEST(InlineTwiceDependentDiamondDifferent) {
FunctionTester T( FunctionTester T(
"(function () {" "var x = 41;"
" var x = 41;" "function foo(s,t) { AssertInlineCount(2); if (s % 2 == 0) {"
" function foo(s,t) { AssertInlineCount(2); if (s % 2 == 0) {" " return x - s * t } else { return x + s * t; } };"
" return x - s * t } else { return x + s * t; } };" "function bar(s,t) { return foo(foo(s, 3), 5); };"
" function bar(s,t) { return foo(foo(s, 3), 5); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -324,11 +292,9 @@ TEST(InlineTwiceDependentDiamondDifferent) { ...@@ -324,11 +292,9 @@ TEST(InlineTwiceDependentDiamondDifferent) {
TEST(InlineLoopGuardedEmpty) { TEST(InlineLoopGuardedEmpty) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(s) { AssertInlineCount(2); if (s) while (s); return s; };"
" function foo(s) { AssertInlineCount(2); if (s) while (s); return s; };" "function bar(s,t) { return foo(s); };"
" function bar(s,t) { return foo(s); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -338,12 +304,10 @@ TEST(InlineLoopGuardedEmpty) { ...@@ -338,12 +304,10 @@ TEST(InlineLoopGuardedEmpty) {
TEST(InlineLoopGuardedOnce) { TEST(InlineLoopGuardedOnce) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(s,t) { AssertInlineCount(2); if (t > 0) while (s > 0) {"
" function foo(s,t) { AssertInlineCount(2); if (t > 0) while (s > 0) {" " s = s - 1; }; return s; };"
" s = s - 1; }; return s; };" "function bar(s,t) { return foo(s,t); };"
" function bar(s,t) { return foo(s,t); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -353,12 +317,10 @@ TEST(InlineLoopGuardedOnce) { ...@@ -353,12 +317,10 @@ TEST(InlineLoopGuardedOnce) {
TEST(InlineLoopGuardedTwice) { TEST(InlineLoopGuardedTwice) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(s,t) { AssertInlineCount(2); if (t > 0) while (s > 0) {"
" function foo(s,t) { AssertInlineCount(2); if (t > 0) while (s > 0) {" " s = s - 1; }; return s; };"
" s = s - 1; }; return s; };" "function bar(s,t) { return foo(foo(s,t),t); };"
" function bar(s,t) { return foo(foo(s,t),t); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -368,11 +330,9 @@ TEST(InlineLoopGuardedTwice) { ...@@ -368,11 +330,9 @@ TEST(InlineLoopGuardedTwice) {
TEST(InlineLoopUnguardedEmpty) { TEST(InlineLoopUnguardedEmpty) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(s) { AssertInlineCount(2); while (s); return s; };"
" function foo(s) { AssertInlineCount(2); while (s); return s; };" "function bar(s, t) { return foo(s); };"
" function bar(s, t) { return foo(s); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -382,12 +342,10 @@ TEST(InlineLoopUnguardedEmpty) { ...@@ -382,12 +342,10 @@ TEST(InlineLoopUnguardedEmpty) {
TEST(InlineLoopUnguardedOnce) { TEST(InlineLoopUnguardedOnce) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(s) { AssertInlineCount(2); while (s) {"
" function foo(s) { AssertInlineCount(2); while (s) {" " s = s - 1; }; return s; };"
" s = s - 1; }; return s; };" "function bar(s, t) { return foo(s); };"
" function bar(s, t) { return foo(s); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -397,12 +355,10 @@ TEST(InlineLoopUnguardedOnce) { ...@@ -397,12 +355,10 @@ TEST(InlineLoopUnguardedOnce) {
TEST(InlineLoopUnguardedTwice) { TEST(InlineLoopUnguardedTwice) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(s) { AssertInlineCount(2); while (s > 0) {"
" function foo(s) { AssertInlineCount(2); while (s > 0) {" " s = s - 1; }; return s; };"
" s = s - 1; }; return s; };" "function bar(s,t) { return foo(foo(s,t),t); };"
" function bar(s,t) { return foo(foo(s,t),t); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -412,13 +368,11 @@ TEST(InlineLoopUnguardedTwice) { ...@@ -412,13 +368,11 @@ TEST(InlineLoopUnguardedTwice) {
TEST(InlineStrictIntoNonStrict) { TEST(InlineStrictIntoNonStrict) {
FunctionTester T( FunctionTester T(
"(function () {" "var x = Object.create({}, { y: { value:42, writable:false } });"
" var x = Object.create({}, { y: { value:42, writable:false } });" "function foo(s) { 'use strict';"
" function foo(s) { 'use strict';" " x.y = 9; };"
" x.y = 9; };" "function bar(s,t) { return foo(s); };"
" function bar(s,t) { return foo(s); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -428,12 +382,10 @@ TEST(InlineStrictIntoNonStrict) { ...@@ -428,12 +382,10 @@ TEST(InlineStrictIntoNonStrict) {
TEST(InlineNonStrictIntoStrict) { TEST(InlineNonStrictIntoStrict) {
FunctionTester T( FunctionTester T(
"(function () {" "var x = Object.create({}, { y: { value:42, writable:false } });"
" var x = Object.create({}, { y: { value:42, writable:false } });" "function foo(s) { x.y = 9; return x.y; };"
" function foo(s) { x.y = 9; return x.y; };" "function bar(s,t) { \'use strict\'; return foo(s); };"
" function bar(s,t) { \'use strict\'; return foo(s); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -441,66 +393,16 @@ TEST(InlineNonStrictIntoStrict) { ...@@ -441,66 +393,16 @@ TEST(InlineNonStrictIntoStrict) {
} }
TEST(InlineIntrinsicIsSmi) {
FunctionTester T(
"(function () {"
" var x = 42;"
" function bar(s,t) { return %_IsSmi(x); };"
" return bar;"
"})();",
kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate());
T.CheckCall(T.true_value(), T.Val(12), T.Val(4));
}
TEST(InlineIntrinsicIsArray) {
FunctionTester T(
"(function () {"
" var x = [1,2,3];"
" function bar(s,t) { return %_IsArray(x); };"
" return bar;"
"})();",
kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate());
T.CheckCall(T.true_value(), T.Val(12), T.Val(4));
FunctionTester T2(
"(function () {"
" var x = 32;"
" function bar(s,t) { return %_IsArray(x); };"
" return bar;"
"})();",
kInlineFlags);
T2.CheckCall(T.false_value(), T.Val(12), T.Val(4));
FunctionTester T3(
"(function () {"
" var x = bar;"
" function bar(s,t) { return %_IsArray(x); };"
" return bar;"
"})();",
kInlineFlags);
T3.CheckCall(T.false_value(), T.Val(12), T.Val(4));
}
TEST(InlineWithArguments) { TEST(InlineWithArguments) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(s,t,u) { AssertInlineCount(2);"
" function foo(s,t,u) { AssertInlineCount(2);" " return foo.arguments.length == 3 &&"
" return foo.arguments.length == 3 &&" " foo.arguments[0] == 13 &&"
" foo.arguments[0] == 13 &&" " foo.arguments[1] == 14 &&"
" foo.arguments[1] == 14 &&" " foo.arguments[2] == 15;"
" foo.arguments[2] == 15;" "}"
" }" "function bar() { return foo(13, 14, 15); };"
" function bar() { return foo(13, 14, 15); };" "bar;",
" return bar;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -510,12 +412,10 @@ TEST(InlineWithArguments) { ...@@ -510,12 +412,10 @@ TEST(InlineWithArguments) {
TEST(InlineBuiltin) { TEST(InlineBuiltin) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(s,t,u) { AssertInlineCount(2); return true; }"
" function foo(s,t,u) { AssertInlineCount(2); return true; }" "function bar() { return foo(); };"
" function bar() { return foo(); };" "%SetForceInlineFlag(foo);"
" %SetForceInlineFlag(foo);" "bar;",
" return bar;"
"})();",
kRestrictedInliningFlags); kRestrictedInliningFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -525,14 +425,12 @@ TEST(InlineBuiltin) { ...@@ -525,14 +425,12 @@ TEST(InlineBuiltin) {
TEST(InlineNestedBuiltin) { TEST(InlineNestedBuiltin) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(s,t,u) { AssertInlineCount(3); return true; }"
" function foo(s,t,u) { AssertInlineCount(3); return true; }" "function baz(s,t,u) { return foo(s,t,u); }"
" function baz(s,t,u) { return foo(s,t,u); }" "function bar() { return baz(); };"
" function bar() { return baz(); };" "%SetForceInlineFlag(foo);"
" %SetForceInlineFlag(foo);" "%SetForceInlineFlag(baz);"
" %SetForceInlineFlag(baz);" "bar;",
" return bar;"
"})();",
kRestrictedInliningFlags); kRestrictedInliningFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -542,14 +440,12 @@ TEST(InlineNestedBuiltin) { ...@@ -542,14 +440,12 @@ TEST(InlineNestedBuiltin) {
TEST(InlineSelfRecursive) { TEST(InlineSelfRecursive) {
FunctionTester T( FunctionTester T(
"(function () {" "function foo(x) { "
" function foo(x) { " " AssertInlineCount(1);"
" AssertInlineCount(1);" " if (x == 1) return foo(12);"
" if (x == 1) return foo(12);" " return x;"
" return x;" "}"
" }" "foo;",
" return foo;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
...@@ -559,14 +455,12 @@ TEST(InlineSelfRecursive) { ...@@ -559,14 +455,12 @@ TEST(InlineSelfRecursive) {
TEST(InlineMutuallyRecursive) { TEST(InlineMutuallyRecursive) {
FunctionTester T( FunctionTester T(
"(function () {" "function bar(x) { AssertInlineCount(2); return foo(x); }"
" function bar(x) { AssertInlineCount(2); return foo(x); }" "function foo(x) { "
" function foo(x) { " " if (x == 1) return bar(42);"
" if (x == 1) return bar(42);" " return x;"
" return x;" "}"
" }" "foo;",
" return foo;"
"})();",
kInlineFlags); kInlineFlags);
InstallAssertInlineCountHelper(CcTest::isolate()); InstallAssertInlineCountHelper(CcTest::isolate());
......
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