| OLD | NEW |
| 1 // Copyright 2010 the V8 project authors. All rights reserved. | 1 // Copyright 2010 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 508 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 519 Type type, | 519 Type type, |
| 520 const char* name, | 520 const char* name, |
| 521 uint64_t id, | 521 uint64_t id, |
| 522 int self_size, | 522 int self_size, |
| 523 int children_count, | 523 int children_count, |
| 524 int retainers_count); | 524 int retainers_count); |
| 525 | 525 |
| 526 HeapSnapshot* snapshot() { return snapshot_; } | 526 HeapSnapshot* snapshot() { return snapshot_; } |
| 527 Type type() { return static_cast<Type>(type_); } | 527 Type type() { return static_cast<Type>(type_); } |
| 528 const char* name() { return name_; } | 528 const char* name() { return name_; } |
| 529 uint64_t id(); | 529 inline uint64_t id(); |
| 530 int self_size() { return self_size_; } | 530 int self_size() { return self_size_; } |
| 531 int retained_size() { return retained_size_; } | 531 int retained_size() { return retained_size_; } |
| 532 void add_retained_size(int size) { retained_size_ += size; } | 532 void add_retained_size(int size) { retained_size_ += size; } |
| 533 void set_retained_size(int value) { retained_size_ = value; } | 533 void set_retained_size(int value) { retained_size_ = value; } |
| 534 int ordered_index() { return ordered_index_; } | 534 int ordered_index() { return ordered_index_; } |
| 535 void set_ordered_index(int value) { ordered_index_ = value; } | 535 void set_ordered_index(int value) { ordered_index_ = value; } |
| 536 | 536 |
| 537 Vector<HeapGraphEdge> children() { | 537 Vector<HeapGraphEdge> children() { |
| 538 return Vector<HeapGraphEdge>(children_arr(), children_count_); } | 538 return Vector<HeapGraphEdge>(children_arr(), children_count_); } |
| 539 Vector<HeapGraphEdge*> retainers() { | 539 Vector<HeapGraphEdge*> retainers() { |
| (...skipping 11 matching lines...) Expand all Loading... |
| 551 bool not_painted_reachable_from_others() { | 551 bool not_painted_reachable_from_others() { |
| 552 return painted_ != kPaintedReachableFromOthers; | 552 return painted_ != kPaintedReachableFromOthers; |
| 553 } | 553 } |
| 554 void paint_reachable_from_others() { | 554 void paint_reachable_from_others() { |
| 555 painted_ = kPaintedReachableFromOthers; | 555 painted_ = kPaintedReachableFromOthers; |
| 556 } | 556 } |
| 557 template<class Visitor> | 557 template<class Visitor> |
| 558 void ApplyAndPaintAllReachable(Visitor* visitor); | 558 void ApplyAndPaintAllReachable(Visitor* visitor); |
| 559 void PaintAllReachable(); | 559 void PaintAllReachable(); |
| 560 | 560 |
| 561 bool is_leaf() { return painted_ == kLeaf; } | |
| 562 void set_leaf() { painted_ = kLeaf; } | |
| 563 bool is_non_leaf() { return painted_ == kNonLeaf; } | |
| 564 void set_non_leaf() { painted_ = kNonLeaf; } | |
| 565 bool is_processed() { return painted_ == kProcessed; } | |
| 566 void set_processed() { painted_ = kProcessed; } | |
| 567 | |
| 568 void SetIndexedReference(HeapGraphEdge::Type type, | 561 void SetIndexedReference(HeapGraphEdge::Type type, |
| 569 int child_index, | 562 int child_index, |
| 570 int index, | 563 int index, |
| 571 HeapEntry* entry, | 564 HeapEntry* entry, |
| 572 int retainer_index); | 565 int retainer_index); |
| 573 void SetNamedReference(HeapGraphEdge::Type type, | 566 void SetNamedReference(HeapGraphEdge::Type type, |
| 574 int child_index, | 567 int child_index, |
| 575 const char* name, | 568 const char* name, |
| 576 HeapEntry* entry, | 569 HeapEntry* entry, |
| 577 int retainer_index); | 570 int retainer_index); |
| (...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 618 struct Id { | 611 struct Id { |
| 619 uint32_t id1_; | 612 uint32_t id1_; |
| 620 uint32_t id2_; | 613 uint32_t id2_; |
| 621 } id_; // This is to avoid extra padding of 64-bit value. | 614 } id_; // This is to avoid extra padding of 64-bit value. |
| 622 const char* name_; | 615 const char* name_; |
| 623 | 616 |
| 624 // Paints used for exact retained sizes calculation. | 617 // Paints used for exact retained sizes calculation. |
| 625 static const unsigned kUnpainted = 0; | 618 static const unsigned kUnpainted = 0; |
| 626 static const unsigned kPainted = 1; | 619 static const unsigned kPainted = 1; |
| 627 static const unsigned kPaintedReachableFromOthers = 2; | 620 static const unsigned kPaintedReachableFromOthers = 2; |
| 628 // Paints used for approximate retained sizes calculation. | |
| 629 static const unsigned kLeaf = 0; | |
| 630 static const unsigned kNonLeaf = 1; | |
| 631 static const unsigned kProcessed = 2; | |
| 632 | 621 |
| 633 static const int kExactRetainedSizeTag = 1; | 622 static const int kExactRetainedSizeTag = 1; |
| 634 | 623 |
| 635 DISALLOW_COPY_AND_ASSIGN(HeapEntry); | 624 DISALLOW_COPY_AND_ASSIGN(HeapEntry); |
| 636 }; | 625 }; |
| 637 | 626 |
| 638 | 627 |
| 639 class HeapGraphPath { | 628 class HeapGraphPath { |
| 640 public: | 629 public: |
| 641 HeapGraphPath() | 630 HeapGraphPath() |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 675 const char* title, | 664 const char* title, |
| 676 unsigned uid); | 665 unsigned uid); |
| 677 ~HeapSnapshot(); | 666 ~HeapSnapshot(); |
| 678 | 667 |
| 679 HeapSnapshotsCollection* collection() { return collection_; } | 668 HeapSnapshotsCollection* collection() { return collection_; } |
| 680 Type type() { return type_; } | 669 Type type() { return type_; } |
| 681 const char* title() { return title_; } | 670 const char* title() { return title_; } |
| 682 unsigned uid() { return uid_; } | 671 unsigned uid() { return uid_; } |
| 683 HeapEntry* root() { return root_entry_; } | 672 HeapEntry* root() { return root_entry_; } |
| 684 HeapEntry* gc_roots() { return gc_roots_entry_; } | 673 HeapEntry* gc_roots() { return gc_roots_entry_; } |
| 674 List<HeapEntry*>* entries() { return &entries_; } |
| 685 | 675 |
| 686 void AllocateEntries( | 676 void AllocateEntries( |
| 687 int entries_count, int children_count, int retainers_count); | 677 int entries_count, int children_count, int retainers_count); |
| 688 HeapEntry* AddEntry( | 678 HeapEntry* AddEntry( |
| 689 HeapObject* object, int children_count, int retainers_count); | 679 HeapObject* object, int children_count, int retainers_count); |
| 690 HeapEntry* AddEntry(HeapEntry::Type type, | 680 HeapEntry* AddEntry(HeapEntry::Type type, |
| 691 const char* name, | 681 const char* name, |
| 692 uint64_t id, | 682 uint64_t id, |
| 693 int size, | 683 int size, |
| 694 int children_count, | 684 int children_count, |
| 695 int retainers_count); | 685 int retainers_count); |
| 696 void ApproximateRetainedSizes(); | |
| 697 void ClearPaint(); | 686 void ClearPaint(); |
| 698 HeapSnapshotsDiff* CompareWith(HeapSnapshot* snapshot); | 687 HeapSnapshotsDiff* CompareWith(HeapSnapshot* snapshot); |
| 699 HeapEntry* GetEntryById(uint64_t id); | 688 HeapEntry* GetEntryById(uint64_t id); |
| 700 List<HeapGraphPath*>* GetRetainingPaths(HeapEntry* entry); | 689 List<HeapGraphPath*>* GetRetainingPaths(HeapEntry* entry); |
| 701 List<HeapEntry*>* GetSortedEntriesList(); | 690 List<HeapEntry*>* GetSortedEntriesList(); |
| 702 template<class Visitor> | 691 template<class Visitor> |
| 703 void IterateEntries(Visitor* visitor) { entries_.Iterate(visitor); } | 692 void IterateEntries(Visitor* visitor) { entries_.Iterate(visitor); } |
| 704 void SetDominatorsToSelf(); | 693 void SetDominatorsToSelf(); |
| 705 | 694 |
| 706 void Print(int max_depth); | 695 void Print(int max_depth); |
| 707 void PrintEntriesSize(); | 696 void PrintEntriesSize(); |
| 708 | 697 |
| 709 static HeapObject* const kInternalRootObject; | 698 static HeapObject* const kInternalRootObject; |
| 710 static HeapObject* const kGcRootsObject; | 699 static HeapObject* const kGcRootsObject; |
| 711 | 700 |
| 712 private: | 701 private: |
| 713 HeapEntry* AddEntry(HeapObject* object, | 702 HeapEntry* AddEntry(HeapObject* object, |
| 714 HeapEntry::Type type, | 703 HeapEntry::Type type, |
| 715 const char* name, | 704 const char* name, |
| 716 int children_count, | 705 int children_count, |
| 717 int retainers_count); | 706 int retainers_count); |
| 718 HeapEntry* GetNextEntryToInit(); | 707 HeapEntry* GetNextEntryToInit(); |
| 719 void BuildDominatorTree(const Vector<HeapEntry*>& entries, | |
| 720 Vector<HeapEntry*>* dominators); | |
| 721 void FillReversePostorderIndexes(Vector<HeapEntry*>* entries); | |
| 722 void SetEntriesDominators(); | |
| 723 | 708 |
| 724 HeapSnapshotsCollection* collection_; | 709 HeapSnapshotsCollection* collection_; |
| 725 Type type_; | 710 Type type_; |
| 726 const char* title_; | 711 const char* title_; |
| 727 unsigned uid_; | 712 unsigned uid_; |
| 728 HeapEntry* root_entry_; | 713 HeapEntry* root_entry_; |
| 729 HeapEntry* gc_roots_entry_; | 714 HeapEntry* gc_roots_entry_; |
| 730 char* raw_entries_; | 715 char* raw_entries_; |
| 731 List<HeapEntry*> entries_; | 716 List<HeapEntry*> entries_; |
| 732 bool entries_sorted_; | 717 bool entries_sorted_; |
| (...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 838 | 823 |
| 839 class HeapSnapshotsCollection { | 824 class HeapSnapshotsCollection { |
| 840 public: | 825 public: |
| 841 HeapSnapshotsCollection(); | 826 HeapSnapshotsCollection(); |
| 842 ~HeapSnapshotsCollection(); | 827 ~HeapSnapshotsCollection(); |
| 843 | 828 |
| 844 bool is_tracking_objects() { return is_tracking_objects_; } | 829 bool is_tracking_objects() { return is_tracking_objects_; } |
| 845 | 830 |
| 846 HeapSnapshot* NewSnapshot( | 831 HeapSnapshot* NewSnapshot( |
| 847 HeapSnapshot::Type type, const char* name, unsigned uid); | 832 HeapSnapshot::Type type, const char* name, unsigned uid); |
| 848 void SnapshotGenerationFinished() { ids_.SnapshotGenerationFinished(); } | 833 void SnapshotGenerationFinished(HeapSnapshot* snapshot); |
| 849 List<HeapSnapshot*>* snapshots() { return &snapshots_; } | 834 List<HeapSnapshot*>* snapshots() { return &snapshots_; } |
| 850 HeapSnapshot* GetSnapshot(unsigned uid); | 835 HeapSnapshot* GetSnapshot(unsigned uid); |
| 851 | 836 |
| 852 const char* GetName(String* name) { return names_.GetName(name); } | 837 const char* GetName(String* name) { return names_.GetName(name); } |
| 853 const char* GetName(int index) { return names_.GetName(index); } | 838 const char* GetName(int index) { return names_.GetName(index); } |
| 854 const char* GetFunctionName(String* name) { | 839 const char* GetFunctionName(String* name) { |
| 855 return names_.GetFunctionName(name); | 840 return names_.GetFunctionName(name); |
| 856 } | 841 } |
| 857 | 842 |
| 858 TokenEnumerator* token_enumerator() { return token_enumerator_; } | 843 TokenEnumerator* token_enumerator() { return token_enumerator_; } |
| (...skipping 102 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 961 const char* reference_name, | 946 const char* reference_name, |
| 962 Object* child_obj, | 947 Object* child_obj, |
| 963 HeapEntry* child_entry) = 0; | 948 HeapEntry* child_entry) = 0; |
| 964 virtual void SetRootGcRootsReference() = 0; | 949 virtual void SetRootGcRootsReference() = 0; |
| 965 virtual void SetRootShortcutReference(Object* child_obj, | 950 virtual void SetRootShortcutReference(Object* child_obj, |
| 966 HeapEntry* child_entry) = 0; | 951 HeapEntry* child_entry) = 0; |
| 967 virtual void SetStrongRootReference(Object* child_obj, | 952 virtual void SetStrongRootReference(Object* child_obj, |
| 968 HeapEntry* child_entry) = 0; | 953 HeapEntry* child_entry) = 0; |
| 969 }; | 954 }; |
| 970 | 955 |
| 971 explicit HeapSnapshotGenerator(HeapSnapshot* snapshot); | 956 HeapSnapshotGenerator(HeapSnapshot* snapshot, |
| 972 void GenerateSnapshot(); | 957 v8::ActivityControl* control); |
| 958 bool GenerateSnapshot(); |
| 973 | 959 |
| 974 private: | 960 private: |
| 961 bool ApproximateRetainedSizes(); |
| 962 bool BuildDominatorTree(const Vector<HeapEntry*>& entries, |
| 963 Vector<HeapEntry*>* dominators); |
| 964 bool CountEntriesAndReferences(); |
| 975 HeapEntry* GetEntry(Object* obj); | 965 HeapEntry* GetEntry(Object* obj); |
| 966 void IncProgressCounter() { ++progress_counter_; } |
| 976 void ExtractReferences(HeapObject* obj); | 967 void ExtractReferences(HeapObject* obj); |
| 977 void ExtractClosureReferences(JSObject* js_obj, HeapEntry* entry); | 968 void ExtractClosureReferences(JSObject* js_obj, HeapEntry* entry); |
| 978 void ExtractPropertyReferences(JSObject* js_obj, HeapEntry* entry); | 969 void ExtractPropertyReferences(JSObject* js_obj, HeapEntry* entry); |
| 979 void ExtractElementReferences(JSObject* js_obj, HeapEntry* entry); | 970 void ExtractElementReferences(JSObject* js_obj, HeapEntry* entry); |
| 980 void ExtractInternalReferences(JSObject* js_obj, HeapEntry* entry); | 971 void ExtractInternalReferences(JSObject* js_obj, HeapEntry* entry); |
| 972 bool FillReferences(); |
| 973 void FillReversePostorderIndexes(Vector<HeapEntry*>* entries); |
| 974 bool IterateAndExtractReferences(); |
| 975 inline bool ReportProgress(bool force = false); |
| 976 bool SetEntriesDominators(); |
| 981 void SetClosureReference(HeapObject* parent_obj, | 977 void SetClosureReference(HeapObject* parent_obj, |
| 982 HeapEntry* parent, | 978 HeapEntry* parent, |
| 983 String* reference_name, | 979 String* reference_name, |
| 984 Object* child); | 980 Object* child); |
| 985 void SetElementReference(HeapObject* parent_obj, | 981 void SetElementReference(HeapObject* parent_obj, |
| 986 HeapEntry* parent, | 982 HeapEntry* parent, |
| 987 int index, | 983 int index, |
| 988 Object* child); | 984 Object* child); |
| 989 void SetInternalReference(HeapObject* parent_obj, | 985 void SetInternalReference(HeapObject* parent_obj, |
| 990 HeapEntry* parent, | 986 HeapEntry* parent, |
| (...skipping 11 matching lines...) Expand all Loading... |
| 1002 HeapEntry* parent, | 998 HeapEntry* parent, |
| 1003 String* reference_name, | 999 String* reference_name, |
| 1004 Object* child); | 1000 Object* child); |
| 1005 void SetPropertyShortcutReference(HeapObject* parent_obj, | 1001 void SetPropertyShortcutReference(HeapObject* parent_obj, |
| 1006 HeapEntry* parent, | 1002 HeapEntry* parent, |
| 1007 String* reference_name, | 1003 String* reference_name, |
| 1008 Object* child); | 1004 Object* child); |
| 1009 void SetRootShortcutReference(Object* child); | 1005 void SetRootShortcutReference(Object* child); |
| 1010 void SetRootGcRootsReference(); | 1006 void SetRootGcRootsReference(); |
| 1011 void SetGcRootsReference(Object* child); | 1007 void SetGcRootsReference(Object* child); |
| 1008 void SetProgressTotal(int iterations_count); |
| 1012 | 1009 |
| 1013 HeapSnapshot* snapshot_; | 1010 HeapSnapshot* snapshot_; |
| 1011 v8::ActivityControl* control_; |
| 1014 HeapSnapshotsCollection* collection_; | 1012 HeapSnapshotsCollection* collection_; |
| 1015 // Mapping from HeapObject* pointers to HeapEntry* pointers. | 1013 // Mapping from HeapObject* pointers to HeapEntry* pointers. |
| 1016 HeapEntriesMap entries_; | 1014 HeapEntriesMap entries_; |
| 1017 SnapshotFillerInterface* filler_; | 1015 SnapshotFillerInterface* filler_; |
| 1018 // Used during references extraction to mark heap objects that | 1016 // Used during references extraction to mark heap objects that |
| 1019 // are references via non-hidden properties. | 1017 // are references via non-hidden properties. |
| 1020 HeapObjectsSet known_references_; | 1018 HeapObjectsSet known_references_; |
| 1019 // Used during snapshot generation. |
| 1020 int progress_counter_; |
| 1021 int progress_total_; |
| 1021 | 1022 |
| 1022 friend class IndexedReferencesExtractor; | 1023 friend class IndexedReferencesExtractor; |
| 1023 friend class RootsReferencesExtractor; | 1024 friend class RootsReferencesExtractor; |
| 1024 | 1025 |
| 1025 DISALLOW_COPY_AND_ASSIGN(HeapSnapshotGenerator); | 1026 DISALLOW_COPY_AND_ASSIGN(HeapSnapshotGenerator); |
| 1026 }; | 1027 }; |
| 1027 | 1028 |
| 1028 class OutputStreamWriter; | 1029 class OutputStreamWriter; |
| 1029 | 1030 |
| 1030 class HeapSnapshotJSONSerializer { | 1031 class HeapSnapshotJSONSerializer { |
| (...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1075 }; | 1076 }; |
| 1076 | 1077 |
| 1077 | 1078 |
| 1078 String* GetConstructorNameForHeapProfile(JSObject* object); | 1079 String* GetConstructorNameForHeapProfile(JSObject* object); |
| 1079 | 1080 |
| 1080 } } // namespace v8::internal | 1081 } } // namespace v8::internal |
| 1081 | 1082 |
| 1082 #endif // ENABLE_LOGGING_AND_PROFILING | 1083 #endif // ENABLE_LOGGING_AND_PROFILING |
| 1083 | 1084 |
| 1084 #endif // V8_PROFILE_GENERATOR_H_ | 1085 #endif // V8_PROFILE_GENERATOR_H_ |
| OLD | NEW |