diff options
Diffstat (limited to 'content/worker/worker_main.cc')
-rw-r--r-- | content/worker/worker_main.cc | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/content/worker/worker_main.cc b/content/worker/worker_main.cc new file mode 100644 index 0000000..6ec0263 --- /dev/null +++ b/content/worker/worker_main.cc @@ -0,0 +1,55 @@ +// 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/base_switches.h" +#include "base/command_line.h" +#include "base/message_loop.h" +#include "base/string_util.h" +#include "base/threading/platform_thread.h" +#include "content/common/child_process.h" +#include "content/common/hi_res_timer_manager.h" +#include "content/common/main_function_params.h" +#include "content/worker/worker_thread.h" +#include "ui/base/system_monitor/system_monitor.h" + +#if defined(OS_WIN) +#include "content/common/sandbox_init_wrapper.h" +#include "sandbox/src/sandbox.h" +#endif + +// Mainline routine for running as the worker process. +int WorkerMain(const MainFunctionParams& parameters) { + // The main message loop of the worker process. + MessageLoop main_message_loop; + base::PlatformThread::SetName("CrWorkerMain"); + + ui::SystemMonitor system_monitor; + HighResolutionTimerManager hi_res_timer_manager; + + ChildProcess worker_process; + worker_process.set_main_thread(new WorkerThread()); +#if defined(OS_WIN) + sandbox::TargetServices* target_services = + parameters.sandbox_info_.TargetServices(); + if (!target_services) + return false; + + // Cause advapi32 to load before the sandbox is turned on. + unsigned int dummy_rand; + rand_s(&dummy_rand); + + target_services->LowerToken(); +#endif + + const CommandLine& parsed_command_line = parameters.command_line_; + if (parsed_command_line.HasSwitch(switches::kWaitForDebugger)) { + ChildProcess::WaitForDebugger("Worker"); + } + + // Load the accelerator table from the browser executable and tell the + // message loop to use it when translating messages. + MessageLoop::current()->Run(); + + return 0; +} |