diff options
-rw-r--r-- | content/renderer/pepper_plugin_delegate_impl.cc | 19 | ||||
-rw-r--r-- | content/renderer/pepper_plugin_delegate_impl.h | 3 | ||||
-rw-r--r-- | ppapi/c/trusted/ppb_broker_trusted.h | 66 | ||||
-rw-r--r-- | ppapi/ppapi_cpp.gypi | 1 | ||||
-rw-r--r-- | webkit/glue/webkit_glue.gypi | 2 | ||||
-rw-r--r-- | webkit/plugins/ppapi/mock_plugin_delegate.cc | 6 | ||||
-rw-r--r-- | webkit/plugins/ppapi/mock_plugin_delegate.h | 2 | ||||
-rw-r--r-- | webkit/plugins/ppapi/plugin_delegate.h | 23 | ||||
-rw-r--r-- | webkit/plugins/ppapi/plugin_module.cc | 4 | ||||
-rw-r--r-- | webkit/plugins/ppapi/ppb_audio_impl.h | 6 | ||||
-rw-r--r-- | webkit/plugins/ppapi/ppb_broker_impl.cc | 135 | ||||
-rw-r--r-- | webkit/plugins/ppapi/ppb_broker_impl.h | 55 | ||||
-rw-r--r-- | webkit/plugins/ppapi/resource.h | 1 |
13 files changed, 319 insertions, 4 deletions
diff --git a/content/renderer/pepper_plugin_delegate_impl.cc b/content/renderer/pepper_plugin_delegate_impl.cc index 96c775c..b598a96 100644 --- a/content/renderer/pepper_plugin_delegate_impl.cc +++ b/content/renderer/pepper_plugin_delegate_impl.cc @@ -53,6 +53,7 @@ #include "webkit/plugins/ppapi/ppb_file_io_impl.h" #include "webkit/plugins/ppapi/plugin_module.h" #include "webkit/plugins/ppapi/ppapi_plugin_instance.h" +#include "webkit/plugins/ppapi/ppb_broker_impl.h" #include "webkit/plugins/ppapi/ppb_flash_impl.h" #include "webkit/plugins/ppapi/ppb_flash_net_connector_impl.h" @@ -556,6 +557,24 @@ PepperPluginDelegateImpl::CreateAudio( } } +webkit::ppapi::PluginDelegate::PpapiBroker* +PepperPluginDelegateImpl::ConnectToPpapiBroker( + webkit::ppapi::PluginInstance* instance, + webkit::ppapi::PPB_Broker_Impl* client) { + CHECK(instance); + CHECK(client); + + // TODO(ddorwin): Add IPC to broker process to do the following. + // 1) Check if there is an existing broker for instance->module(). + // 2) If not, create. + // 3) broker->Connect(client). + // * Asynchronously launches broker if necessary, establishes pipe, and + // calls BrokerConnected. + // 4) Return pointer to broker. + + return NULL; +} + bool PepperPluginDelegateImpl::RunFileChooser( const WebKit::WebFileChooserParams& params, WebKit::WebFileChooserCompletion* chooser_completion) { diff --git a/content/renderer/pepper_plugin_delegate_impl.h b/content/renderer/pepper_plugin_delegate_impl.h index f839229..8749f3d 100644 --- a/content/renderer/pepper_plugin_delegate_impl.h +++ b/content/renderer/pepper_plugin_delegate_impl.h @@ -100,6 +100,9 @@ class PepperPluginDelegateImpl virtual PlatformContext3D* CreateContext3D(); virtual PlatformVideoDecoder* CreateVideoDecoder( PP_VideoDecoderConfig_Dev* decoder_config); + virtual PpapiBroker* ConnectToPpapiBroker( + webkit::ppapi::PluginInstance* instance, + webkit::ppapi::PPB_Broker_Impl* client); virtual void NumberOfFindResultsChanged(int identifier, int total, bool final_result); diff --git a/ppapi/c/trusted/ppb_broker_trusted.h b/ppapi/c/trusted/ppb_broker_trusted.h new file mode 100644 index 0000000..68f2a97 --- /dev/null +++ b/ppapi/c/trusted/ppb_broker_trusted.h @@ -0,0 +1,66 @@ +/* Copyright (c) 2011 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_C_PPB_BROKER_TRUSTED_H_ +#define PPAPI_C_PPB_BROKER_TRUSTED_H_ + +#include "ppapi/c/pp_completion_callback.h" +#include "ppapi/c/pp_bool.h" +#include "ppapi/c/pp_instance.h" +#include "ppapi/c/pp_resource.h" + +#define PPB_BROKER_TRUSTED_INTERFACE "PPB_BrokerTrusted;0.1" + +/** + * @file + * This file defines the PPB_BrokerTrusted interface, which provides + * access to a trusted broker with greater privileges than the plugin. + */ + +/** + * @addtogroup Interfaces + * @{ + */ + +/** + * The PPB_BrokerTrusted interface provides access to a trusted broker + * with greater privileges than the plugin. The interface only supports + * out-of-process plugins and is to be used by proxy implementations. All + * functions should be called from the main thread only. + */ +struct PPB_BrokerTrusted { + /** + * Returns a trusted broker resource. + */ + PP_Resource (*CreateTrusted)(PP_Instance instance); + + /** + * Returns true if the resource is a trusted broker. + */ + PP_Bool (*IsBrokerTrusted)(PP_Resource resource); + + /** + * Connects to the trusted broker. It may have already + * been launched by another plugin instance. + * Returns PP_ERROR_WOULD_BLOCK on success, and invokes + * the |connect_callback| asynchronously to complete. + * As this function should always be invoked from the main thread, + * do not use the blocking variant of PP_CompletionCallback. + * Returns PP_ERROR_FAILED if called from an in-process plugin. + */ + int32_t (*Connect)(PP_Resource broker, + struct PP_CompletionCallback connect_callback); + + /** + * Returns the handle to the pipe. Use once Connect has completed. + * Returns PP_OK on success. + * Each plugin instance has its own pipe. + */ + int32_t (*GetHandle)(PP_Resource broker, int32_t* handle); +}; +/** + * @} + */ + +#endif /* PPAPI_C_PPB_BROKER_TRUSTED_H_ */ diff --git a/ppapi/ppapi_cpp.gypi b/ppapi/ppapi_cpp.gypi index ecd9fa0..be43504 100644 --- a/ppapi/ppapi_cpp.gypi +++ b/ppapi/ppapi_cpp.gypi @@ -102,6 +102,7 @@ # Trusted interfaces. 'c/trusted/ppb_audio_trusted.h', 'c/trusted/ppb_image_data_trusted.h', + 'c/trusted/ppb_broker_trusted.h', 'c/trusted/ppb_url_loader_trusted.h', ], }, diff --git a/webkit/glue/webkit_glue.gypi b/webkit/glue/webkit_glue.gypi index 4d999e5..001fd18 100644 --- a/webkit/glue/webkit_glue.gypi +++ b/webkit/glue/webkit_glue.gypi @@ -230,6 +230,8 @@ '../plugins/ppapi/ppapi_webplugin_impl.h', '../plugins/ppapi/ppb_audio_impl.cc', '../plugins/ppapi/ppb_audio_impl.h', + '../plugins/ppapi/ppb_broker_impl.cc', + '../plugins/ppapi/ppb_broker_impl.h', '../plugins/ppapi/ppb_buffer_impl.cc', '../plugins/ppapi/ppb_buffer_impl.h', '../plugins/ppapi/ppb_char_set_impl.cc', diff --git a/webkit/plugins/ppapi/mock_plugin_delegate.cc b/webkit/plugins/ppapi/mock_plugin_delegate.cc index 10aee19..5376483 100644 --- a/webkit/plugins/ppapi/mock_plugin_delegate.cc +++ b/webkit/plugins/ppapi/mock_plugin_delegate.cc @@ -52,6 +52,12 @@ MockPluginDelegate::PlatformAudio* MockPluginDelegate::CreateAudio( return NULL; } +MockPluginDelegate::PpapiBroker* MockPluginDelegate::ConnectToPpapiBroker( + PluginInstance* instance, + PPB_Broker_Impl* client) { + return NULL; +} + void MockPluginDelegate::NumberOfFindResultsChanged(int identifier, int total, bool final_result) { diff --git a/webkit/plugins/ppapi/mock_plugin_delegate.h b/webkit/plugins/ppapi/mock_plugin_delegate.h index 9e91160..754282f7 100644 --- a/webkit/plugins/ppapi/mock_plugin_delegate.h +++ b/webkit/plugins/ppapi/mock_plugin_delegate.h @@ -26,6 +26,8 @@ class MockPluginDelegate : public PluginDelegate { virtual PlatformAudio* CreateAudio(uint32_t sample_rate, uint32_t sample_count, PlatformAudio::Client* client); + virtual PpapiBroker* ConnectToPpapiBroker(PluginInstance* instance, + PPB_Broker_Impl* client); virtual void NumberOfFindResultsChanged(int identifier, int total, bool final_result); diff --git a/webkit/plugins/ppapi/plugin_delegate.h b/webkit/plugins/ppapi/plugin_delegate.h index 6112d53..6349cd9 100644 --- a/webkit/plugins/ppapi/plugin_delegate.h +++ b/webkit/plugins/ppapi/plugin_delegate.h @@ -67,6 +67,7 @@ class FullscreenContainer; class PepperFilePath; class PluginInstance; class PluginModule; +class PPB_Broker_Impl; class PPB_Flash_Menu_Impl; class PPB_Flash_NetConnector_Impl; @@ -95,7 +96,7 @@ class PluginDelegate { }; // This class is implemented by the PluginDelegate implementation and is - // designed to manage the lifetime and communicatin with the proxy's + // designed to manage the lifetime and communication with the proxy's // HostDispatcher for out-of-process PPAPI plugins. // // The point of this is to avoid having a relationship from the PPAPI plugin @@ -204,6 +205,18 @@ class PluginDelegate { virtual ~PlatformVideoDecoder() {} }; + // Provides access to the ppapi broker. + class PpapiBroker { + public: + virtual ~PpapiBroker() {} + + // Decrements the references to the broker for the instance. + // When the references reach 0 for all instances in this renderer, this + // object may be destroyed. When the references reach 0 for all instances + // using the same module, the broker may shut down. + virtual void Release(PluginInstance* instance) = 0; + }; + // Notification that the given plugin has crashed. When a plugin crashes, all // instances associated with that plugin will notify that they've crashed via // this function. @@ -237,6 +250,14 @@ class PluginDelegate { uint32_t sample_count, PlatformAudio::Client* client) = 0; + // A pointer is returned immediately, but it is not ready to be used until + // BrokerConnected has been called. + // The caller is responsible for calling Release() on the returned pointer + // to clean up the corresponding resources allocated during this call. + virtual PpapiBroker* ConnectToPpapiBroker( + PluginInstance* instance, + webkit::ppapi::PPB_Broker_Impl* client) = 0; + // Notifies that the number of find results has changed. virtual void NumberOfFindResultsChanged(int identifier, int total, diff --git a/webkit/plugins/ppapi/plugin_module.cc b/webkit/plugins/ppapi/plugin_module.cc index b4ab5f0..6a7c397 100644 --- a/webkit/plugins/ppapi/plugin_module.cc +++ b/webkit/plugins/ppapi/plugin_module.cc @@ -58,12 +58,14 @@ #include "ppapi/c/private/ppb_pdf.h" #include "ppapi/c/private/ppb_proxy_private.h" #include "ppapi/c/private/ppb_nacl_private.h" +#include "ppapi/c/trusted/ppb_broker_trusted.h" #include "ppapi/c/trusted/ppb_image_data_trusted.h" #include "ppapi/c/trusted/ppb_url_loader_trusted.h" #include "webkit/plugins/ppapi/callbacks.h" #include "webkit/plugins/ppapi/common.h" #include "webkit/plugins/ppapi/ppapi_plugin_instance.h" #include "webkit/plugins/ppapi/ppb_audio_impl.h" +#include "webkit/plugins/ppapi/ppb_broker_impl.h" #include "webkit/plugins/ppapi/ppb_buffer_impl.h" #include "webkit/plugins/ppapi/ppb_char_set_impl.h" #include "webkit/plugins/ppapi/ppb_console_impl.h" @@ -225,6 +227,8 @@ const void* GetInterface(const char* name) { return PPB_Audio_Impl::GetInterface(); if (strcmp(name, PPB_AUDIO_TRUSTED_INTERFACE) == 0) return PPB_Audio_Impl::GetTrustedInterface(); + if (strcmp(name, PPB_BROKER_TRUSTED_INTERFACE) == 0) + return PPB_Broker_Impl::GetTrustedInterface(); if (strcmp(name, PPB_BUFFER_DEV_INTERFACE) == 0) return PPB_Buffer_Impl::GetInterface(); if (strcmp(name, PPB_CHAR_SET_DEV_INTERFACE) == 0) diff --git a/webkit/plugins/ppapi/ppb_audio_impl.h b/webkit/plugins/ppapi/ppb_audio_impl.h index 62f33d4..9ea2588 100644 --- a/webkit/plugins/ppapi/ppb_audio_impl.h +++ b/webkit/plugins/ppapi/ppb_audio_impl.h @@ -2,8 +2,8 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. -#ifndef WEBKIT_PLUGINS_PPAPI_DEVICE_CONTEXT_AUDIO_H_ -#define WEBKIT_PLUGINS_PPAPI_DEVICE_CONTEXT_AUDIO_H_ +#ifndef WEBKIT_PLUGINS_PPAPI_PPB_AUDIO_IMPL_H_ +#define WEBKIT_PLUGINS_PPAPI_PPB_AUDIO_IMPL_H_ #include "base/basictypes.h" #include "base/memory/ref_counted.h" @@ -105,4 +105,4 @@ class PPB_Audio_Impl : public Resource, } // namespace ppapi } // namespace webkit -#endif // WEBKIT_PLUGINS_PPAPI_DEVICE_CONTEXT_AUDIO_H_ +#endif // WEBKIT_PLUGINS_PPAPI_PPB_AUDIO_IMPL_H_ diff --git a/webkit/plugins/ppapi/ppb_broker_impl.cc b/webkit/plugins/ppapi/ppb_broker_impl.cc new file mode 100644 index 0000000..d214c7b --- /dev/null +++ b/webkit/plugins/ppapi/ppb_broker_impl.cc @@ -0,0 +1,135 @@ +// Copyright (c) 2011 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 "webkit/plugins/ppapi/ppb_broker_impl.h" + +#include "base/logging.h" +#include "webkit/plugins/ppapi/common.h" +#include "webkit/plugins/ppapi/plugin_module.h" + +namespace webkit { +namespace ppapi { + +namespace { + +// PPB_BrokerTrusted ---------------------------------------------------- + +PP_Resource CreateTrusted(PP_Instance instance_id) { + PluginInstance* instance = ResourceTracker::Get()->GetInstance(instance_id); + if (!instance) + return 0; + scoped_refptr<PPB_Broker_Impl> broker(new PPB_Broker_Impl(instance)); + return broker->GetReference(); +} + +PP_Bool IsBrokerTrusted(PP_Resource resource) { + scoped_refptr<PPB_Broker_Impl> broker = + Resource::GetAs<PPB_Broker_Impl>(resource); + return BoolToPPBool(!!broker); +} + +int32_t Connect(PP_Resource broker_id, + PP_CompletionCallback connect_callback) { + scoped_refptr<PPB_Broker_Impl> broker = + Resource::GetAs<PPB_Broker_Impl>(broker_id); + if (!broker) + return PP_ERROR_BADRESOURCE; + if (!connect_callback.func) { + // Synchronous calls are not supported. + return PP_ERROR_BADARGUMENT; + } + return broker->Connect(broker->instance()->delegate(), connect_callback); +} + +int32_t GetHandle(PP_Resource broker_id, int32_t* handle) { + scoped_refptr<PPB_Broker_Impl> broker = + Resource::GetAs<PPB_Broker_Impl>(broker_id); + if (!broker) + return PP_ERROR_BADRESOURCE; + if (!handle) + return PP_ERROR_BADARGUMENT; + return broker->GetHandle(handle); +} + +const PPB_BrokerTrusted ppb_brokertrusted = { + &CreateTrusted, + &IsBrokerTrusted, + &Connect, + &GetHandle, +}; + +} // namespace + +// PPB_Broker_Impl ------------------------------------------------------ + +PPB_Broker_Impl::PPB_Broker_Impl(PluginInstance* instance) + : Resource(instance), + broker_(NULL), + connect_callback_(), + pipe_handle_(0) { +} + +PPB_Broker_Impl::~PPB_Broker_Impl() { + if (broker_) { + broker_->Release(instance()); + broker_ = NULL; + } + + // TODO(ddorwin): Should the plugin or Chrome free the handle? + pipe_handle_ = 0; +} + +const PPB_BrokerTrusted* PPB_Broker_Impl::GetTrustedInterface() { + return &ppb_brokertrusted; +} + +int32_t PPB_Broker_Impl::Connect( + PluginDelegate* plugin_delegate, + PP_CompletionCallback connect_callback) { + // TODO(ddorwin): Return PP_ERROR_FAILED if plugin is in-process. + + if (broker_) { + // May only be called once. + return PP_ERROR_FAILED; + } + + broker_ = plugin_delegate->ConnectToPpapiBroker(instance(), this); + if (!broker_) + return PP_ERROR_FAILED; + + PP_Resource resource_id = GetReferenceNoAddRef(); + CHECK(resource_id); + connect_callback_ = new TrackedCompletionCallback( + instance()->module()->GetCallbackTracker(), resource_id, + connect_callback); + return PP_ERROR_WOULDBLOCK; +} + +int32_t PPB_Broker_Impl::GetHandle(int32_t* handle) { + *handle = pipe_handle_; + + if (!*handle) + return PP_ERROR_FAILED; + + return PP_OK; +} + +PPB_Broker_Impl* PPB_Broker_Impl::AsPPB_Broker_Impl() { + return this; +} + +void PPB_Broker_Impl::BrokerConnected(int32_t handle) { + DCHECK(handle); + pipe_handle_ = handle; + + // Synchronous calls are not supported. + DCHECK(connect_callback_.get() && !connect_callback_->completed()); + + scoped_refptr<TrackedCompletionCallback> callback; + callback.swap(connect_callback_); + callback->Run(0); // Will complete abortively if necessary. +} + +} // namespace ppapi +} // namespace webkit diff --git a/webkit/plugins/ppapi/ppb_broker_impl.h b/webkit/plugins/ppapi/ppb_broker_impl.h new file mode 100644 index 0000000..f83d280 --- /dev/null +++ b/webkit/plugins/ppapi/ppb_broker_impl.h @@ -0,0 +1,55 @@ +// Copyright (c) 2011 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 WEBKIT_PLUGINS_PPAPI_PPB_BROKER_IMPL_H_ +#define WEBKIT_PLUGINS_PPAPI_PPB_BROKER_IMPL_H_ + +#include "base/basictypes.h" +#include "ppapi/c/pp_completion_callback.h" +#include "ppapi/c/trusted/ppb_broker_trusted.h" +#include "webkit/plugins/ppapi/plugin_delegate.h" +#include "webkit/plugins/ppapi/ppapi_plugin_instance.h" +#include "webkit/plugins/ppapi/callbacks.h" +#include "webkit/plugins/ppapi/resource.h" + +namespace webkit { +namespace ppapi { + +class PluginInstance; + +class PPB_Broker_Impl : public Resource { + public: + explicit PPB_Broker_Impl(PluginInstance* instance); + virtual ~PPB_Broker_Impl(); + + static const PPB_BrokerTrusted* GetTrustedInterface(); + + // PPB_BrokerTrusted implementation. + int32_t Connect(PluginDelegate* plugin_delegate, + PP_CompletionCallback connect_callback); + int32_t GetHandle(int32_t* handle); + + // Resource override. + virtual PPB_Broker_Impl* AsPPB_Broker_Impl(); + + virtual void BrokerConnected(int32_t handle); + + private: + // PluginDelegate ppapi broker object. + // We don't own this pointer but are responsible for calling Release on it. + PluginDelegate::PpapiBroker* broker_; + + // Callback invoked from BrokerConnected. + scoped_refptr<TrackedCompletionCallback> connect_callback_; + + // Pipe handle for the plugin instance to use to communicate with the broker. + int32_t pipe_handle_; + + DISALLOW_COPY_AND_ASSIGN(PPB_Broker_Impl); +}; + +} // namespace ppapi +} // namespace webkit + +#endif // WEBKIT_PLUGINS_PPAPI_PPB_BROKER_IMPL_H_ diff --git a/webkit/plugins/ppapi/resource.h b/webkit/plugins/ppapi/resource.h index 018988f..267249b 100644 --- a/webkit/plugins/ppapi/resource.h +++ b/webkit/plugins/ppapi/resource.h @@ -18,6 +18,7 @@ namespace ppapi { F(MockResource) \ F(PPB_AudioConfig_Impl) \ F(PPB_Audio_Impl) \ + F(PPB_Broker_Impl) \ F(PPB_Buffer_Impl) \ F(PPB_Context3D_Impl) \ F(PPB_DirectoryReader_Impl) \ |