summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authordmichael@chromium.org <dmichael@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-02-16 19:39:22 +0000
committerdmichael@chromium.org <dmichael@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-02-16 19:39:22 +0000
commit10305deb1ed8a625a34629c372c7aae171e07cac (patch)
treead8b7d5e3ea63b6848fa05a6cc298df7743a21d9
parentc98ea3f52244b1a083e48ba760fb184fff664cd7 (diff)
downloadchromium_src-10305deb1ed8a625a34629c372c7aae171e07cac.zip
chromium_src-10305deb1ed8a625a34629c372c7aae171e07cac.tar.gz
chromium_src-10305deb1ed8a625a34629c372c7aae171e07cac.tar.bz2
PPAPI: Proxy VarArrayBuffer for out-of-process.
BUG=103435 TEST= Review URL: https://chromiumcodereview.appspot.com/9373032 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@122340 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--chrome/test/ui/ppapi_uitest.cc2
-rw-r--r--ppapi/proxy/host_var_serialization_rules.cc4
-rw-r--r--ppapi/proxy/interface_list.cc3
-rw-r--r--ppapi/proxy/plugin_var_serialization_rules.cc10
-rw-r--r--ppapi/proxy/ppb_instance_proxy.cc5
-rw-r--r--ppapi/proxy/serialized_var.cc32
-rw-r--r--ppapi/shared_impl/var_tracker.cc11
-rw-r--r--ppapi/shared_impl/var_tracker.h2
-rw-r--r--ppapi/thunk/interfaces_ppb_public_dev.h1
-rw-r--r--ppapi/thunk/interfaces_ppb_public_stable.h3
10 files changed, 58 insertions, 15 deletions
diff --git a/chrome/test/ui/ppapi_uitest.cc b/chrome/test/ui/ppapi_uitest.cc
index e6fa0c9..271068eb 100644
--- a/chrome/test/ui/ppapi_uitest.cc
+++ b/chrome/test/ui/ppapi_uitest.cc
@@ -523,7 +523,7 @@ TEST_PPAPI_IN_PROCESS(PostMessage_NoHandler)
TEST_PPAPI_IN_PROCESS(PostMessage_ExtraParam)
TEST_PPAPI_OUT_OF_PROCESS(PostMessage_SendInInit)
TEST_PPAPI_OUT_OF_PROCESS(PostMessage_SendingData)
-TEST_PPAPI_OUT_OF_PROCESS(DISABLED_PostMessage_SendingArrayBuffer)
+TEST_PPAPI_OUT_OF_PROCESS(PostMessage_SendingArrayBuffer)
TEST_PPAPI_OUT_OF_PROCESS(PostMessage_MessageEvent)
TEST_PPAPI_OUT_OF_PROCESS(PostMessage_NoHandler)
TEST_PPAPI_OUT_OF_PROCESS(PostMessage_ExtraParam)
diff --git a/ppapi/proxy/host_var_serialization_rules.cc b/ppapi/proxy/host_var_serialization_rules.cc
index 52b2cbc..d6b5677 100644
--- a/ppapi/proxy/host_var_serialization_rules.cc
+++ b/ppapi/proxy/host_var_serialization_rules.cc
@@ -35,8 +35,8 @@ PP_Var HostVarSerializationRules::BeginReceiveCallerOwned(
}
void HostVarSerializationRules::EndReceiveCallerOwned(const PP_Var& var) {
- if (var.type == PP_VARTYPE_STRING) {
- // Destroy the string.
+ if (var.type != PP_VARTYPE_OBJECT && var.type >= PP_VARTYPE_STRING) {
+ // Release our reference to the local Var.
PpapiGlobals::Get()->GetVarTracker()->ReleaseVar(var);
}
}
diff --git a/ppapi/proxy/interface_list.cc b/ppapi/proxy/interface_list.cc
index c37da44..ce456ddc 100644
--- a/ppapi/proxy/interface_list.cc
+++ b/ppapi/proxy/interface_list.cc
@@ -42,6 +42,7 @@
#include "ppapi/c/ppb_url_request_info.h"
#include "ppapi/c/ppb_url_response_info.h"
#include "ppapi/c/ppb_var.h"
+#include "ppapi/c/ppb_var_array_buffer.h"
#include "ppapi/c/ppb_view.h"
#include "ppapi/c/pp_errors.h"
#include "ppapi/c/ppp_instance.h"
@@ -178,6 +179,8 @@ InterfaceList::InterfaceList() {
PPB_MessageLoop_Proxy::GetInterface());
AddPPB(PPB_OPENGLES2_INTERFACE_1_0, API_ID_NONE,
PPB_OpenGLES2_Shared::GetInterface());
+ AddPPB(PPB_VAR_ARRAY_BUFFER_INTERFACE_1_0, API_ID_NONE,
+ PPB_Var_Shared::GetVarArrayBufferInterface1_0());
AddPPB(PPB_VAR_INTERFACE_1_1, API_ID_NONE,
PPB_Var_Shared::GetVarInterface1_1());
AddPPB(PPB_VAR_INTERFACE_1_0, API_ID_NONE,
diff --git a/ppapi/proxy/plugin_var_serialization_rules.cc b/ppapi/proxy/plugin_var_serialization_rules.cc
index 0456637..461676f 100644
--- a/ppapi/proxy/plugin_var_serialization_rules.cc
+++ b/ppapi/proxy/plugin_var_serialization_rules.cc
@@ -41,11 +41,11 @@ PP_Var PluginVarSerializationRules::BeginReceiveCallerOwned(
}
void PluginVarSerializationRules::EndReceiveCallerOwned(const PP_Var& var) {
- if (var.type == PP_VARTYPE_STRING) {
- // Destroy the string.
- var_tracker_->ReleaseVar(var);
- } else if (var.type == PP_VARTYPE_OBJECT) {
+ if (var.type == PP_VARTYPE_OBJECT) {
var_tracker_->StopTrackingObjectWithNoReference(var);
+ } else if (var.type >= PP_VARTYPE_STRING) {
+ // Release our reference to the local Var.
+ var_tracker_->ReleaseVar(var);
}
}
@@ -108,7 +108,7 @@ void PluginVarSerializationRules::EndSendPassRef(const PP_Var& var,
if (var.type == PP_VARTYPE_OBJECT) {
var_tracker_->ReleaseHostObject(
static_cast<PluginDispatcher*>(dispatcher), var);
- } else if (var.type == PP_VARTYPE_STRING) {
+ } else if (var.type >= PP_VARTYPE_STRING) {
var_tracker_->ReleaseVar(var);
}
}
diff --git a/ppapi/proxy/ppb_instance_proxy.cc b/ppapi/proxy/ppb_instance_proxy.cc
index 62335c2..7cc33f0 100644
--- a/ppapi/proxy/ppb_instance_proxy.cc
+++ b/ppapi/proxy/ppb_instance_proxy.cc
@@ -491,8 +491,9 @@ void PPB_Instance_Proxy::OnHostMsgClearInputEvents(PP_Instance instance,
enter.functions()->ClearInputEventRequest(instance, event_classes);
}
-void PPB_Instance_Proxy::OnHostMsgPostMessage(PP_Instance instance,
- SerializedVarReceiveInput message) {
+void PPB_Instance_Proxy::OnHostMsgPostMessage(
+ PP_Instance instance,
+ SerializedVarReceiveInput message) {
EnterInstanceNoLock enter(instance, false);
if (enter.succeeded())
enter.functions()->PostMessage(instance, message.Get(dispatcher()));
diff --git a/ppapi/proxy/serialized_var.cc b/ppapi/proxy/serialized_var.cc
index 7153c0c..eb20333 100644
--- a/ppapi/proxy/serialized_var.cc
+++ b/ppapi/proxy/serialized_var.cc
@@ -5,11 +5,13 @@
#include "ppapi/proxy/serialized_var.h"
#include "base/logging.h"
+#include "base/memory/ref_counted.h"
#include "ipc/ipc_message_utils.h"
#include "ppapi/proxy/dispatcher.h"
#include "ppapi/proxy/interface_proxy.h"
#include "ppapi/proxy/ppapi_param_traits.h"
#include "ppapi/proxy/var_serialization_rules.h"
+#include "ppapi/shared_impl/ppapi_globals.h"
#include "ppapi/shared_impl/var.h"
namespace ppapi {
@@ -116,10 +118,24 @@ void SerializedVar::Inner::WriteToMessage(IPC::Message* m) const {
m->WriteString(string_var ? *string_var->ptr() : std::string());
break;
}
- case PP_VARTYPE_ARRAY_BUFFER:
- // TODO(dmichael): Proxy ArrayBuffer.
- NOTIMPLEMENTED();
+ case PP_VARTYPE_ARRAY_BUFFER: {
+ // TODO(dmichael) in the case of an invalid var ID, it would be nice
+ // to send something to the other side such that a 0 ID would be
+ // generated there. Then the function implementing the interface can
+ // handle the invalid string as if it was in process rather than seeing
+ // what looks like a valid empty ArraryBuffer.
+ ArrayBufferVar* buffer_var = ArrayBufferVar::FromPPVar(var_);
+ if (buffer_var) {
+ // TODO(dmichael): If it wasn't already Mapped, Unmap it. (Though once
+ // we use shared memory, this will probably be
+ // completely different anyway).
+ m->WriteData(static_cast<const char*>(buffer_var->Map()),
+ buffer_var->ByteLength());
+ } else {
+ m->WriteData(NULL, 0);
+ }
break;
+ }
case PP_VARTYPE_OBJECT:
m->WriteInt64(var_.value.as_id);
break;
@@ -176,6 +192,16 @@ bool SerializedVar::Inner::ReadFromMessage(const IPC::Message* m, void** iter) {
var_ = StringVar::SwapValidatedUTF8StringIntoPPVar(&string_from_ipc);
break;
}
+ case PP_VARTYPE_ARRAY_BUFFER: {
+ int length = 0;
+ const char* message_bytes = NULL;
+ success = m->ReadData(iter, &message_bytes, &length);
+ if (success) {
+ var_ = PpapiGlobals::Get()->GetVarTracker()->MakeArrayBufferPPVar(
+ length, message_bytes);
+ }
+ break;
+ }
case PP_VARTYPE_OBJECT:
success = m->ReadInt64(iter, &var_.value.as_id);
break;
diff --git a/ppapi/shared_impl/var_tracker.cc b/ppapi/shared_impl/var_tracker.cc
index 0b70349..9e1abe8 100644
--- a/ppapi/shared_impl/var_tracker.cc
+++ b/ppapi/shared_impl/var_tracker.cc
@@ -4,6 +4,8 @@
#include "ppapi/shared_impl/var_tracker.h"
+#include <string.h>
+
#include <limits>
#include "base/logging.h"
@@ -164,6 +166,15 @@ PP_Var VarTracker::MakeArrayBufferPPVar(uint32 size_in_bytes) {
return array_buffer->GetPPVar();
}
+PP_Var VarTracker::MakeArrayBufferPPVar(uint32 size_in_bytes,
+ const void* data) {
+ scoped_refptr<ArrayBufferVar> array_buffer(CreateArrayBuffer(size_in_bytes));
+ if (!array_buffer)
+ return PP_MakeNull();
+ memcpy(array_buffer->Map(), data, size_in_bytes);
+ return array_buffer->GetPPVar();
+}
+
std::vector<PP_Var> VarTracker::GetLiveVars() {
std::vector<PP_Var> var_vector;
var_vector.reserve(live_vars_.size());
diff --git a/ppapi/shared_impl/var_tracker.h b/ppapi/shared_impl/var_tracker.h
index 52e38bd..575b710 100644
--- a/ppapi/shared_impl/var_tracker.h
+++ b/ppapi/shared_impl/var_tracker.h
@@ -61,6 +61,8 @@ class PPAPI_SHARED_EXPORT VarTracker {
// Create a new array buffer of size |size_in_bytes|. Return a PP_Var that
// that references it and has an initial reference-count of 1.
PP_Var MakeArrayBufferPPVar(uint32 size_in_bytes);
+ // Same as above, but copy the contents of |data| in to the new array buffer.
+ PP_Var MakeArrayBufferPPVar(uint32 size_in_bytes, const void* data);
// Return a vector containing all PP_Vars that are in the tracker. This is
// to help implement PPB_Testing_Dev.GetLiveVars and should generally not be
diff --git a/ppapi/thunk/interfaces_ppb_public_dev.h b/ppapi/thunk/interfaces_ppb_public_dev.h
index 43361399..cd48609 100644
--- a/ppapi/thunk/interfaces_ppb_public_dev.h
+++ b/ppapi/thunk/interfaces_ppb_public_dev.h
@@ -18,7 +18,6 @@ UNPROXIED_API(PPB_LayerCompositor)
UNPROXIED_API(PPB_Scrollbar)
PROXIED_API(PPB_TextInput)
UNPROXIED_API(PPB_Transport)
-UNPROXIED_API(PPB_VarArrayBuffer)
PROXIED_API(PPB_VideoCapture)
PROXIED_API(PPB_VideoDecoder)
UNPROXIED_API(PPB_WebSocket)
diff --git a/ppapi/thunk/interfaces_ppb_public_stable.h b/ppapi/thunk/interfaces_ppb_public_stable.h
index 6556cf4..5bf22de 100644
--- a/ppapi/thunk/interfaces_ppb_public_stable.h
+++ b/ppapi/thunk/interfaces_ppb_public_stable.h
@@ -74,7 +74,8 @@ PROXIED_IFACE(NoAPIName, PPB_URLREQUESTINFO_INTERFACE_1_0,
PPB_URLRequestInfo_1_0)
PROXIED_IFACE(PPB_URLResponseInfo, PPB_URLRESPONSEINFO_INTERFACE_1_0,
PPB_URLResponseInfo_1_0)
-// Note: PPB_Var is special and registered manually.
+
+// Note: PPB_Var and PPB_VarArrayBuffer are special and registered manually.
PROXIED_IFACE(NoAPIName, PPB_VIEW_INTERFACE_1_0, PPB_View_1_0)
#include "ppapi/thunk/interfaces_postamble.h"