Index: src/compiler/js-create-lowering.cc |
diff --git a/src/compiler/js-create-lowering.cc b/src/compiler/js-create-lowering.cc |
index 6874f301f7b74b947211e38fd72d40b905c64cac..0a5e9f5a6aa18dc2a60bde235ea200e7fac3b453 100644 |
--- a/src/compiler/js-create-lowering.cc |
+++ b/src/compiler/js-create-lowering.cc |
@@ -762,12 +762,15 @@ Reduction JSCreateLowering::ReduceJSCreateClosure(Node* node) { |
Node* function_map = jsgraph()->HeapConstant( |
handle(Map::cast(native_context()->get(function_map_index)), isolate())); |
+ FeedbackVectorSlot slot = p.feedback().slot(); |
+ Node* literals = jsgraph()->HeapConstant( |
+ handle(LiteralsArray::cast(p.feedback().vector()->Get(slot)), isolate())); |
+ |
// Note that it is only safe to embed the raw entry point of the compile |
// lazy stub into the code, because that stub is immortal and immovable. |
Node* compile_entry = jsgraph()->PointerConstant( |
jsgraph()->isolate()->builtins()->CompileLazy()->entry()); |
Node* empty_fixed_array = jsgraph()->EmptyFixedArrayConstant(); |
- Node* empty_literals_array = jsgraph()->EmptyLiteralsArrayConstant(); |
Node* the_hole = jsgraph()->TheHoleConstant(); |
Node* undefined = jsgraph()->UndefinedConstant(); |
AllocationBuilder a(jsgraph(), effect, control); |
@@ -776,7 +779,7 @@ Reduction JSCreateLowering::ReduceJSCreateClosure(Node* node) { |
a.Store(AccessBuilder::ForMap(), function_map); |
a.Store(AccessBuilder::ForJSObjectProperties(), empty_fixed_array); |
a.Store(AccessBuilder::ForJSObjectElements(), empty_fixed_array); |
- a.Store(AccessBuilder::ForJSFunctionLiterals(), empty_literals_array); |
+ a.Store(AccessBuilder::ForJSFunctionLiterals(), literals); |
a.Store(AccessBuilder::ForJSFunctionPrototypeOrInitialMap(), the_hole); |
a.Store(AccessBuilder::ForJSFunctionSharedFunctionInfo(), shared); |
a.Store(AccessBuilder::ForJSFunctionContext(), context); |