summaryrefslogtreecommitdiffstats
path: root/ppapi/proxy/serialized_var.h
diff options
context:
space:
mode:
authoryzshen@chromium.org <yzshen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-03-21 01:35:24 +0000
committeryzshen@chromium.org <yzshen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-03-21 01:35:24 +0000
commitcf9a53040381220f684457bf17c3ee7aa62a8a0d (patch)
tree8aff7d6ff611d75b3e7f820d3fcca73ad1fbbc18 /ppapi/proxy/serialized_var.h
parentf4a6d057fda1a466cef8a6e7112abc2cdf514d41 (diff)
downloadchromium_src-cf9a53040381220f684457bf17c3ee7aa62a8a0d.zip
chromium_src-cf9a53040381220f684457bf17c3ee7aa62a8a0d.tar.gz
chromium_src-cf9a53040381220f684457bf17c3ee7aa62a8a0d.tar.bz2
Avoid accessing VarTracker from multiple threads.
BUG=118223,118226 TEST=None Review URL: http://codereview.chromium.org/9786001 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@127871 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ppapi/proxy/serialized_var.h')
-rw-r--r--ppapi/proxy/serialized_var.h22
1 files changed, 21 insertions, 1 deletions
diff --git a/ppapi/proxy/serialized_var.h b/ppapi/proxy/serialized_var.h
index aec557d..3b74a3e 100644
--- a/ppapi/proxy/serialized_var.h
+++ b/ppapi/proxy/serialized_var.h
@@ -101,7 +101,7 @@ class PPAPI_PROXY_EXPORT SerializedVar {
}
// See outer class's declarations above.
- PP_Var GetVar() const;
+ PP_Var GetVar();
void SetVar(PP_Var var);
// For the SerializedVarTestConstructor, this writes the Var value as if
@@ -128,6 +128,21 @@ class PPAPI_PROXY_EXPORT SerializedVar {
END_RECEIVE_CALLER_OWNED
};
+ // ReadFromMessage() may be called on the I/O thread, e.g., when reading the
+ // reply to a sync message. We cannot use the var tracker on the I/O thread,
+ // which means we cannot create PP_Var for PP_VARTYPE_STRING and
+ // PP_VARTYPE_ARRAY_BUFFER in ReadFromMessage(). So we save the raw var data
+ // and create PP_Var later when GetVar() is called, which should happen on
+ // the main thread.
+ struct RawVarData {
+ PP_VarType type;
+ std::string data;
+ };
+
+ // Converts |raw_var_data_| to |var_|. It is a no-op if |raw_var_data_| is
+ // NULL.
+ void ConvertRawVarData();
+
// Rules for serializing and deserializing vars for this process type.
// This may be NULL, but must be set before trying to serialize to IPC when
// sending, or before converting back to a PP_Var when receiving.
@@ -152,6 +167,11 @@ class PPAPI_PROXY_EXPORT SerializedVar {
mutable bool has_been_deserialized_;
#endif
+ // It will be non-NULL if there is PP_VARTYPE_STRING or
+ // PP_VARTYPE_ARRAY_BUFFER data from ReadFromMessage() that hasn't been
+ // converted to PP_Var.
+ scoped_ptr<RawVarData> raw_var_data_;
+
DISALLOW_COPY_AND_ASSIGN(Inner);
};