summaryrefslogtreecommitdiffstats
path: root/webkit
diff options
context:
space:
mode:
authorbrettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-04-15 22:06:21 +0000
committerbrettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-04-15 22:06:21 +0000
commit1609d0d3a7d5b0f3777702308a440b22f1b42b59 (patch)
tree754be1a35ea8faa52a8dbb6a63264a2f686bea64 /webkit
parent54457f38c36e43d9f5d434e5bfc3cb83d9e56926 (diff)
downloadchromium_src-1609d0d3a7d5b0f3777702308a440b22f1b42b59.zip
chromium_src-1609d0d3a7d5b0f3777702308a440b22f1b42b59.tar.gz
chromium_src-1609d0d3a7d5b0f3777702308a440b22f1b42b59.tar.bz2
Support PPB_Flash_ModileLocal blocking calls from background threads. This is
a temporary stopgap to allow these specific functions to be used until the entire proxy can support threading. There are two functions that set up and clean up the routing information in the interface. These are necessary because the global dispatcher routing information is not threadsafe. When used from the main thread, the code works the same as before. When used from a background thread, we create a sync message, send it to the I/O thread, and block the sending thread until the reply is received. There is no handling of other incoming blocking messages (which are impossible), and no other Pepper functions are supported from the background thread. TEST=manual BUG=none Review URL: http://codereview.chromium.org/6875009 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@81814 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit')
-rw-r--r--webkit/plugins/ppapi/ppb_flash_file_impl.cc9
1 files changed, 9 insertions, 0 deletions
diff --git a/webkit/plugins/ppapi/ppb_flash_file_impl.cc b/webkit/plugins/ppapi/ppb_flash_file_impl.cc
index 48e4ab0..cf657a9 100644
--- a/webkit/plugins/ppapi/ppb_flash_file_impl.cc
+++ b/webkit/plugins/ppapi/ppb_flash_file_impl.cc
@@ -72,6 +72,13 @@ void FreeDirContents(PP_Instance instance, PP_DirContents_Dev* contents) {
namespace {
+bool CreateThreadAdapterForInstance(PP_Instance instance) {
+ return false; // No multithreaded access allowed.
+}
+
+void ClearThreadAdapterForInstance(PP_Instance instance) {
+}
+
int32_t OpenModuleLocalFile(PP_Instance pp_instance,
const char* path,
int32_t mode,
@@ -205,6 +212,8 @@ int32_t GetModuleLocalDirContents(PP_Instance pp_instance,
}
const PPB_Flash_File_ModuleLocal ppb_flash_file_modulelocal = {
+ &CreateThreadAdapterForInstance,
+ &ClearThreadAdapterForInstance,
&OpenModuleLocalFile,
&RenameModuleLocalFile,
&DeleteModuleLocalFileOrDir,