// Copyright 2013 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef PPAPI_PROXY_RESOURCE_REPLY_THREAD_REGISTRAR_H_ #define PPAPI_PROXY_RESOURCE_REPLY_THREAD_REGISTRAR_H_ #include <map> #include "base/basictypes.h" #include "base/memory/ref_counted.h" #include "base/synchronization/lock.h" #include "ppapi/c/pp_resource.h" #include "ppapi/proxy/ppapi_proxy_export.h" namespace base { class MessageLoopProxy; } namespace ppapi { class TrackedCallback; namespace proxy { // ResourceReplyThreadRegistrar records the handling thread for // PpapiPluginMsg_ResourceReply messages. // This class is thread safe. class PPAPI_PROXY_EXPORT ResourceReplyThreadRegistrar : public base::RefCountedThreadSafe<ResourceReplyThreadRegistrar> { public: explicit ResourceReplyThreadRegistrar( scoped_refptr<base::MessageLoopProxy> default_thread); // This method can only be called while holding the Pepper proxy lock; the // other methods can be called with/without the Pepper proxy lock. void Register(PP_Resource resource, int32_t sequence_number, scoped_refptr<TrackedCallback> reply_thread_hint); void Unregister(PP_Resource resource); scoped_refptr<base::MessageLoopProxy> GetTargetThreadAndUnregister( PP_Resource resource, int32_t sequence_number); private: friend class base::RefCountedThreadSafe<ResourceReplyThreadRegistrar>; typedef std::map<int32_t, scoped_refptr<base::MessageLoopProxy> > SequenceNumberMap; typedef std::map<PP_Resource, SequenceNumberMap> ResourceMap; ~ResourceReplyThreadRegistrar(); // The lock that protects the data members below. // Please note that we should never try to acquire the Pepper proxy lock while // holding |lock_|, otherwise we will cause deadlock. base::Lock lock_; ResourceMap map_; scoped_refptr<base::MessageLoopProxy> default_thread_; DISALLOW_COPY_AND_ASSIGN(ResourceReplyThreadRegistrar); }; } // namespace proxy } // namespace ppapi #endif // PPAPI_PROXY_RESOURCE_REPLY_THREAD_REGISTRAR_H_