Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(569)

Side by Side Diff: Source/heap/Heap.h

Issue 197343003: Fix PersistentHeapHashMap to work with stack allocated, heap backed weak collections (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Update comments. Created 6 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | Source/heap/Heap.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2013 Google Inc. All rights reserved. 2 * Copyright (C) 2013 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 754 matching lines...) Expand 10 before | Expand all | Expand 10 after
765 static void init(); 765 static void init();
766 static void shutdown(); 766 static void shutdown();
767 767
768 static BaseHeapPage* contains(Address); 768 static BaseHeapPage* contains(Address);
769 static BaseHeapPage* contains(void* pointer) { return contains(reinterpret_c ast<Address>(pointer)); } 769 static BaseHeapPage* contains(void* pointer) { return contains(reinterpret_c ast<Address>(pointer)); }
770 static BaseHeapPage* contains(const void* pointer) { return contains(const_c ast<void*>(pointer)); } 770 static BaseHeapPage* contains(const void* pointer) { return contains(const_c ast<void*>(pointer)); }
771 771
772 // Push a trace callback on the marking stack. 772 // Push a trace callback on the marking stack.
773 static void pushTraceCallback(void* containerObject, TraceCallback); 773 static void pushTraceCallback(void* containerObject, TraceCallback);
774 774
775 // Push a weak pointer callback on the weak callback 775 // Add a weak pointer callback to the weak callback work list. General
776 // stack. General object pointer callbacks are pushed on a thread 776 // object pointer callbacks are added to a thread local weak callback work
777 // local weak callback stack and the callback is called on the 777 // list and the callback is called on the thread that owns the object, with
778 // thread that owns the object. Cell pointer callbacks are pushed 778 // the closure pointer as an argument. Most of the time, the closure and
779 // on a static callback stack and the weak callback is performed 779 // the containerObject can be the same thing, but the containerObject is
780 // on the thread performing garbage collection. This is OK because 780 // constrained to be on the heap, since the heap is used to identify the
781 // cells are just cleared and no deallocation can happen. 781 // correct thread.
782 static void pushWeakObjectPointerCallback(void* containerObject, WeakPointer Callback); 782 static void pushWeakObjectPointerCallback(void* closure, void* containerObje ct, WeakPointerCallback);
783
784 // Similar to the more general pushWeakObjectPointerCallback, but cell
785 // pointer callbacks are added to a static callback work list and the weak
786 // callback is performed on the thread performing garbage collection. This
787 // is OK because cells are just cleared and no deallocation can happen.
783 static void pushWeakCellPointerCallback(void** cell, WeakPointerCallback); 788 static void pushWeakCellPointerCallback(void** cell, WeakPointerCallback);
784 789
785 // Pop the top of the marking stack and call the callback with the visitor 790 // Pop the top of the marking stack and call the callback with the visitor
786 // and the object. Returns false when there is nothing more to do. 791 // and the object. Returns false when there is nothing more to do.
787 static bool popAndInvokeTraceCallback(Visitor*); 792 static bool popAndInvokeTraceCallback(Visitor*);
788 793
789 // Pop the top of the weak callback stack and call the callback with the vis itor 794 // Remove an item from the weak callback work list and call the callback
790 // and the object. Returns false when there is nothing more to do. 795 // with the visitor and the closure pointer. Returns false when there is
796 // nothing more to do.
791 static bool popAndInvokeWeakPointerCallback(Visitor*); 797 static bool popAndInvokeWeakPointerCallback(Visitor*);
792 798
793 template<typename T> static Address allocate(size_t); 799 template<typename T> static Address allocate(size_t);
794 template<typename T> static Address reallocate(void* previous, size_t); 800 template<typename T> static Address reallocate(void* previous, size_t);
795 801
796 static void collectGarbage(ThreadState::StackState, GCType = Normal); 802 static void collectGarbage(ThreadState::StackState, GCType = Normal);
797 static void collectAllGarbage(ThreadState::StackState, GCType = Normal); 803 static void collectAllGarbage(ThreadState::StackState, GCType = Normal);
798 804
799 static void prepareForGC(); 805 static void prepareForGC();
800 806
(...skipping 455 matching lines...) Expand 10 before | Expand all | Expand 10 after
1256 { 1262 {
1257 return !visitor->isAlive(t); 1263 return !visitor->isAlive(t);
1258 } 1264 }
1259 1265
1260 template<typename T, typename U> 1266 template<typename T, typename U>
1261 static bool hasDeadMember(Visitor* visitor, const WTF::KeyValuePair<T, U>& t ) 1267 static bool hasDeadMember(Visitor* visitor, const WTF::KeyValuePair<T, U>& t )
1262 { 1268 {
1263 return hasDeadMember(visitor, t.key) || hasDeadMember(visitor, t.value); 1269 return hasDeadMember(visitor, t.key) || hasDeadMember(visitor, t.value);
1264 } 1270 }
1265 1271
1266 static void registerWeakMembers(Visitor* visitor, const void* object, WeakPo interCallback callback) 1272 static void registerWeakMembers(Visitor* visitor, const void* closure, const void* object, WeakPointerCallback callback)
1267 { 1273 {
1268 visitor->registerWeakMembers(object, callback); 1274 visitor->registerWeakMembers(closure, object, callback);
1269 } 1275 }
1270 1276
1271 template<typename T> 1277 template<typename T>
1272 struct ResultType { 1278 struct ResultType {
1273 typedef T* Type; 1279 typedef T* Type;
1274 }; 1280 };
1275 1281
1276 // The WTF classes use Allocator::VectorBackingHelper in order to find a 1282 // The WTF classes use Allocator::VectorBackingHelper in order to find a
1277 // class to template their backing allocation operation on. For off-heap 1283 // class to template their backing allocation operation on. For off-heap
1278 // allocations the VectorBackingHelper is a dummy class, since the class is 1284 // allocations the VectorBackingHelper is a dummy class, since the class is
(...skipping 430 matching lines...) Expand 10 before | Expand all | Expand 10 after
1709 // to export. This forces it to export all the methods from ThreadHeap. 1715 // to export. This forces it to export all the methods from ThreadHeap.
1710 template<> void ThreadHeap<FinalizedHeapObjectHeader>::addPageToHeap(const GCInf o*); 1716 template<> void ThreadHeap<FinalizedHeapObjectHeader>::addPageToHeap(const GCInf o*);
1711 template<> void ThreadHeap<HeapObjectHeader>::addPageToHeap(const GCInfo*); 1717 template<> void ThreadHeap<HeapObjectHeader>::addPageToHeap(const GCInfo*);
1712 extern template class HEAP_EXPORT ThreadHeap<FinalizedHeapObjectHeader>; 1718 extern template class HEAP_EXPORT ThreadHeap<FinalizedHeapObjectHeader>;
1713 extern template class HEAP_EXPORT ThreadHeap<HeapObjectHeader>; 1719 extern template class HEAP_EXPORT ThreadHeap<HeapObjectHeader>;
1714 #endif 1720 #endif
1715 1721
1716 } 1722 }
1717 1723
1718 #endif // Heap_h 1724 #endif // Heap_h
OLDNEW
« no previous file with comments | « no previous file | Source/heap/Heap.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698