Chromium Code Reviews| 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/browser/browser_main_loop.h" | 5 #include "content/browser/browser_main_loop.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 | 8 |
| 9 #include <utility> | 9 #include <utility> |
| 10 | 10 |
| (...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 68 #include "content/common/mojo/mojo_shell_connection_impl.h" | 68 #include "content/common/mojo/mojo_shell_connection_impl.h" |
| 69 #include "content/public/browser/browser_main_parts.h" | 69 #include "content/public/browser/browser_main_parts.h" |
| 70 #include "content/public/browser/content_browser_client.h" | 70 #include "content/public/browser/content_browser_client.h" |
| 71 #include "content/public/browser/render_process_host.h" | 71 #include "content/public/browser/render_process_host.h" |
| 72 #include "content/public/browser/tracing_controller.h" | 72 #include "content/public/browser/tracing_controller.h" |
| 73 #include "content/public/common/content_switches.h" | 73 #include "content/public/common/content_switches.h" |
| 74 #include "content/public/common/main_function_params.h" | 74 #include "content/public/common/main_function_params.h" |
| 75 #include "content/public/common/result_codes.h" | 75 #include "content/public/common/result_codes.h" |
| 76 #include "device/battery/battery_status_service.h" | 76 #include "device/battery/battery_status_service.h" |
| 77 #include "ipc/mojo/scoped_ipc_support.h" | 77 #include "ipc/mojo/scoped_ipc_support.h" |
| 78 #include "media/audio/audio_manager.h" | |
| 79 #include "media/base/media.h" | 78 #include "media/base/media.h" |
| 80 #include "media/base/user_input_monitor.h" | 79 #include "media/base/user_input_monitor.h" |
| 81 #include "media/midi/midi_manager.h" | 80 #include "media/midi/midi_manager.h" |
| 82 #include "mojo/edk/embedder/embedder.h" | 81 #include "mojo/edk/embedder/embedder.h" |
| 83 #include "mojo/shell/public/cpp/shell.h" | 82 #include "mojo/shell/public/cpp/shell.h" |
| 84 #include "net/base/network_change_notifier.h" | 83 #include "net/base/network_change_notifier.h" |
| 85 #include "net/socket/client_socket_factory.h" | 84 #include "net/socket/client_socket_factory.h" |
| 86 #include "net/ssl/ssl_config_service.h" | 85 #include "net/ssl/ssl_config_service.h" |
| 87 #include "skia/ext/event_tracer_impl.h" | 86 #include "skia/ext/event_tracer_impl.h" |
| 88 #include "skia/ext/skia_memory_dump_provider.h" | 87 #include "skia/ext/skia_memory_dump_provider.h" |
| (...skipping 1132 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1221 BrowserGpuMemoryBufferManager::current(), "BrowserGpuMemoryBufferManager", | 1220 BrowserGpuMemoryBufferManager::current(), "BrowserGpuMemoryBufferManager", |
| 1222 io_thread_->task_runner()); | 1221 io_thread_->task_runner()); |
| 1223 #if defined(OS_ANDROID) | 1222 #if defined(OS_ANDROID) |
| 1224 base::trace_event::MemoryDumpManager::GetInstance()->RegisterDumpProvider( | 1223 base::trace_event::MemoryDumpManager::GetInstance()->RegisterDumpProvider( |
| 1225 tracing::GraphicsMemoryDumpProvider::GetInstance(), "AndroidGraphics", | 1224 tracing::GraphicsMemoryDumpProvider::GetInstance(), "AndroidGraphics", |
| 1226 nullptr); | 1225 nullptr); |
| 1227 #endif | 1226 #endif |
| 1228 | 1227 |
| 1229 { | 1228 { |
| 1230 TRACE_EVENT0("startup", "BrowserThreadsStarted::Subsystem:AudioMan"); | 1229 TRACE_EVENT0("startup", "BrowserThreadsStarted::Subsystem:AudioMan"); |
| 1231 audio_manager_.reset(media::AudioManager::CreateWithHangTimer( | 1230 // TODO(alokp): Allow content embedders to override the default |
|
tommi (sloooow) - chröme
2016/04/13 07:31:51
nit: in order to keep the size of BrowserThreadsSt
alokp
2016/04/17 16:55:19
Done.
| |
| 1232 MediaInternals::GetInstance(), io_thread_->task_runner())); | 1231 // task runners by defining ContentBrowserClient::GetAudioTaskRunner. |
| 1232 scoped_refptr<base::SingleThreadTaskRunner> audio_task_runner; | |
| 1233 scoped_refptr<base::SingleThreadTaskRunner> worker_task_runner; | |
| 1234 scoped_refptr<base::SingleThreadTaskRunner> monitor_task_runner; | |
| 1235 audio_thread_.reset(new base::Thread("AudioThread")); | |
| 1236 #if defined(OS_WIN) | |
| 1237 audio_thread_->init_com_with_mta(true); | |
| 1238 #endif // defined(OS_WIN) | |
| 1239 CHECK(audio_thread_->Start()); | |
| 1240 #if defined(OS_MACOSX) | |
| 1241 // On Mac audio task runner must belong to the main thread. | |
| 1242 // See http://crbug.com/158170. | |
| 1243 // Since the audio thread is the UI thread, a hang monitor is not | |
| 1244 // necessary or recommended. | |
| 1245 audio_task_runner = base::ThreadTaskRunnerHandle::Get(); | |
| 1246 worker_task_runner = audio_thread_->task_runner(); | |
| 1247 #else | |
| 1248 audio_task_runner = audio_thread_->task_runner(); | |
| 1249 worker_task_runner = audio_thread_->task_runner(); | |
| 1250 monitor_task_runner = io_thread_->task_runner(); | |
| 1251 #endif // defined(OS_MACOSX) | |
| 1252 audio_manager_ = media::AudioManager::Create( | |
| 1253 std::move(audio_task_runner), std::move(worker_task_runner), | |
| 1254 std::move(monitor_task_runner), MediaInternals::GetInstance()); | |
| 1233 } | 1255 } |
| 1234 | 1256 |
| 1235 { | 1257 { |
| 1236 TRACE_EVENT0("startup", "BrowserThreadsStarted::Subsystem:MidiManager"); | 1258 TRACE_EVENT0("startup", "BrowserThreadsStarted::Subsystem:MidiManager"); |
| 1237 midi_manager_.reset(media::midi::MidiManager::Create()); | 1259 midi_manager_.reset(media::midi::MidiManager::Create()); |
| 1238 } | 1260 } |
| 1239 | 1261 |
| 1240 #if defined(OS_WIN) | 1262 #if defined(OS_WIN) |
| 1241 system_message_window_.reset(new media::SystemMessageWindowWin); | 1263 system_message_window_.reset(new media::SystemMessageWindowWin); |
| 1242 #elif defined(OS_LINUX) && defined(USE_UDEV) | 1264 #elif defined(OS_LINUX) && defined(USE_UDEV) |
| (...skipping 208 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1451 DCHECK(is_tracing_startup_for_duration_); | 1473 DCHECK(is_tracing_startup_for_duration_); |
| 1452 | 1474 |
| 1453 is_tracing_startup_for_duration_ = false; | 1475 is_tracing_startup_for_duration_ = false; |
| 1454 TracingController::GetInstance()->StopTracing( | 1476 TracingController::GetInstance()->StopTracing( |
| 1455 TracingController::CreateFileSink( | 1477 TracingController::CreateFileSink( |
| 1456 startup_trace_file_, | 1478 startup_trace_file_, |
| 1457 base::Bind(OnStoppedStartupTracing, startup_trace_file_))); | 1479 base::Bind(OnStoppedStartupTracing, startup_trace_file_))); |
| 1458 } | 1480 } |
| 1459 | 1481 |
| 1460 } // namespace content | 1482 } // namespace content |
| OLD | NEW |