| OLD | NEW |
| 1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef V8_GLOBAL_HANDLES_H_ | 5 #ifndef V8_GLOBAL_HANDLES_H_ |
| 6 #define V8_GLOBAL_HANDLES_H_ | 6 #define V8_GLOBAL_HANDLES_H_ |
| 7 | 7 |
| 8 #include <type_traits> | 8 #include <type_traits> |
| 9 | 9 |
| 10 #include "include/v8.h" | 10 #include "include/v8.h" |
| 11 #include "include/v8-profiler.h" | 11 #include "include/v8-profiler.h" |
| 12 | 12 |
| 13 #include "src/handles.h" | 13 #include "src/handles.h" |
| 14 #include "src/list.h" | 14 #include "src/list.h" |
| 15 #include "src/utils.h" | 15 #include "src/utils.h" |
| 16 | 16 |
| 17 namespace v8 { | 17 namespace v8 { |
| 18 namespace internal { | 18 namespace internal { |
| 19 | 19 |
| 20 class HeapStats; | 20 class HeapStats; |
| 21 class ObjectVisitor; | 21 class RootVisitor; |
| 22 | 22 |
| 23 // Structure for tracking global handles. | 23 // Structure for tracking global handles. |
| 24 // A single list keeps all the allocated global handles. | 24 // A single list keeps all the allocated global handles. |
| 25 // Destroyed handles stay in the list but is added to the free list. | 25 // Destroyed handles stay in the list but is added to the free list. |
| 26 // At GC the destroyed global handles are removed from the free list | 26 // At GC the destroyed global handles are removed from the free list |
| 27 // and deallocated. | 27 // and deallocated. |
| 28 | 28 |
| 29 enum WeaknessType { | 29 enum WeaknessType { |
| 30 // Embedder gets a handle to the dying object. | 30 // Embedder gets a handle to the dying object. |
| 31 FINALIZER_WEAK, | 31 FINALIZER_WEAK, |
| (...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 118 | 118 |
| 119 // Tells whether global handle is weak. | 119 // Tells whether global handle is weak. |
| 120 static bool IsWeak(Object** location); | 120 static bool IsWeak(Object** location); |
| 121 | 121 |
| 122 // Process pending weak handles. | 122 // Process pending weak handles. |
| 123 // Returns the number of freed nodes. | 123 // Returns the number of freed nodes. |
| 124 int PostGarbageCollectionProcessing( | 124 int PostGarbageCollectionProcessing( |
| 125 GarbageCollector collector, const v8::GCCallbackFlags gc_callback_flags); | 125 GarbageCollector collector, const v8::GCCallbackFlags gc_callback_flags); |
| 126 | 126 |
| 127 // Iterates over all strong handles. | 127 // Iterates over all strong handles. |
| 128 void IterateStrongRoots(ObjectVisitor* v); | 128 void IterateStrongRoots(RootVisitor* v); |
| 129 | 129 |
| 130 // Iterates over all handles. | 130 // Iterates over all handles. |
| 131 void IterateAllRoots(ObjectVisitor* v); | 131 void IterateAllRoots(RootVisitor* v); |
| 132 | 132 |
| 133 // Iterates over all handles that have embedder-assigned class ID. | 133 // Iterates over all handles that have embedder-assigned class ID. |
| 134 void IterateAllRootsWithClassIds(v8::PersistentHandleVisitor* v); | 134 void IterateAllRootsWithClassIds(v8::PersistentHandleVisitor* v); |
| 135 | 135 |
| 136 // Iterates over all handles in the new space that have embedder-assigned | 136 // Iterates over all handles in the new space that have embedder-assigned |
| 137 // class ID. | 137 // class ID. |
| 138 void IterateAllRootsInNewSpaceWithClassIds(v8::PersistentHandleVisitor* v); | 138 void IterateAllRootsInNewSpaceWithClassIds(v8::PersistentHandleVisitor* v); |
| 139 | 139 |
| 140 // Iterate over all handles in the new space that are weak, unmodified | 140 // Iterate over all handles in the new space that are weak, unmodified |
| 141 // and have class IDs | 141 // and have class IDs |
| 142 void IterateWeakRootsInNewSpaceWithClassIds(v8::PersistentHandleVisitor* v); | 142 void IterateWeakRootsInNewSpaceWithClassIds(v8::PersistentHandleVisitor* v); |
| 143 | 143 |
| 144 // Iterates over all weak roots in heap. | 144 // Iterates over all weak roots in heap. |
| 145 void IterateWeakRoots(ObjectVisitor* v); | 145 void IterateWeakRoots(RootVisitor* v); |
| 146 | 146 |
| 147 // Find all weak handles satisfying the callback predicate, mark | 147 // Find all weak handles satisfying the callback predicate, mark |
| 148 // them as pending. | 148 // them as pending. |
| 149 void IdentifyWeakHandles(WeakSlotCallback f); | 149 void IdentifyWeakHandles(WeakSlotCallback f); |
| 150 | 150 |
| 151 // NOTE: Five ...NewSpace... functions below are used during | 151 // NOTE: Five ...NewSpace... functions below are used during |
| 152 // scavenge collections and iterate over sets of handles that are | 152 // scavenge collections and iterate over sets of handles that are |
| 153 // guaranteed to contain all handles holding new space objects (but | 153 // guaranteed to contain all handles holding new space objects (but |
| 154 // may also include old space objects). | 154 // may also include old space objects). |
| 155 | 155 |
| 156 // Iterates over strong and dependent handles. See the node above. | 156 // Iterates over strong and dependent handles. See the node above. |
| 157 void IterateNewSpaceStrongAndDependentRoots(ObjectVisitor* v); | 157 void IterateNewSpaceStrongAndDependentRoots(RootVisitor* v); |
| 158 | 158 |
| 159 // Finds weak independent or partially independent handles satisfying | 159 // Finds weak independent or partially independent handles satisfying |
| 160 // the callback predicate and marks them as pending. See the note above. | 160 // the callback predicate and marks them as pending. See the note above. |
| 161 void IdentifyNewSpaceWeakIndependentHandles(WeakSlotCallbackWithHeap f); | 161 void IdentifyNewSpaceWeakIndependentHandles(WeakSlotCallbackWithHeap f); |
| 162 | 162 |
| 163 // Iterates over weak independent or partially independent handles. | 163 // Iterates over weak independent or partially independent handles. |
| 164 // See the note above. | 164 // See the note above. |
| 165 void IterateNewSpaceWeakIndependentRoots(ObjectVisitor* v); | 165 void IterateNewSpaceWeakIndependentRoots(RootVisitor* v); |
| 166 | 166 |
| 167 // Finds weak independent or unmodified handles satisfying | 167 // Finds weak independent or unmodified handles satisfying |
| 168 // the callback predicate and marks them as pending. See the note above. | 168 // the callback predicate and marks them as pending. See the note above. |
| 169 void MarkNewSpaceWeakUnmodifiedObjectsPending( | 169 void MarkNewSpaceWeakUnmodifiedObjectsPending( |
| 170 WeakSlotCallbackWithHeap is_unscavenged); | 170 WeakSlotCallbackWithHeap is_unscavenged); |
| 171 | 171 |
| 172 // Iterates over weak independent or unmodified handles. | 172 // Iterates over weak independent or unmodified handles. |
| 173 // See the note above. | 173 // See the note above. |
| 174 template <IterationMode mode> | 174 template <IterationMode mode> |
| 175 void IterateNewSpaceWeakUnmodifiedRoots(ObjectVisitor* v); | 175 void IterateNewSpaceWeakUnmodifiedRoots(RootVisitor* v); |
| 176 | 176 |
| 177 // Identify unmodified objects that are in weak state and marks them | 177 // Identify unmodified objects that are in weak state and marks them |
| 178 // unmodified | 178 // unmodified |
| 179 void IdentifyWeakUnmodifiedObjects(WeakSlotCallback is_unmodified); | 179 void IdentifyWeakUnmodifiedObjects(WeakSlotCallback is_unmodified); |
| 180 | 180 |
| 181 // Tear down the global handle structure. | 181 // Tear down the global handle structure. |
| 182 void TearDown(); | 182 void TearDown(); |
| 183 | 183 |
| 184 Isolate* isolate() { return isolate_; } | 184 Isolate* isolate() { return isolate_; } |
| 185 | 185 |
| (...skipping 111 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 297 | 297 |
| 298 // Assign a SingletonHandle to an empty slot and returns the handle. | 298 // Assign a SingletonHandle to an empty slot and returns the handle. |
| 299 Handle<Object> CreateSingleton(Isolate* isolate, | 299 Handle<Object> CreateSingleton(Isolate* isolate, |
| 300 Object* object, | 300 Object* object, |
| 301 SingletonHandle singleton) { | 301 SingletonHandle singleton) { |
| 302 Create(isolate, object, &singleton_handles_[singleton]); | 302 Create(isolate, object, &singleton_handles_[singleton]); |
| 303 return Get(singleton_handles_[singleton]); | 303 return Get(singleton_handles_[singleton]); |
| 304 } | 304 } |
| 305 | 305 |
| 306 // Iterates over all handles. | 306 // Iterates over all handles. |
| 307 void IterateAllRoots(ObjectVisitor* visitor); | 307 void IterateAllRoots(RootVisitor* visitor); |
| 308 // Iterates over all handles which might be in new space. | 308 // Iterates over all handles which might be in new space. |
| 309 void IterateNewSpaceRoots(ObjectVisitor* visitor); | 309 void IterateNewSpaceRoots(RootVisitor* visitor); |
| 310 // Rebuilds new space list. | 310 // Rebuilds new space list. |
| 311 void PostGarbageCollectionProcessing(Heap* heap); | 311 void PostGarbageCollectionProcessing(Heap* heap); |
| 312 | 312 |
| 313 private: | 313 private: |
| 314 static const int kInvalidIndex = -1; | 314 static const int kInvalidIndex = -1; |
| 315 static const int kShift = 8; | 315 static const int kShift = 8; |
| 316 static const int kSize = 1 << kShift; | 316 static const int kSize = 1 << kShift; |
| 317 static const int kMask = 0xff; | 317 static const int kMask = 0xff; |
| 318 | 318 |
| 319 // Gets the slot for an index | 319 // Gets the slot for an index |
| 320 inline Object** GetLocation(int index) { | 320 inline Object** GetLocation(int index) { |
| 321 DCHECK(index >= 0 && index < size_); | 321 DCHECK(index >= 0 && index < size_); |
| 322 return &blocks_[index >> kShift][index & kMask]; | 322 return &blocks_[index >> kShift][index & kMask]; |
| 323 } | 323 } |
| 324 | 324 |
| 325 int size_; | 325 int size_; |
| 326 List<Object**> blocks_; | 326 List<Object**> blocks_; |
| 327 List<int> new_space_indices_; | 327 List<int> new_space_indices_; |
| 328 int singleton_handles_[NUMBER_OF_SINGLETON_HANDLES]; | 328 int singleton_handles_[NUMBER_OF_SINGLETON_HANDLES]; |
| 329 | 329 |
| 330 DISALLOW_COPY_AND_ASSIGN(EternalHandles); | 330 DISALLOW_COPY_AND_ASSIGN(EternalHandles); |
| 331 }; | 331 }; |
| 332 | 332 |
| 333 | 333 |
| 334 } // namespace internal | 334 } // namespace internal |
| 335 } // namespace v8 | 335 } // namespace v8 |
| 336 | 336 |
| 337 #endif // V8_GLOBAL_HANDLES_H_ | 337 #endif // V8_GLOBAL_HANDLES_H_ |
| OLD | NEW |