Index: chrome/nacl/nacl_main.cc |
=================================================================== |
--- chrome/nacl/nacl_main.cc (revision 100721) |
+++ chrome/nacl/nacl_main.cc (working copy) |
@@ -4,89 +4,28 @@ |
#include "build/build_config.h" |
-#if defined(OS_WIN) |
-#include <windows.h> |
-#endif |
- |
#include "base/command_line.h" |
#include "base/message_loop.h" |
-#include "base/string_util.h" |
#include "base/system_monitor/system_monitor.h" |
-#include "chrome/common/chrome_constants.h" |
#include "chrome/common/chrome_result_codes.h" |
#include "chrome/common/chrome_switches.h" |
#include "chrome/common/logging_chrome.h" |
#include "chrome/nacl/nacl_listener.h" |
#include "chrome/nacl/nacl_main_platform_delegate.h" |
#include "content/common/child_process.h" |
-#include "content/common/child_process_info.h" |
#include "content/common/hi_res_timer_manager.h" |
#include "content/common/main_function_params.h" |
-#include "content/common/sandbox_policy.h" |
-#include "ipc/ipc_switches.h" |
-#if defined(OS_WIN) |
-#include "chrome/nacl/broker_thread.h" |
-#include "sandbox/src/sandbox.h" |
-#endif |
- |
-#ifdef _WIN64 |
- |
-// main() routine for the NaCl broker process. |
-// This is necessary for supporting NaCl in Chrome on Win64. |
-int NaClBrokerMain(const MainFunctionParams& parameters) { |
- // The main thread of the broker. |
- MessageLoopForIO main_message_loop; |
- base::PlatformThread::SetName("CrNaClBrokerMain"); |
- |
- base::SystemMonitor system_monitor; |
- HighResolutionTimerManager hi_res_timer_manager; |
- |
- const CommandLine& parsed_command_line = parameters.command_line_; |
- |
- DVLOG(1) << "Started NaCL broker with " |
- << parsed_command_line.GetCommandLineString(); |
- |
- // NOTE: this code is duplicated from browser_main.cc |
- // IMPORTANT: This piece of code needs to run as early as possible in the |
- // process because it will initialize the sandbox broker, which requires the |
- // process to swap its window station. During this time all the UI will be |
- // broken. This has to run before threads and windows are created. |
- sandbox::BrokerServices* broker_services = |
- parameters.sandbox_info_.BrokerServices(); |
- if (broker_services) { |
- sandbox::InitBrokerServices(broker_services); |
- if (!parsed_command_line.HasSwitch(switches::kNoSandbox)) { |
- bool use_winsta = !parsed_command_line.HasSwitch( |
- switches::kDisableAltWinstation); |
- // Precreate the desktop and window station used by the renderers. |
- sandbox::TargetPolicy* policy = broker_services->CreatePolicy(); |
- sandbox::ResultCode result = policy->CreateAlternateDesktop(use_winsta); |
- CHECK(sandbox::SBOX_ERROR_FAILED_TO_SWITCH_BACK_WINSTATION != result); |
- policy->Release(); |
- } |
- } |
- |
- { |
- ChildProcess broker_process; |
- broker_process.set_main_thread(new NaClBrokerThread()); |
- MessageLoop::current()->Run(); |
- } |
- |
- return 0; |
-} |
-#else |
-int NaClBrokerMain(const MainFunctionParams& parameters) { |
- return chrome::RESULT_CODE_BAD_PROCESS_TYPE; |
-} |
-#endif // _WIN64 |
- |
// This function provides some ways to test crash and assertion handling |
// behavior of the renderer. |
static void HandleNaClTestParameters(const CommandLine& command_line) { |
+// The message box doesn't work in the 64 bit binaries anyways, so no need to |
+// link to it since the 64 bit binary doesn't link with chrome or content. |
+#if !defined(NACL_WIN64) |
if (command_line.HasSwitch(switches::kNaClStartupDialog)) { |
ChildProcess::WaitForDebugger("NativeClient"); |
} |
+#endif |
} |
// main() routine for the NaCl loader process. |