| Index: src/hydrogen.cc
 | 
| diff --git a/src/hydrogen.cc b/src/hydrogen.cc
 | 
| index 0aa96e899cc34f3eb7c46d0bb90650355012130a..762ac0ea06ad8b71bbdae6100d34e747ace343af 100644
 | 
| --- a/src/hydrogen.cc
 | 
| +++ b/src/hydrogen.cc
 | 
| @@ -9910,12 +9910,13 @@ HInstruction* HOptimizedGraphBuilder::BuildFastLiteral(
 | 
|      HValue* object_elements_size = Add<HConstant>(elements_size);
 | 
|      if (boilerplate_object->HasFastDoubleElements()) {
 | 
|        // Allocation folding will not be able to fold |object| and
 | 
| -      // |object_elements| together in some cases, so initialize
 | 
| -      // elements with the undefined to make GC happy.
 | 
| -      HConstant* empty_fixed_array = Add<HConstant>(
 | 
| -          isolate()->factory()->empty_fixed_array());
 | 
| -      Add<HStoreNamedField>(object, HObjectAccess::ForElementsPointer(),
 | 
| -                            empty_fixed_array, INITIALIZING_STORE);
 | 
| +      // |object_elements| together if they are pre-tenured.
 | 
| +      if (pretenure_flag == TENURED) {
 | 
| +        HConstant* empty_fixed_array = Add<HConstant>(
 | 
| +            isolate()->factory()->empty_fixed_array());
 | 
| +        Add<HStoreNamedField>(object, HObjectAccess::ForElementsPointer(),
 | 
| +                              empty_fixed_array, INITIALIZING_STORE);
 | 
| +      }
 | 
|        object_elements = Add<HAllocate>(object_elements_size, HType::JSObject(),
 | 
|            pretenure_flag, FIXED_DOUBLE_ARRAY_TYPE, site_context->current());
 | 
|      } else {
 | 
| 
 |