| Index: chrome/nacl/nacl_exe_win_64.cc
|
| ===================================================================
|
| --- chrome/nacl/nacl_exe_win_64.cc (revision 0)
|
| +++ chrome/nacl/nacl_exe_win_64.cc (revision 0)
|
| @@ -0,0 +1,105 @@
|
| +// Copyright (c) 2011 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 "base/at_exit.h"
|
| +#include "base/command_line.h"
|
| +#include "base/logging.h"
|
| +#include "base/message_loop.h"
|
| +#include "base/process_util.h"
|
| +#include "base/string_util.h"
|
| +#include "base/system_monitor/system_monitor.h"
|
| +#include "chrome/app/breakpad_win.h"
|
| +#include "chrome/common/chrome_result_codes.h"
|
| +#include "chrome/common/chrome_switches.h"
|
| +#include "chrome/common/logging_chrome.h"
|
| +#include "chrome/nacl/nacl_broker_listener.h"
|
| +#include "chrome/nacl/nacl_listener.h"
|
| +#include "chrome/nacl/nacl_main_platform_delegate.h"
|
| +#include "content/app/startup_helper_win.h"
|
| +#include "content/common/hi_res_timer_manager.h"
|
| +#include "content/common/main_function_params.h"
|
| +#include "content/common/sandbox_init_wrapper.h"
|
| +#include "content/common/sandbox_policy.h"
|
| +#include "sandbox/src/sandbox.h"
|
| +#include "sandbox/src/sandbox_types.h"
|
| +
|
| +extern int NaClMain(const MainFunctionParams&);
|
| +
|
| +// main() routine for the NaCl broker process.
|
| +// This is necessary for supporting NaCl in Chrome on Win64.
|
| +int NaClBrokerMain(const MainFunctionParams& parameters) {
|
| + const CommandLine& parsed_command_line = parameters.command_line_;
|
| +
|
| + MessageLoopForIO main_message_loop;
|
| + base::PlatformThread::SetName("CrNaClBrokerMain");
|
| +
|
| + base::SystemMonitor system_monitor;
|
| + HighResolutionTimerManager hi_res_timer_manager;
|
| +
|
| + // 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();
|
| + }
|
| + }
|
| +
|
| + NaClBrokerListener listener;
|
| + listener.Listen();
|
| +
|
| + return 0;
|
| +}
|
| +
|
| +int APIENTRY wWinMain(HINSTANCE instance, HINSTANCE, wchar_t*, int) {
|
| + sandbox::SandboxInterfaceInfo sandbox_info = {0};
|
| + content::InitializeSandboxInfo(&sandbox_info);
|
| +
|
| + base::AtExitManager exit_manager;
|
| + CommandLine::Init(0, NULL);
|
| +
|
| + wchar_t path[MAX_PATH];
|
| + ::GetModuleFileNameW(NULL, path, MAX_PATH);
|
| + InitCrashReporterWithDllPath(std::wstring(path));
|
| +
|
| + const CommandLine& command_line = *CommandLine::ForCurrentProcess();
|
| + std::string process_type =
|
| + command_line.GetSwitchValueASCII(switches::kProcessType);
|
| +
|
| + // Copy what ContentMain() does.
|
| + base::EnableTerminationOnHeapCorruption();
|
| + base::EnableTerminationOnOutOfMemory();
|
| + content::RegisterInvalidParamHandler();
|
| + content::SetupCRT(command_line);
|
| +
|
| + // Initialize the sandbox for this process.
|
| + SandboxInitWrapper sandbox_wrapper;
|
| + sandbox_wrapper.SetServices(&sandbox_info);
|
| + bool sandbox_initialized_ok =
|
| + sandbox_wrapper.InitializeSandbox(command_line, process_type);
|
| + // Die if the sandbox can't be enabled.
|
| + CHECK(sandbox_initialized_ok) << "Error initializing sandbox for "
|
| + << process_type;
|
| + MainFunctionParams main_params(command_line, sandbox_wrapper, NULL);
|
| +
|
| + if (process_type == switches::kNaClLoaderProcess)
|
| + return NaClMain(main_params);
|
| +
|
| + if (process_type == switches::kNaClBrokerProcess)
|
| + return NaClBrokerMain(main_params);
|
| +
|
| + CHECK(false) << "Unknown NaCl 64 process.";
|
| + return -1;
|
| +}
|
|
|
| Property changes on: chrome\nacl\nacl_exe_win_64.cc
|
| ___________________________________________________________________
|
| Added: svn:eol-style
|
| + LF
|
|
|
|
|