// Copyright 2014 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 "ppapi/nacl_irt/plugin_main.h" #include "build/build_config.h" // Need to include this before most other files because it defines // IPC_MESSAGE_LOG_ENABLED. We need to use it to define // IPC_MESSAGE_MACROS_LOG_ENABLED so ppapi_messages.h will generate the // ViewMsgLog et al. functions. #include "base/message_loop/message_loop.h" #include "base/threading/thread.h" #include "ipc/ipc_logging.h" #include "ppapi/nacl_irt/plugin_startup.h" #include "ppapi/nacl_irt/ppapi_dispatcher.h" #include "ppapi/proxy/plugin_globals.h" #include "ppapi/shared_impl/ppb_audio_shared.h" #if defined(__native_client__) #include "native_client/src/shared/srpc/nacl_srpc.h" #endif void PpapiPluginRegisterThreadCreator( const struct PP_ThreadFunctions* thread_functions) { // Initialize all classes that need to create threads that call back into // user code. ppapi::PPB_Audio_Shared::SetThreadFunctions(thread_functions); } int PpapiPluginMain() { base::MessageLoop loop; ppapi::proxy::PluginGlobals plugin_globals; #if defined(__native_client__) // Currently on non-SFI mode, we don't use SRPC server on plugin. // TODO(hidehiko): Make sure this SRPC is actually used on SFI-mode. // Start up the SRPC server on another thread. Otherwise, when it blocks // on an RPC, the PPAPI proxy will hang. Do this before we initialize the // module and start the PPAPI proxy so that the NaCl plugin can continue // loading the app. static struct NaClSrpcHandlerDesc srpc_methods[] = { { NULL, NULL } }; if (!NaClSrpcAcceptClientOnThread(srpc_methods)) { return 1; } #endif ppapi::PpapiDispatcher ppapi_dispatcher( ppapi::GetIOThread()->message_loop_proxy(), ppapi::GetShutdownEvent(), ppapi::GetBrowserIPCFileDescriptor(), ppapi::GetRendererIPCFileDescriptor()); plugin_globals.set_plugin_proxy_delegate(&ppapi_dispatcher); loop.Run(); return 0; }