 Chromium Code Reviews
 Chromium Code Reviews Issue 2294913006:
  [Interpreter] Enable allocation site mementos in CreateArrayLiterals.  (Closed)
    
  
    Issue 2294913006:
  [Interpreter] Enable allocation site mementos in CreateArrayLiterals.  (Closed) 
  | OLD | NEW | 
|---|---|
| 1 // Copyright 2015 the V8 project authors. All rights reserved. | 1 // Copyright 2015 the V8 project authors. All rights reserved. | 
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be | 
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. | 
| 4 | 4 | 
| 5 #include "src/interpreter/bytecode-generator.h" | 5 #include "src/interpreter/bytecode-generator.h" | 
| 6 | 6 | 
| 7 #include "src/ast/scopes.h" | 7 #include "src/ast/scopes.h" | 
| 8 #include "src/code-stubs.h" | 8 #include "src/code-stubs.h" | 
| 9 #include "src/compilation-info.h" | 9 #include "src/compilation-info.h" | 
| 10 #include "src/compiler.h" | 10 #include "src/compiler.h" | 
| (...skipping 1864 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1875 break; | 1875 break; | 
| 1876 } | 1876 } | 
| 1877 } | 1877 } | 
| 1878 | 1878 | 
| 1879 execution_result()->SetResultInRegister(literal); | 1879 execution_result()->SetResultInRegister(literal); | 
| 1880 } | 1880 } | 
| 1881 | 1881 | 
| 1882 void BytecodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) { | 1882 void BytecodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) { | 
| 1883 // Deep-copy the literal boilerplate. | 1883 // Deep-copy the literal boilerplate. | 
| 1884 builder()->CreateArrayLiteral(expr->constant_elements(), | 1884 builder()->CreateArrayLiteral(expr->constant_elements(), | 
| 1885 expr->literal_index(), | 1885 expr->literal_index(), expr->ComputeFlags()); | 
| 1886 expr->ComputeFlags(true)); | |
| 
mythria
2016/09/02 15:06:53
Ross, I think this is the only change that is requ
 
rmcilroy
2016/09/05 09:28:33
AST Graph Builder doesn't create mementos (presuma
 
Michael Starzinger
2016/09/05 12:23:04
Yes, correct. The reasoning was that only the unop
 | |
| 1887 Register index, literal; | 1886 Register index, literal; | 
| 1888 | 1887 | 
| 1889 // Evaluate all the non-constant subexpressions and store them into the | 1888 // Evaluate all the non-constant subexpressions and store them into the | 
| 1890 // newly cloned array. | 1889 // newly cloned array. | 
| 1891 bool literal_in_accumulator = true; | 1890 bool literal_in_accumulator = true; | 
| 1892 for (int array_index = 0; array_index < expr->values()->length(); | 1891 for (int array_index = 0; array_index < expr->values()->length(); | 
| 1893 array_index++) { | 1892 array_index++) { | 
| 1894 Expression* subexpr = expr->values()->at(array_index); | 1893 Expression* subexpr = expr->values()->at(array_index); | 
| 1895 if (CompileTimeValue::IsCompileTimeValue(subexpr)) continue; | 1894 if (CompileTimeValue::IsCompileTimeValue(subexpr)) continue; | 
| 1896 DCHECK(!subexpr->IsSpread()); | 1895 DCHECK(!subexpr->IsSpread()); | 
| (...skipping 1507 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 3404 return execution_context()->scope()->language_mode(); | 3403 return execution_context()->scope()->language_mode(); | 
| 3405 } | 3404 } | 
| 3406 | 3405 | 
| 3407 int BytecodeGenerator::feedback_index(FeedbackVectorSlot slot) const { | 3406 int BytecodeGenerator::feedback_index(FeedbackVectorSlot slot) const { | 
| 3408 return TypeFeedbackVector::GetIndex(slot); | 3407 return TypeFeedbackVector::GetIndex(slot); | 
| 3409 } | 3408 } | 
| 3410 | 3409 | 
| 3411 } // namespace interpreter | 3410 } // namespace interpreter | 
| 3412 } // namespace internal | 3411 } // namespace internal | 
| 3413 } // namespace v8 | 3412 } // namespace v8 | 
| OLD | NEW |