| Index: ppapi/native_client/src/shared/ppapi_proxy/plugin_resource_tracker.h
|
| ===================================================================
|
| --- ppapi/native_client/src/shared/ppapi_proxy/plugin_resource_tracker.h (revision 0)
|
| +++ ppapi/native_client/src/shared/ppapi_proxy/plugin_resource_tracker.h (revision 0)
|
| @@ -0,0 +1,91 @@
|
| +// Copyright (c) 2011 The Native Client 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 WEBKIT_GLUE_PLUGINS_PEPPER_RESOURCE_TRACKER_H_
|
| +#define WEBKIT_GLUE_PLUGINS_PEPPER_RESOURCE_TRACKER_H_
|
| +
|
| +#include <map>
|
| +#include <utility>
|
| +
|
| +#include "native_client/src/include/nacl_base.h"
|
| +#include "native_client/src/include/ref_counted.h"
|
| +#include "ppapi/c/pp_instance.h"
|
| +#include "ppapi/c/pp_module.h"
|
| +#include "ppapi/c/pp_resource.h"
|
| +
|
| +namespace ppapi_proxy {
|
| +
|
| +class PluginInstance;
|
| +class PluginResource;
|
| +
|
| +// This class maintains a global list of all live pepper resources. It allows
|
| +// us to check resource ID validity and to map them to a specific module.
|
| +//
|
| +// This object is threadsafe.
|
| +class PluginResourceTracker {
|
| + public:
|
| + // Returns the pointer to the singleton object.
|
| + static PluginResourceTracker* Get() {
|
| + static PluginResourceTracker tracker;
|
| + return &tracker;
|
| + }
|
| +
|
| + // PP_Resources --------------------------------------------------------------
|
| +
|
| + // Increment resource's plugin refcount. See ResourceAndRefCount.
|
| + bool AddRefResource(PP_Resource res);
|
| + bool UnrefResource(PP_Resource res);
|
| +
|
| + private:
|
| + friend class PluginResource;
|
| +
|
| + // Prohibit creation other then by the Singleton class.
|
| + PluginResourceTracker();
|
| +
|
| + // Adds the given resource to the tracker and assigns it a resource ID, local
|
| + // refcount of 1, and initializes the browser reference count to
|
| + // |browser_refcount|. Used only by the Resource class.
|
| + void AddResource(PluginResource* resource, PP_Resource id,
|
| + size_t browser_refcount);
|
| +
|
| + // The returned pointer will be NULL if there is no resource. Note that this
|
| + // return value is a scoped_refptr so that we ensure the resource is valid
|
| + // from the point of the lookup to the point that the calling code needs it.
|
| + // Otherwise, the plugin could Release() the resource on another thread and
|
| + // the object will get deleted out from under us.
|
| + scoped_refptr<PluginResource> GetExistingResource(PP_Resource res) const;
|
| +
|
| + // Get or create a new PluginResource from a browser resource.
|
| + // If we are already tracking this resource, we bump its browser_refcount to
|
| + // reflect that we took ownership of it. If this is a new resource, we create
|
| + // a PluginResource for it with the given browser_refcount.
|
| + template<typename T> scoped_refptr<T> AdoptBrowserResource(
|
| + PP_Resource res, size_t browser_refcount);
|
| +
|
| + // Try to get a browser-side refcount for an existing resource.
|
| + void ObtainBrowserResource(PP_Resource res);
|
| +
|
| + // Release browser-side refcount.
|
| + void ReleaseBrowserResource(PP_Resource res, size_t refcount);
|
| +
|
| + // Last assigned resource ID.
|
| + PP_Resource last_id_;
|
| +
|
| + struct ResourceAndRefCounts {
|
| + scoped_refptr<PluginResource> resource;
|
| + size_t browser_refcount;
|
| + size_t plugin_refcount;
|
| + ResourceAndRefCounts(PluginResource* r, size_t browser_refcount);
|
| + ~ResourceAndRefCounts();
|
| + };
|
| + typedef std::map<PP_Resource, ResourceAndRefCounts> ResourceMap;
|
| + ResourceMap live_resources_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(PluginResourceTracker);
|
| +};
|
| +
|
| +} // namespace ppapi_proxy
|
| +
|
| +#endif // WEBKIT_GLUE_PLUGINS_PEPPER_RESOURCE_TRACKER_H_
|
| +
|
|
|