allocation-tracker.h 4.2 KB
Newer Older
1
// Copyright 2013 the V8 project authors. All rights reserved.
2 3
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
4 5 6 7

#ifndef V8_ALLOCATION_TRACKER_H_
#define V8_ALLOCATION_TRACKER_H_

8 9
#include <map>

10 11 12 13 14 15
#include "include/v8-profiler.h"
#include "src/handles.h"
#include "src/hashmap.h"
#include "src/list.h"
#include "src/vector.h"

16 17 18
namespace v8 {
namespace internal {

19
// Forward declarations.
20
class AllocationTraceTree;
21 22 23 24
class AllocationTracker;
class HeapObjectsMap;
class SharedFunctionInfo;
class StringsStorage;
25 26 27 28

class AllocationTraceNode {
 public:
  AllocationTraceNode(AllocationTraceTree* tree,
29
                      unsigned function_info_index);
30
  ~AllocationTraceNode();
31 32
  AllocationTraceNode* FindChild(unsigned function_info_index);
  AllocationTraceNode* FindOrAddChild(unsigned function_info_index);
33 34
  void AddAllocation(unsigned size);

35
  unsigned function_info_index() const { return function_info_index_; }
36 37 38 39 40 41 42 43 44
  unsigned allocation_size() const { return total_size_; }
  unsigned allocation_count() const { return allocation_count_; }
  unsigned id() const { return id_; }
  Vector<AllocationTraceNode*> children() const { return children_.ToVector(); }

  void Print(int indent, AllocationTracker* tracker);

 private:
  AllocationTraceTree* tree_;
45
  unsigned function_info_index_;
46 47 48 49 50 51 52 53 54 55 56 57 58
  unsigned total_size_;
  unsigned allocation_count_;
  unsigned id_;
  List<AllocationTraceNode*> children_;

  DISALLOW_COPY_AND_ASSIGN(AllocationTraceNode);
};


class AllocationTraceTree {
 public:
  AllocationTraceTree();
  ~AllocationTraceTree();
59
  AllocationTraceNode* AddPathFromEnd(const Vector<unsigned>& path);
60 61 62 63 64 65 66 67 68 69 70 71
  AllocationTraceNode* root() { return &root_; }
  unsigned next_node_id() { return next_node_id_++; }
  void Print(AllocationTracker* tracker);

 private:
  unsigned next_node_id_;
  AllocationTraceNode root_;

  DISALLOW_COPY_AND_ASSIGN(AllocationTraceTree);
};


72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
class AddressToTraceMap {
 public:
  void AddRange(Address addr, int size, unsigned node_id);
  unsigned GetTraceNodeId(Address addr);
  void MoveObject(Address from, Address to, int size);
  void Clear();
  size_t size() { return ranges_.size(); }
  void Print();

 private:
  struct RangeStack {
    RangeStack(Address start, unsigned node_id)
        : start(start), trace_node_id(node_id) {}
    Address start;
    unsigned trace_node_id;
  };
  // [start, end) -> trace
  typedef std::map<Address, RangeStack> RangeMap;

  void RemoveRange(Address start, Address end);

  RangeMap ranges_;
};

96 97 98 99 100
class AllocationTracker {
 public:
  struct FunctionInfo {
    FunctionInfo();
    const char* name;
101
    SnapshotObjectId function_id;
102 103 104 105 106 107 108 109 110 111
    const char* script_name;
    int script_id;
    int line;
    int column;
  };

  AllocationTracker(HeapObjectsMap* ids, StringsStorage* names);
  ~AllocationTracker();

  void PrepareForSerialization();
112
  void AllocationEvent(Address addr, int size);
113 114

  AllocationTraceTree* trace_tree() { return &trace_tree_; }
115 116 117
  const List<FunctionInfo*>& function_info_list() const {
    return function_info_list_;
  }
118
  AddressToTraceMap* address_to_trace() { return &address_to_trace_; }
119 120

 private:
121 122 123
  unsigned AddFunctionInfo(SharedFunctionInfo* info, SnapshotObjectId id);
  static void DeleteFunctionInfo(FunctionInfo** info);
  unsigned functionInfoIndexForVMState(StateTag state);
124 125 126 127 128 129 130 131

  class UnresolvedLocation {
   public:
    UnresolvedLocation(Script* script, int start, FunctionInfo* info);
    ~UnresolvedLocation();
    void Resolve();

   private:
132 133 134
    static void HandleWeakScript(
        const v8::WeakCallbackData<v8::Value, void>& data);

135 136 137 138 139 140 141 142 143 144
    Handle<Script> script_;
    int start_position_;
    FunctionInfo* info_;
  };
  static void DeleteUnresolvedLocation(UnresolvedLocation** location);

  static const int kMaxAllocationTraceLength = 64;
  HeapObjectsMap* ids_;
  StringsStorage* names_;
  AllocationTraceTree trace_tree_;
145 146 147
  unsigned allocation_trace_buffer_[kMaxAllocationTraceLength];
  List<FunctionInfo*> function_info_list_;
  HashMap id_to_function_info_index_;
148
  List<UnresolvedLocation*> unresolved_locations_;
149
  unsigned info_index_for_other_state_;
150
  AddressToTraceMap address_to_trace_;
151 152 153 154 155 156 157

  DISALLOW_COPY_AND_ASSIGN(AllocationTracker);
};

} }  // namespace v8::internal

#endif  // V8_ALLOCATION_TRACKER_H_