blob: 256890c79dd8b05d02512f50dd02f55f61a85ea2 [file] [log] [blame]
// 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.
#include <stdint.h>
#include <map>
#include <set>
#include "base/macros.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 SingleThreadTaskRunner;
namespace IPC {
class Message;
namespace ppapi {
class TrackedCallback;
namespace proxy {
class ResourceMessageReplyParams;
// ResourceReplyThreadRegistrar records the handling thread for
// PpapiPluginMsg_ResourceReply messages.
// This class is thread safe.
class PPAPI_PROXY_EXPORT ResourceReplyThreadRegistrar
: public base::RefCountedThreadSafe<ResourceReplyThreadRegistrar> {
explicit ResourceReplyThreadRegistrar(
scoped_refptr<base::SingleThreadTaskRunner> main_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::SingleThreadTaskRunner> GetTargetThread(
const ResourceMessageReplyParams& reply_params,
const IPC::Message& nested_msg);
friend class base::RefCountedThreadSafe<ResourceReplyThreadRegistrar>;
typedef std::map<int32_t, scoped_refptr<base::SingleThreadTaskRunner>>
typedef std::map<PP_Resource, SequenceThreadMap> ResourceMap;
// 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::SingleThreadTaskRunner> main_thread_;
} // namespace proxy
} // namespace ppapi