| Index: Source/platform/scheduler/CancellableTaskFactory.h | 
| diff --git a/Source/platform/scheduler/CancellableTaskFactory.h b/Source/platform/scheduler/CancellableTaskFactory.h | 
| index 2d1a642b309cc1e1a4842006e67dd875e3612195..932963a6d452b8496c09f94c4e29110396474339 100644 | 
| --- a/Source/platform/scheduler/CancellableTaskFactory.h | 
| +++ b/Source/platform/scheduler/CancellableTaskFactory.h | 
| @@ -6,27 +6,51 @@ | 
| #define CancellableTaskFactory_h | 
|  | 
| #include "platform/PlatformExport.h" | 
| +#include "platform/heap/Handle.h" | 
| #include "public/platform/WebScheduler.h" | 
| -#include "wtf/AddressSanitizer.h" | 
| #include "wtf/Functional.h" | 
| #include "wtf/Noncopyable.h" | 
| #include "wtf/OwnPtr.h" | 
| #include "wtf/PassOwnPtr.h" | 
| #include "wtf/RefCounted.h" | 
| +#include "wtf/TypeTraits.h" | 
| #include "wtf/WeakPtr.h" | 
|  | 
| namespace blink { | 
| + | 
| class TraceLocation; | 
|  | 
| class PLATFORM_EXPORT CancellableTaskFactory { | 
| WTF_MAKE_NONCOPYABLE(CancellableTaskFactory); | 
| - | 
| +    WTF_MAKE_FAST_ALLOCATED(CancellableTaskFactory); | 
| public: | 
| +    // A pair of mutually exclusive factory methods are provided for constructing | 
| +    // a CancellableTaskFactory, one for when a Oilpan heap object owns a | 
| +    // CancellableTaskFactory, and one when that owning object isn't controlled | 
| +    // by Oilpan. | 
| +    // | 
| +    // In the Oilpan case, as WTF::Closure objects are off-heap, we have to construct the | 
| +    // closure in such a manner that it doesn't end up referring back to the owning heap | 
| +    // object with a strong Persistent<> GC root reference. If we do, this will create | 
| +    // a heap <-> off-heap cycle and leak, the owning object can never be GCed. | 
| +    // Instead, the closure will keep an off-heap persistent reference of the weak | 
| +    // variety, which will refer back to the owner heap object safely (but weakly.) | 
| +    // | 
| +    template<typename T> | 
| +    static PassOwnPtr<CancellableTaskFactory> create(T* thisObject, void (T::*method)(), typename WTF::EnableIf<IsGarbageCollectedType<T>::value>::Type* = nullptr) | 
| +    { | 
| +        return adoptPtr(new CancellableTaskFactory(WTF::bind(method, AllowCrossThreadWeakPersistent<T>(thisObject)))); | 
| +    } | 
| + | 
| +    template<typename T> | 
| +    static PassOwnPtr<CancellableTaskFactory> create(T* thisObject, void (T::*method)(), typename WTF::EnableIf<!IsGarbageCollectedType<T>::value>::Type* = nullptr) | 
| +    { | 
| +        return adoptPtr(new CancellableTaskFactory(WTF::bind(method, thisObject))); | 
| +    } | 
| + | 
| +    // Only intended used by unit tests. Please use leak safe create() factory method, if possible. | 
| explicit CancellableTaskFactory(PassOwnPtr<Closure> closure) | 
| : m_closure(closure) | 
| -#if defined(ADDRESS_SANITIZER) | 
| -        , m_unpoisonBeforeUpdate(false) | 
| -#endif | 
| , m_weakPtrFactory(this) | 
| { | 
| } | 
| @@ -42,15 +66,6 @@ public: | 
| // ownership of the task.  Creating a new task cancels any previous ones. | 
| WebTaskRunner::Task* cancelAndCreate(); | 
|  | 
| -#if defined(ADDRESS_SANITIZER) | 
| -    // The CancellableTaskFactory part object might be within a poisoned heap | 
| -    // object, hence CancellableTask::run() will access poisoned memory | 
| -    // when reaching into the factory object to update its state. | 
| -    // We will allow such access iff the task factory is marked as requiring | 
| -    // unpoisoning first. | 
| -    void setUnpoisonBeforeUpdate() { m_unpoisonBeforeUpdate = true; } | 
| -#endif | 
| - | 
| private: | 
| class CancellableTask : public WebTaskRunner::Task { | 
| WTF_MAKE_NONCOPYABLE(CancellableTask); | 
| @@ -68,9 +83,6 @@ private: | 
| }; | 
|  | 
| OwnPtr<Closure> m_closure; | 
| -#if defined(ADDRESS_SANITIZER) | 
| -    bool m_unpoisonBeforeUpdate; | 
| -#endif | 
| WeakPtrFactory<CancellableTaskFactory> m_weakPtrFactory; | 
| }; | 
|  | 
|  |