OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "content/public/browser/browser_main_runner.h" | 5 #include "content/public/browser/browser_main_runner.h" |
6 | 6 |
7 #include "base/base_switches.h" | 7 #include "base/base_switches.h" |
8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
9 #include "base/debug/leak_annotations.h" | 9 #include "base/debug/leak_annotations.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
11 #include "base/metrics/histogram.h" | 11 #include "base/metrics/histogram.h" |
12 #include "base/metrics/statistics_recorder.h" | 12 #include "base/metrics/statistics_recorder.h" |
13 #include "base/profiler/scoped_profile.h" | 13 #include "base/profiler/scoped_profile.h" |
14 #include "base/profiler/scoped_tracker.h" | 14 #include "base/profiler/scoped_tracker.h" |
15 #include "base/trace_event/trace_event.h" | 15 #include "base/trace_event/trace_event.h" |
16 #include "base/tracked_objects.h" | 16 #include "base/tracked_objects.h" |
17 #include "components/tracing/trace_config_file.h" | |
18 #include "components/tracing/tracing_switches.h" | 17 #include "components/tracing/tracing_switches.h" |
19 #include "content/browser/browser_main_loop.h" | 18 #include "content/browser/browser_main_loop.h" |
20 #include "content/browser/browser_shutdown_profile_dumper.h" | 19 #include "content/browser/browser_shutdown_profile_dumper.h" |
21 #include "content/browser/notification_service_impl.h" | 20 #include "content/browser/notification_service_impl.h" |
22 #include "content/public/browser/tracing_controller.h" | |
23 #include "content/public/common/content_switches.h" | 21 #include "content/public/common/content_switches.h" |
24 #include "content/public/common/main_function_params.h" | 22 #include "content/public/common/main_function_params.h" |
25 #include "ui/base/ime/input_method_initializer.h" | 23 #include "ui/base/ime/input_method_initializer.h" |
26 | 24 |
27 #if defined(OS_ANDROID) | |
28 #include "content/browser/android/tracing_controller_android.h" | |
29 #endif | |
30 | |
31 #if defined(OS_WIN) | 25 #if defined(OS_WIN) |
32 #include "base/win/win_util.h" | 26 #include "base/win/win_util.h" |
33 #include "base/win/windows_version.h" | 27 #include "base/win/windows_version.h" |
34 #include "net/cert/sha256_legacy_support_win.h" | 28 #include "net/cert/sha256_legacy_support_win.h" |
35 #include "sandbox/win/src/sidestep/preamble_patcher.h" | 29 #include "sandbox/win/src/sidestep/preamble_patcher.h" |
36 #include "ui/base/win/scoped_ole_initializer.h" | 30 #include "ui/base/win/scoped_ole_initializer.h" |
37 #include "ui/gfx/switches.h" | 31 #include "ui/gfx/switches.h" |
38 #include "ui/gfx/win/direct_write.h" | 32 #include "ui/gfx/win/direct_write.h" |
39 #endif | 33 #endif |
40 | 34 |
(...skipping 187 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
228 // Invoke leak detection now, to avoid dealing with shutdown-only leaks. | 222 // Invoke leak detection now, to avoid dealing with shutdown-only leaks. |
229 // Normally this will have already happened in | 223 // Normally this will have already happened in |
230 // BroserProcessImpl::ReleaseModule(), so this call has no effect. This is | 224 // BroserProcessImpl::ReleaseModule(), so this call has no effect. This is |
231 // only for processes which do not instantiate a BrowserProcess. | 225 // only for processes which do not instantiate a BrowserProcess. |
232 // If leaks are found, the process will exit here. | 226 // If leaks are found, the process will exit here. |
233 __lsan_do_leak_check(); | 227 __lsan_do_leak_check(); |
234 #endif | 228 #endif |
235 // If startup tracing has not been finished yet, replace it's dumper | 229 // If startup tracing has not been finished yet, replace it's dumper |
236 // with special version, which would save trace file on exit (i.e. | 230 // with special version, which would save trace file on exit (i.e. |
237 // startup tracing becomes a version of shutdown tracing). | 231 // startup tracing becomes a version of shutdown tracing). |
238 // There are two cases: | |
239 // 1. Startup duration is not reached. | |
240 // 2. Or startup duration is not specified for --trace-config-file flag. | |
241 scoped_ptr<BrowserShutdownProfileDumper> startup_profiler; | 232 scoped_ptr<BrowserShutdownProfileDumper> startup_profiler; |
242 if (main_loop_->is_tracing_startup_for_duration()) { | 233 if (main_loop_->is_tracing_startup()) { |
243 main_loop_->StopStartupTracingTimer(); | 234 main_loop_->StopStartupTracingTimer(); |
244 if (main_loop_->startup_trace_file() != | 235 if (main_loop_->startup_trace_file() != |
245 base::FilePath().AppendASCII("none")) { | 236 base::FilePath().AppendASCII("none")) { |
246 startup_profiler.reset( | 237 startup_profiler.reset( |
247 new BrowserShutdownProfileDumper(main_loop_->startup_trace_file())); | 238 new BrowserShutdownProfileDumper(main_loop_->startup_trace_file())); |
248 } | 239 } |
249 } else if (tracing::TraceConfigFile::GetInstance()->IsEnabled() && | |
250 TracingController::GetInstance()->IsRecording()) { | |
251 base::FilePath result_file; | |
252 #if defined(OS_ANDROID) | |
253 TracingControllerAndroid::GenerateTracingFilePath(&result_file); | |
254 #else | |
255 result_file = tracing::TraceConfigFile::GetInstance()->GetResultFile(); | |
256 #endif | |
257 startup_profiler.reset(new BrowserShutdownProfileDumper(result_file)); | |
258 } | 240 } |
259 | 241 |
260 // The shutdown tracing got enabled in AttemptUserExit earlier, but someone | 242 // The shutdown tracing got enabled in AttemptUserExit earlier, but someone |
261 // needs to write the result to disc. For that a dumper needs to get created | 243 // needs to write the result to disc. For that a dumper needs to get created |
262 // which will dump the traces to disc when it gets destroyed. | 244 // which will dump the traces to disc when it gets destroyed. |
263 const base::CommandLine& command_line = | 245 const base::CommandLine& command_line = |
264 *base::CommandLine::ForCurrentProcess(); | 246 *base::CommandLine::ForCurrentProcess(); |
265 scoped_ptr<BrowserShutdownProfileDumper> shutdown_profiler; | 247 scoped_ptr<BrowserShutdownProfileDumper> shutdown_profiler; |
266 if (command_line.HasSwitch(switches::kTraceShutdown)) { | 248 if (command_line.HasSwitch(switches::kTraceShutdown)) { |
267 shutdown_profiler.reset(new BrowserShutdownProfileDumper( | 249 shutdown_profiler.reset(new BrowserShutdownProfileDumper( |
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
309 | 291 |
310 DISALLOW_COPY_AND_ASSIGN(BrowserMainRunnerImpl); | 292 DISALLOW_COPY_AND_ASSIGN(BrowserMainRunnerImpl); |
311 }; | 293 }; |
312 | 294 |
313 // static | 295 // static |
314 BrowserMainRunner* BrowserMainRunner::Create() { | 296 BrowserMainRunner* BrowserMainRunner::Create() { |
315 return new BrowserMainRunnerImpl(); | 297 return new BrowserMainRunnerImpl(); |
316 } | 298 } |
317 | 299 |
318 } // namespace content | 300 } // namespace content |
OLD | NEW |