Chromium Code Reviews| Index: test/cctest/interpreter/test-bytecode-generator.cc |
| diff --git a/test/cctest/interpreter/test-bytecode-generator.cc b/test/cctest/interpreter/test-bytecode-generator.cc |
| index 7524e9c3839afb3c233212d4f13720bb773df71c..dcb153e2b1fe750409d35c7c4602f803ef5be7d9 100644 |
| --- a/test/cctest/interpreter/test-bytecode-generator.cc |
| +++ b/test/cctest/interpreter/test-bytecode-generator.cc |
| @@ -1019,29 +1019,47 @@ TEST(PropertyCall) { |
| TEST(LoadGlobal) { |
| InitializedHandleScope handle_scope; |
| BytecodeGeneratorHelper helper; |
| + Zone zone; |
| - if (!FLAG_global_var_shortcuts) return; |
| + int context_reg = Register::function_context().index(); |
| + int global_index = Context::GLOBAL_OBJECT_INDEX; |
| - ExpectedSnippet<int> snippets[] = { |
| + FeedbackVectorSpec feedback_spec(&zone); |
| + FeedbackVectorSlot slot1 = feedback_spec.AddLoadICSlot(); |
| + |
| + Handle<i::TypeFeedbackVector> vector = |
| + i::NewTypeFeedbackVector(helper.isolate(), &feedback_spec); |
| + |
| + ExpectedSnippet<InstanceType> snippets[] = { |
| { |
| "var a = 1;\nfunction f() { return a; }\nf()", |
| - 0, |
| + kPointerSize, |
| 1, |
| - 3, |
| + 11, |
| { |
| - B(LdaGlobal), _, // |
| - B(Return) // |
| + B(LdaContextSlot), R(context_reg), U8(global_index), // |
| + B(Star), R(0), // |
| + B(LdaConstant), U8(0), // |
| + B(LoadICSloppy), R(0), U8(vector->GetIndex(slot1)), // |
| + B(Return) // |
|
rmcilroy
2015/10/21 16:52:15
This is really a lot more verbose than the LdaGlob
Igor Sheludko
2015/10/21 17:08:55
I totally agree! The plan is to make new kinds of
|
| }, |
| + 1, |
| + {InstanceType::ONE_BYTE_INTERNALIZED_STRING_TYPE}, |
| }, |
| { |
| "function t() { }\nfunction f() { return t; }\nf()", |
| - 0, |
| + kPointerSize, |
| 1, |
| - 3, |
| + 11, |
| { |
| - B(LdaGlobal), _, // |
| - B(Return) // |
| + B(LdaContextSlot), R(context_reg), U8(global_index), // |
| + B(Star), R(0), // |
| + B(LdaConstant), U8(0), // |
| + B(LoadICSloppy), R(0), U8(vector->GetIndex(slot1)), // |
| + B(Return) // |
| }, |
| + 1, |
| + {InstanceType::ONE_BYTE_INTERNALIZED_STRING_TYPE}, |
| }, |
| }; |
| @@ -1056,45 +1074,77 @@ TEST(LoadGlobal) { |
| TEST(StoreGlobal) { |
| InitializedHandleScope handle_scope; |
| BytecodeGeneratorHelper helper; |
| + Zone zone; |
| + |
| + int context_reg = Register::function_context().index(); |
| + int global_index = Context::GLOBAL_OBJECT_INDEX; |
| - if (!FLAG_global_var_shortcuts) return; |
| + FeedbackVectorSpec feedback_spec(&zone); |
| + FeedbackVectorSlot slot1 = feedback_spec.AddStoreICSlot(); |
| + |
| + Handle<i::TypeFeedbackVector> vector = |
| + i::NewTypeFeedbackVector(helper.isolate(), &feedback_spec); |
| ExpectedSnippet<InstanceType> snippets[] = { |
| { |
| "var a = 1;\nfunction f() { a = 2; }\nf()", |
| - 0, |
| + 3 * kPointerSize, |
| 1, |
| - 6, |
| + 21, |
| { |
| - B(LdaSmi8), U8(2), // |
| - B(StaGlobalSloppy), _, // |
| - B(LdaUndefined), // |
| - B(Return) // |
| + B(LdaSmi8), U8(2), // |
| + B(Star), R(0), // |
| + B(LdaContextSlot), R(context_reg), U8(global_index), // |
| + B(Star), R(1), // |
| + B(LdaConstant), U8(0), // |
| + B(Star), R(2), // |
| + B(Ldar), R(0), // |
| + B(StoreICSloppy), R(1), R(2), U8(vector->GetIndex(slot1)), // |
| + B(LdaUndefined), // |
| + B(Return) // |
| }, |
| + 1, |
| + {InstanceType::ONE_BYTE_INTERNALIZED_STRING_TYPE}, |
| }, |
| { |
| "var a = \"test\"; function f(b) { a = b; }\nf(\"global\")", |
| - 0, |
| + 3 * kPointerSize, |
| 2, |
| - 6, |
| + 21, |
| { |
| - B(Ldar), R(helper.kLastParamIndex), // |
| - B(StaGlobalSloppy), _, // |
| - B(LdaUndefined), // |
| - B(Return) // |
| + B(Ldar), R(helper.kLastParamIndex), // |
| + B(Star), R(0), // |
| + B(LdaContextSlot), R(context_reg), U8(global_index), // |
| + B(Star), R(1), // |
| + B(LdaConstant), U8(0), // |
| + B(Star), R(2), // |
| + B(Ldar), R(0), // |
| + B(StoreICSloppy), R(1), R(2), U8(vector->GetIndex(slot1)), // |
| + B(LdaUndefined), // |
| + B(Return) // |
| }, |
| + 1, |
| + {InstanceType::ONE_BYTE_INTERNALIZED_STRING_TYPE}, |
| }, |
| { |
| "'use strict'; var a = 1;\nfunction f() { a = 2; }\nf()", |
| - 0, |
| + 3 * kPointerSize, |
| 1, |
| - 6, |
| + 21, |
| { |
| - B(LdaSmi8), U8(2), // |
| - B(StaGlobalStrict), _, // |
| - B(LdaUndefined), // |
| - B(Return) // |
| + B(LdaSmi8), U8(2), // |
| + B(Star), R(0), // |
| + B(LdaContextSlot), R(context_reg), U8(global_index), // |
| + B(Star), R(1), // |
| + B(LdaConstant), U8(0), // |
| + B(Star), R(2), // |
| + B(Ldar), R(0), // |
| + B(StoreICStrict), R(1), R(2), U8(vector->GetIndex(slot1)), // |
| + B(LdaUndefined), // |
| + B(Return) // |
| }, |
| + 1, |
| + {InstanceType::ONE_BYTE_INTERNALIZED_STRING_TYPE}, |
| }, |
| }; |
| @@ -1109,43 +1159,63 @@ TEST(StoreGlobal) { |
| TEST(CallGlobal) { |
| InitializedHandleScope handle_scope; |
| BytecodeGeneratorHelper helper; |
| + Zone zone; |
| - if (!FLAG_global_var_shortcuts) return; |
| + int context_reg = Register::function_context().index(); |
| + int global_index = Context::GLOBAL_OBJECT_INDEX; |
| - ExpectedSnippet<int> snippets[] = { |
| + FeedbackVectorSpec feedback_spec(&zone); |
| + FeedbackVectorSlot slot1 = feedback_spec.AddCallICSlot(); |
| + FeedbackVectorSlot slot2 = feedback_spec.AddLoadICSlot(); |
| + USE(slot1); |
| + |
| + Handle<i::TypeFeedbackVector> vector = |
| + i::NewTypeFeedbackVector(helper.isolate(), &feedback_spec); |
| + |
| + ExpectedSnippet<InstanceType> snippets[] = { |
| { |
| "function t() { }\nfunction f() { return t(); }\nf()", |
| - 2 * kPointerSize, |
| + 3 * kPointerSize, |
| 1, |
| - 12, |
| + 20, |
| { |
| - B(LdaUndefined), // |
| - B(Star), R(1), // |
| - B(LdaGlobal), _, // |
| - B(Star), R(0), // |
| - B(Call), R(0), R(1), U8(0), // |
| - B(Return) // |
| + B(LdaUndefined), // |
| + B(Star), R(1), // |
| + B(LdaContextSlot), R(context_reg), U8(global_index), // |
| + B(Star), R(2), // |
| + B(LdaConstant), U8(0), // |
| + B(LoadICSloppy), R(2), U8(vector->GetIndex(slot2)), // |
| + B(Star), R(0), // |
| + B(Call), R(0), R(1), U8(0), // |
| + B(Return) // |
| }, |
| + 1, |
| + {InstanceType::ONE_BYTE_INTERNALIZED_STRING_TYPE}, |
| }, |
| { |
| "function t(a, b, c) { }\nfunction f() { return t(1, 2, 3); }\nf()", |
| 5 * kPointerSize, |
| 1, |
| - 24, |
| + 32, |
| { |
| - B(LdaUndefined), // |
| - B(Star), R(1), // |
| - B(LdaGlobal), _, // |
| - B(Star), R(0), // |
| - B(LdaSmi8), U8(1), // |
| - B(Star), R(2), // |
| - B(LdaSmi8), U8(2), // |
| - B(Star), R(3), // |
| - B(LdaSmi8), U8(3), // |
| - B(Star), R(4), // |
| - B(Call), R(0), R(1), U8(3), // |
| - B(Return) // |
| + B(LdaUndefined), // |
| + B(Star), R(1), // |
| + B(LdaContextSlot), R(context_reg), U8(global_index), // |
| + B(Star), R(2), // |
| + B(LdaConstant), U8(0), // |
| + B(LoadICSloppy), R(2), U8(vector->GetIndex(slot2)), // |
| + B(Star), R(0), // |
| + B(LdaSmi8), U8(1), // |
| + B(Star), R(2), // |
| + B(LdaSmi8), U8(2), // |
| + B(Star), R(3), // |
| + B(LdaSmi8), U8(3), // |
| + B(Star), R(4), // |
| + B(Call), R(0), R(1), U8(3), // |
| + B(Return) // |
| }, |
| + 1, |
| + {InstanceType::ONE_BYTE_INTERNALIZED_STRING_TYPE}, |
| }, |
| }; |
| @@ -1480,14 +1550,11 @@ TEST(IfConditions) { |
| } |
| -// Tests !FLAG_global_var_shortcuts mode. |
| TEST(DeclareGlobals) { |
| InitializedHandleScope handle_scope; |
| BytecodeGeneratorHelper helper; |
| Zone zone; |
| - if (FLAG_global_var_shortcuts) return; |
| - |
| int context_reg = Register::function_context().index(); |
| int global_index = Context::GLOBAL_OBJECT_INDEX; |
| @@ -1615,135 +1682,6 @@ TEST(DeclareGlobals) { |
| } |
| -// Tests FLAG_global_var_shortcuts mode. |
| -// TODO(ishell): remove when FLAG_global_var_shortcuts is removed. |
| -TEST(DeclareGlobals2) { |
| - InitializedHandleScope handle_scope; |
| - BytecodeGeneratorHelper helper; |
| - |
| - if (!FLAG_global_var_shortcuts) return; |
| - |
| - ExpectedSnippet<InstanceType> snippets[] = { |
| - {"var a = 1;", |
| - 5 * kPointerSize, |
| - 1, |
| - 45, |
| - { |
| - B(Ldar), R(Register::function_closure().index()), // |
| - B(Star), R(2), // |
| - B(LdaConstant), U8(0), // |
| - B(Star), R(3), // |
| - B(CallRuntime), U16(Runtime::kNewScriptContext), R(2), U8(2), // |
| - B(PushContext), R(1), // |
| - B(LdaConstant), U8(1), // |
| - B(Star), R(2), // |
| - B(LdaZero), // |
| - B(Star), R(3), // |
| - B(CallRuntime), U16(Runtime::kDeclareGlobals), R(2), U8(2), // |
| - B(LdaConstant), U8(2), // |
| - B(Star), R(2), // |
| - B(LdaZero), // |
| - B(Star), R(3), // |
| - B(LdaSmi8), U8(1), // |
| - B(Star), R(4), // |
| - B(CallRuntime), U16(Runtime::kInitializeVarGlobal), R(2), U8(3), // |
| - B(LdaUndefined), // |
| - B(Return), // |
| - }, |
| - 3, |
| - {InstanceType::FIXED_ARRAY_TYPE, InstanceType::FIXED_ARRAY_TYPE, |
| - InstanceType::ONE_BYTE_INTERNALIZED_STRING_TYPE}}, |
| - {"function f() {}", |
| - 3 * kPointerSize, |
| - 1, |
| - 29, |
| - { |
| - B(Ldar), R(Register::function_closure().index()), // |
| - B(Star), R(1), // |
| - B(LdaConstant), U8(0), // |
| - B(Star), R(2), // |
| - B(CallRuntime), U16(Runtime::kNewScriptContext), R(1), U8(2), // |
| - B(PushContext), R(0), // |
| - B(LdaConstant), U8(1), // |
| - B(Star), R(1), // |
| - B(LdaZero), // |
| - B(Star), R(2), // |
| - B(CallRuntime), U16(Runtime::kDeclareGlobals), R(1), U8(2), // |
| - B(LdaUndefined), // |
| - B(Return) // |
| - }, |
| - 2, |
| - {InstanceType::FIXED_ARRAY_TYPE, InstanceType::FIXED_ARRAY_TYPE}}, |
| - {"var a = 1;\na=2;", |
| - 5 * kPointerSize, |
| - 1, |
| - 52, |
| - { |
| - B(Ldar), R(Register::function_closure().index()), // |
| - B(Star), R(2), // |
| - B(LdaConstant), U8(0), // |
| - B(Star), R(3), // |
| - B(CallRuntime), U16(Runtime::kNewScriptContext), R(2), U8(2), // |
| - B(PushContext), R(1), // |
| - B(LdaConstant), U8(1), // |
| - B(Star), R(2), // |
| - B(LdaZero), // |
| - B(Star), R(3), // |
| - B(CallRuntime), U16(Runtime::kDeclareGlobals), R(2), U8(2), // |
| - B(LdaConstant), U8(2), // |
| - B(Star), R(2), // |
| - B(LdaZero), // |
| - B(Star), R(3), // |
| - B(LdaSmi8), U8(1), // |
| - B(Star), R(4), // |
| - B(CallRuntime), U16(Runtime::kInitializeVarGlobal), R(2), // |
| - U8(3), // |
| - B(LdaSmi8), U8(2), // |
| - B(StaGlobalSloppy), _, // |
| - B(Star), R(0), // |
| - B(Ldar), R(0), // |
| - B(Return) // |
| - }, |
| - 3, |
| - {InstanceType::FIXED_ARRAY_TYPE, InstanceType::FIXED_ARRAY_TYPE, |
| - InstanceType::ONE_BYTE_INTERNALIZED_STRING_TYPE}}, |
| - {"function f() {}\nf();", |
| - 4 * kPointerSize, |
| - 1, |
| - 43, |
| - { |
| - B(Ldar), R(Register::function_closure().index()), // |
| - B(Star), R(2), // |
| - B(LdaConstant), U8(0), // |
| - B(Star), R(3), // |
| - B(CallRuntime), U16(Runtime::kNewScriptContext), R(2), U8(2), // |
| - B(PushContext), R(1), // |
| - B(LdaConstant), U8(1), // |
| - B(Star), R(2), // |
| - B(LdaZero), // |
| - B(Star), R(3), // |
| - B(CallRuntime), U16(Runtime::kDeclareGlobals), R(2), U8(2), // |
| - B(LdaUndefined), // |
| - B(Star), R(3), // |
| - B(LdaGlobal), _, // |
| - B(Star), R(2), // |
| - B(Call), R(2), R(3), U8(0), // |
| - B(Star), R(0), // |
| - B(Ldar), R(0), // |
| - B(Return) // |
| - }, |
| - 2, |
| - {InstanceType::FIXED_ARRAY_TYPE, InstanceType::FIXED_ARRAY_TYPE}}, |
| - }; |
| - |
| - for (size_t i = 0; i < arraysize(snippets); i++) { |
| - Handle<BytecodeArray> bytecode_array = |
| - helper.MakeTopLevelBytecode(snippets[i].code_snippet); |
| - CheckBytecodeArrayEqual(snippets[i], bytecode_array, true); |
| - } |
| -} |
| - |
| - |
| TEST(BasicLoops) { |
| InitializedHandleScope handle_scope; |
| BytecodeGeneratorHelper helper; |
| @@ -2679,13 +2617,10 @@ TEST(ObjectLiterals) { |
| } |
| -// Tests !FLAG_global_var_shortcuts mode. |
| TEST(TopLevelObjectLiterals) { |
| InitializedHandleScope handle_scope; |
| BytecodeGeneratorHelper helper; |
| - if (FLAG_global_var_shortcuts) return; |
| - |
| int has_function_flags = ObjectLiteral::kFastElements | |
| ObjectLiteral::kHasFunction | |
| ObjectLiteral::kDisableMementos; |
| @@ -2735,70 +2670,6 @@ TEST(TopLevelObjectLiterals) { |
| } |
| -// Tests FLAG_global_var_shortcuts mode. |
| -// TODO(ishell): remove when FLAG_global_var_shortcuts is removed. |
| -TEST(TopLevelObjectLiterals2) { |
| - InitializedHandleScope handle_scope; |
| - BytecodeGeneratorHelper helper; |
| - |
| - if (!FLAG_global_var_shortcuts) return; |
| - |
| - int has_function_flags = ObjectLiteral::kFastElements | |
| - ObjectLiteral::kHasFunction | |
| - ObjectLiteral::kDisableMementos; |
| - ExpectedSnippet<InstanceType> snippets[] = { |
| - {"var a = { func: function() { } };", |
| - 7 * kPointerSize, |
| - 1, |
| - 69, |
| - { |
| - B(Ldar), R(Register::function_closure().index()), // |
| - B(Star), R(2), // |
| - B(LdaConstant), U8(0), // |
| - B(Star), R(3), // |
| - B(CallRuntime), U16(Runtime::kNewScriptContext), R(2), U8(2), // |
| - B(PushContext), R(1), // |
| - B(LdaConstant), U8(1), // |
| - B(Star), R(2), // |
| - B(LdaZero), // |
| - B(Star), R(3), // |
| - B(CallRuntime), U16(Runtime::kDeclareGlobals), R(2), U8(2), // |
| - B(LdaConstant), U8(2), // |
| - B(Star), R(2), // |
| - B(LdaZero), // |
| - B(Star), R(3), // |
| - B(LdaConstant), U8(3), // |
| - B(CreateObjectLiteral), U8(0), U8(has_function_flags), // |
| - B(Star), R(5), // |
| - B(LdaConstant), U8(4), // |
| - B(Star), R(6), // |
| - B(LdaConstant), U8(5), // |
| - B(CreateClosure), U8(1), // |
| - B(StoreICSloppy), R(5), R(6), U8(3), // |
| - B(CallRuntime), U16(Runtime::kToFastProperties), R(5), U8(1), // |
| - B(Ldar), R(5), // |
| - B(Star), R(4), // |
| - B(CallRuntime), U16(Runtime::kInitializeVarGlobal), R(2), U8(3), // |
| - B(LdaUndefined), // |
| - B(Return), |
| - }, |
| - 6, |
| - {InstanceType::FIXED_ARRAY_TYPE, |
| - InstanceType::FIXED_ARRAY_TYPE, |
| - InstanceType::ONE_BYTE_INTERNALIZED_STRING_TYPE, |
| - InstanceType::FIXED_ARRAY_TYPE, |
| - InstanceType::ONE_BYTE_INTERNALIZED_STRING_TYPE, |
| - InstanceType::SHARED_FUNCTION_INFO_TYPE}}, |
| - }; |
| - |
| - for (size_t i = 0; i < arraysize(snippets); i++) { |
| - Handle<BytecodeArray> bytecode_array = |
| - helper.MakeTopLevelBytecode(snippets[i].code_snippet); |
| - CheckBytecodeArrayEqual(snippets[i], bytecode_array); |
| - } |
| -} |
| - |
| - |
| TEST(TryCatch) { |
| InitializedHandleScope handle_scope; |
| BytecodeGeneratorHelper helper; |
| @@ -2922,14 +2793,11 @@ TEST(Throw) { |
| } |
| -// Tests !FLAG_global_var_shortcuts mode. |
| TEST(CallNew) { |
| InitializedHandleScope handle_scope; |
| BytecodeGeneratorHelper helper; |
| Zone zone; |
| - if (FLAG_global_var_shortcuts) return; |
| - |
| int context_reg = Register::function_context().index(); |
| int global_index = Context::GLOBAL_OBJECT_INDEX; |
| @@ -3016,76 +2884,6 @@ TEST(CallNew) { |
| } |
| -// Tests FLAG_global_var_shortcuts mode. |
| -// TODO(ishell): remove when FLAG_global_var_shortcuts is removed. |
| -TEST(CallNew2) { |
| - InitializedHandleScope handle_scope; |
| - BytecodeGeneratorHelper helper; |
| - |
| - if (!FLAG_global_var_shortcuts) return; |
| - |
| - ExpectedSnippet<InstanceType> snippets[] = { |
| - {"function bar() { this.value = 0; }\n" |
| - "function f() { return new bar(); }\n" |
| - "f()", |
| - kPointerSize, |
| - 1, |
| - 9, |
| - { |
| - B(LdaGlobal), _, // |
| - B(Star), R(0), // |
| - B(New), R(0), R(0), U8(0), // |
| - B(Return), // |
| - }, |
| - 0}, |
| - {"function bar(x) { this.value = 18; this.x = x;}\n" |
| - "function f() { return new bar(3); }\n" |
| - "f()", |
| - 2 * kPointerSize, |
| - 1, |
| - 13, |
| - { |
| - B(LdaGlobal), _, // |
| - B(Star), R(0), // |
| - B(LdaSmi8), U8(3), // |
| - B(Star), R(1), // |
| - B(New), R(0), R(1), U8(1), // |
| - B(Return), // |
| - }, |
| - 0}, |
| - {"function bar(w, x, y, z) {\n" |
| - " this.value = 18;\n" |
| - " this.x = x;\n" |
| - " this.y = y;\n" |
| - " this.z = z;\n" |
| - "}\n" |
| - "function f() { return new bar(3, 4, 5); }\n" |
| - "f()", |
| - 4 * kPointerSize, |
| - 1, |
| - 21, |
| - { |
| - B(LdaGlobal), _, // |
| - B(Star), R(0), // |
| - B(LdaSmi8), U8(3), // |
| - B(Star), R(1), // |
| - B(LdaSmi8), U8(4), // |
| - B(Star), R(2), // |
| - B(LdaSmi8), U8(5), // |
| - B(Star), R(3), // |
| - B(New), R(0), R(1), U8(3), // |
| - B(Return), // |
| - }, |
| - 0}}; |
| - |
| - for (size_t i = 0; i < arraysize(snippets); i++) { |
| - Handle<BytecodeArray> bytecode_array = |
| - helper.MakeBytecode(snippets[i].code_snippet, "f"); |
| - CheckBytecodeArrayEqual(snippets[i], bytecode_array, true); |
| - } |
| -} |
| - |
| - |
| TEST(ContextVariables) { |
| InitializedHandleScope handle_scope; |
| BytecodeGeneratorHelper helper; |