| Index: src/x64/full-codegen-x64.cc
|
| diff --git a/src/x64/full-codegen-x64.cc b/src/x64/full-codegen-x64.cc
|
| index 46447de6691e51e63d726709bacf46bb26403eb7..6f0b9907ca3a41667cbbb64ae1c147681ce60e54 100644
|
| --- a/src/x64/full-codegen-x64.cc
|
| +++ b/src/x64/full-codegen-x64.cc
|
| @@ -1561,6 +1561,12 @@ void FullCodeGenerator::VisitObjectLiteral(ObjectLiteral* expr) {
|
| flags |= expr->has_function()
|
| ? ObjectLiteral::kHasFunction
|
| : ObjectLiteral::kNoFlags;
|
| +
|
| + if (FLAG_track_allocation_sites && !IsOneTimeCode()) {
|
| + // Don't track global arrays that are never re-created
|
| + flags |= ObjectLiteral::kAllocationSiteInfoAllowed;
|
| + }
|
| +
|
| __ Push(Smi::FromInt(flags));
|
| int properties_count = constant_properties->length() / 2;
|
| if (expr->depth() > 1) {
|
| @@ -1677,6 +1683,19 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
| Handle<FixedArrayBase> constant_elements_values(
|
| FixedArrayBase::cast(constant_elements->get(1)));
|
|
|
| + AllocationSiteMode allocation_site_mode = DONT_TRACK_ALLOCATION_SITE;
|
| + int flags = ArrayLiteral::kNoFlags;
|
| + if (FLAG_track_allocation_sites && !IsOneTimeCode()) {
|
| + // Don't track global arrays that are never re-created
|
| + flags |= ArrayLiteral::kAllocationSiteInfoAllowed;
|
| + allocation_site_mode = TRACK_ALLOCATION_SITE;
|
| + }
|
| +
|
| + ASSERT(((flags & ArrayLiteral::kAllocationSiteInfoAllowed) &&
|
| + (allocation_site_mode == TRACK_ALLOCATION_SITE)) ||
|
| + (((flags & ArrayLiteral::kAllocationSiteInfoAllowed) == 0) &&
|
| + (allocation_site_mode == DONT_TRACK_ALLOCATION_SITE)));
|
| +
|
| __ movq(rbx, Operand(rbp, JavaScriptFrameConstants::kFunctionOffset));
|
| __ push(FieldOperand(rbx, JSFunction::kLiteralsOffset));
|
| __ Push(Smi::FromInt(expr->literal_index()));
|
| @@ -1693,16 +1712,16 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
| length);
|
| __ CallStub(&stub);
|
| } else if (expr->depth() > 1) {
|
| - __ CallRuntime(Runtime::kCreateArrayLiteral, 3);
|
| + __ Push(Smi::FromInt(flags));
|
| + __ CallRuntime(Runtime::kCreateArrayLiteral, 4);
|
| } else if (length > FastCloneShallowArrayStub::kMaximumClonedLength) {
|
| - __ CallRuntime(Runtime::kCreateArrayLiteralShallow, 3);
|
| + __ Push(Smi::FromInt(flags));
|
| + __ CallRuntime(Runtime::kCreateArrayLiteralShallow, 4);
|
| } else {
|
| ASSERT(IsFastSmiOrObjectElementsKind(constant_elements_kind) ||
|
| FLAG_smi_only_arrays);
|
| FastCloneShallowArrayStub::Mode mode =
|
| FastCloneShallowArrayStub::CLONE_ANY_ELEMENTS;
|
| - AllocationSiteMode allocation_site_mode = FLAG_track_allocation_sites
|
| - ? TRACK_ALLOCATION_SITE : DONT_TRACK_ALLOCATION_SITE;
|
|
|
| // If the elements are already FAST_*_ELEMENTS, the boilerplate cannot
|
| // change, so it's possible to specialize the stub in advance.
|
|
|