OLD | NEW |
1 // Copyright 2009 the V8 project authors. All rights reserved. | 1 // Copyright 2009 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 909 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
920 AllocatingRetainersIterator(const JSObjectsCluster& child_cluster, | 920 AllocatingRetainersIterator(const JSObjectsCluster& child_cluster, |
921 HeapEntriesMap* map) | 921 HeapEntriesMap* map) |
922 : child_(ClusterAsHeapObject(child_cluster)), map_(map) { | 922 : child_(ClusterAsHeapObject(child_cluster)), map_(map) { |
923 child_entry_ = map_->Map(child_); | 923 child_entry_ = map_->Map(child_); |
924 ASSERT(child_entry_ != NULL); | 924 ASSERT(child_entry_ != NULL); |
925 } | 925 } |
926 | 926 |
927 void Call(const JSObjectsCluster& cluster, | 927 void Call(const JSObjectsCluster& cluster, |
928 const NumberAndSizeInfo& number_and_size) { | 928 const NumberAndSizeInfo& number_and_size) { |
929 int child_index, retainer_index; | 929 int child_index, retainer_index; |
930 map_->CountReference(ClusterAsHeapObject(cluster), child_, | 930 map_->CountReference(ClusterAsHeapObject(cluster), |
931 &child_index, &retainer_index); | 931 child_, |
932 map_->Map(ClusterAsHeapObject(cluster))->SetElementReference( | 932 &child_index, |
933 child_index, number_and_size.number(), child_entry_, retainer_index); | 933 &retainer_index); |
| 934 map_->Map(ClusterAsHeapObject(cluster))->SetIndexedReference( |
| 935 HeapGraphEdge::kElement, |
| 936 child_index, |
| 937 number_and_size.number(), |
| 938 child_entry_, |
| 939 retainer_index); |
934 } | 940 } |
935 | 941 |
936 private: | 942 private: |
937 HeapObject* child_; | 943 HeapObject* child_; |
938 HeapEntriesMap* map_; | 944 HeapEntriesMap* map_; |
939 HeapEntry* child_entry_; | 945 HeapEntry* child_entry_; |
940 }; | 946 }; |
941 | 947 |
942 | 948 |
943 template<class RetainersIterator> | 949 template<class RetainersIterator> |
(...skipping 91 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1035 histogram_children_count, | 1041 histogram_children_count, |
1036 histogram_retainers_count); | 1042 histogram_retainers_count); |
1037 snapshot->AddEntry(HeapSnapshot::kInternalRootObject, | 1043 snapshot->AddEntry(HeapSnapshot::kInternalRootObject, |
1038 root_children_count, | 1044 root_children_count, |
1039 0); | 1045 0); |
1040 int root_child_index = 0; | 1046 int root_child_index = 0; |
1041 for (int i = FIRST_NONSTRING_TYPE; i <= kAllStringsType; ++i) { | 1047 for (int i = FIRST_NONSTRING_TYPE; i <= kAllStringsType; ++i) { |
1042 if (agg_snapshot_->info()[i].bytes() > 0) { | 1048 if (agg_snapshot_->info()[i].bytes() > 0) { |
1043 AddEntryFromAggregatedSnapshot(snapshot, | 1049 AddEntryFromAggregatedSnapshot(snapshot, |
1044 &root_child_index, | 1050 &root_child_index, |
1045 HeapEntry::kInternal, | 1051 HeapEntry::kHidden, |
1046 agg_snapshot_->info()[i].name(), | 1052 agg_snapshot_->info()[i].name(), |
1047 agg_snapshot_->info()[i].number(), | 1053 agg_snapshot_->info()[i].number(), |
1048 agg_snapshot_->info()[i].bytes(), | 1054 agg_snapshot_->info()[i].bytes(), |
1049 0, | 1055 0, |
1050 0); | 1056 0); |
1051 } | 1057 } |
1052 } | 1058 } |
1053 AllocatingConstructorHeapProfileIterator alloc_cons_iter( | 1059 AllocatingConstructorHeapProfileIterator alloc_cons_iter( |
1054 snapshot, &root_child_index); | 1060 snapshot, &root_child_index); |
1055 agg_snapshot_->js_cons_profile()->ForEach(&alloc_cons_iter); | 1061 agg_snapshot_->js_cons_profile()->ForEach(&alloc_cons_iter); |
(...skipping 30 matching lines...) Expand all Loading... |
1086 GlobalHandles::MakeWeak(handle.location(), | 1092 GlobalHandles::MakeWeak(handle.location(), |
1087 static_cast<void*>(stack.start()), | 1093 static_cast<void*>(stack.start()), |
1088 StackWeakReferenceCallback); | 1094 StackWeakReferenceCallback); |
1089 } | 1095 } |
1090 | 1096 |
1091 | 1097 |
1092 #endif // ENABLE_LOGGING_AND_PROFILING | 1098 #endif // ENABLE_LOGGING_AND_PROFILING |
1093 | 1099 |
1094 | 1100 |
1095 } } // namespace v8::internal | 1101 } } // namespace v8::internal |
OLD | NEW |