OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "chromecast/browser/cast_browser_main_parts.h" | 5 #include "chromecast/browser/cast_browser_main_parts.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 #include <string.h> | 8 #include <string.h> |
9 | 9 |
10 #include <string> | 10 #include <string> |
(...skipping 22 matching lines...) Expand all Loading... | |
33 #include "chromecast/browser/cast_memory_pressure_monitor.h" | 33 #include "chromecast/browser/cast_memory_pressure_monitor.h" |
34 #include "chromecast/browser/cast_net_log.h" | 34 #include "chromecast/browser/cast_net_log.h" |
35 #include "chromecast/browser/devtools/remote_debugging_server.h" | 35 #include "chromecast/browser/devtools/remote_debugging_server.h" |
36 #include "chromecast/browser/geolocation/cast_access_token_store.h" | 36 #include "chromecast/browser/geolocation/cast_access_token_store.h" |
37 #include "chromecast/browser/media/media_caps_impl.h" | 37 #include "chromecast/browser/media/media_caps_impl.h" |
38 #include "chromecast/browser/metrics/cast_metrics_prefs.h" | 38 #include "chromecast/browser/metrics/cast_metrics_prefs.h" |
39 #include "chromecast/browser/metrics/cast_metrics_service_client.h" | 39 #include "chromecast/browser/metrics/cast_metrics_service_client.h" |
40 #include "chromecast/browser/pref_service_helper.h" | 40 #include "chromecast/browser/pref_service_helper.h" |
41 #include "chromecast/browser/url_request_context_factory.h" | 41 #include "chromecast/browser/url_request_context_factory.h" |
42 #include "chromecast/chromecast_features.h" | 42 #include "chromecast/chromecast_features.h" |
43 #include "chromecast/common/global_descriptors.h" | |
43 #include "chromecast/common/platform_client_auth.h" | 44 #include "chromecast/common/platform_client_auth.h" |
44 #include "chromecast/media/base/key_systems_common.h" | 45 #include "chromecast/media/base/key_systems_common.h" |
45 #include "chromecast/media/base/media_resource_tracker.h" | 46 #include "chromecast/media/base/media_resource_tracker.h" |
46 #include "chromecast/media/base/video_plane_controller.h" | 47 #include "chromecast/media/base/video_plane_controller.h" |
47 #include "chromecast/media/cma/backend/media_pipeline_backend_manager.h" | 48 #include "chromecast/media/cma/backend/media_pipeline_backend_manager.h" |
48 #include "chromecast/net/connectivity_checker.h" | 49 #include "chromecast/net/connectivity_checker.h" |
49 #include "chromecast/public/cast_media_shlib.h" | 50 #include "chromecast/public/cast_media_shlib.h" |
50 #include "chromecast/public/cast_sys_info.h" | 51 #include "chromecast/public/cast_sys_info.h" |
51 #include "chromecast/service/cast_service.h" | 52 #include "chromecast/service/cast_service.h" |
52 #include "components/prefs/pref_registry_simple.h" | 53 #include "components/prefs/pref_registry_simple.h" |
(...skipping 217 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
270 media_caps_(new media::MediaCapsImpl()) { | 271 media_caps_(new media::MediaCapsImpl()) { |
271 base::CommandLine* command_line = base::CommandLine::ForCurrentProcess(); | 272 base::CommandLine* command_line = base::CommandLine::ForCurrentProcess(); |
272 AddDefaultCommandLineSwitches(command_line); | 273 AddDefaultCommandLineSwitches(command_line); |
273 | 274 |
274 #if !defined(OS_ANDROID) | 275 #if !defined(OS_ANDROID) |
275 media_resource_tracker_ = nullptr; | 276 media_resource_tracker_ = nullptr; |
276 #endif // !defined(OS_ANDROID) | 277 #endif // !defined(OS_ANDROID) |
277 } | 278 } |
278 | 279 |
279 CastBrowserMainParts::~CastBrowserMainParts() { | 280 CastBrowserMainParts::~CastBrowserMainParts() { |
280 #if !defined(OS_ANDROID) | 281 #if defined(OS_ANDROID) |
282 breakpad::CrashDumpObserver::GetInstance()->UnregisterClient( | |
283 crash_dump_manager_); | |
284 #else | |
281 if (media_thread_ && media_pipeline_backend_manager_) { | 285 if (media_thread_ && media_pipeline_backend_manager_) { |
282 // Make sure that media_pipeline_backend_manager_ is destroyed after any | 286 // Make sure that media_pipeline_backend_manager_ is destroyed after any |
283 // pending media thread tasks. The CastAudioOutputStream implementation | 287 // pending media thread tasks. The CastAudioOutputStream implementation |
284 // calls into media_pipeline_backend_manager_ when the stream is closed; | 288 // calls into media_pipeline_backend_manager_ when the stream is closed; |
285 // therefore, we must be sure that all CastAudioOutputStreams are gone | 289 // therefore, we must be sure that all CastAudioOutputStreams are gone |
286 // before destroying media_pipeline_backend_manager_. This is guaranteed | 290 // before destroying media_pipeline_backend_manager_. This is guaranteed |
287 // once the AudioManager is destroyed; the AudioManager destruction is | 291 // once the AudioManager is destroyed; the AudioManager destruction is |
288 // posted to the media thread in the BrowserMainLoop destructor, just before | 292 // posted to the media thread in the BrowserMainLoop destructor, just before |
289 // the BrowserMainParts are destroyed (ie, here). Therefore, if we delete | 293 // the BrowserMainParts are destroyed (ie, here). Therefore, if we delete |
290 // the media_pipeline_backend_manager_ using DeleteSoon on the media thread, | 294 // the media_pipeline_backend_manager_ using DeleteSoon on the media thread, |
291 // it is guaranteed that the AudioManager and all AudioOutputStreams have | 295 // it is guaranteed that the AudioManager and all AudioOutputStreams have |
292 // been destroyed before media_pipeline_backend_manager_ is destroyed. | 296 // been destroyed before media_pipeline_backend_manager_ is destroyed. |
293 media_thread_->task_runner()->DeleteSoon( | 297 media_thread_->task_runner()->DeleteSoon( |
294 FROM_HERE, media_pipeline_backend_manager_.release()); | 298 FROM_HERE, media_pipeline_backend_manager_.release()); |
295 } | 299 } |
296 #endif // !defined(OS_ANDROID) | 300 #endif // defined(OS_ANDROID) |
297 } | 301 } |
298 | 302 |
299 scoped_refptr<base::SingleThreadTaskRunner> | 303 scoped_refptr<base::SingleThreadTaskRunner> |
300 CastBrowserMainParts::GetMediaTaskRunner() { | 304 CastBrowserMainParts::GetMediaTaskRunner() { |
301 #if defined(OS_ANDROID) | 305 #if defined(OS_ANDROID) |
302 return nullptr; | 306 return nullptr; |
303 #else | 307 #else |
304 if (!media_thread_) { | 308 if (!media_thread_) { |
305 media_thread_.reset(new base::Thread("CastMediaThread")); | 309 media_thread_.reset(new base::Thread("CastMediaThread")); |
306 base::Thread::Options options; | 310 base::Thread::Options options; |
(...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
379 } | 383 } |
380 | 384 |
381 int CastBrowserMainParts::PreCreateThreads() { | 385 int CastBrowserMainParts::PreCreateThreads() { |
382 #if defined(OS_ANDROID) | 386 #if defined(OS_ANDROID) |
383 // GPU process is started immediately after threads are created, requiring | 387 // GPU process is started immediately after threads are created, requiring |
384 // CrashDumpManager to be initialized beforehand. | 388 // CrashDumpManager to be initialized beforehand. |
385 base::FilePath crash_dumps_dir; | 389 base::FilePath crash_dumps_dir; |
386 if (!chromecast::CrashHandler::GetCrashDumpLocation(&crash_dumps_dir)) { | 390 if (!chromecast::CrashHandler::GetCrashDumpLocation(&crash_dumps_dir)) { |
387 LOG(ERROR) << "Could not find crash dump location."; | 391 LOG(ERROR) << "Could not find crash dump location."; |
388 } | 392 } |
389 cast_browser_process_->SetCrashDumpManager( | 393 breakpad::CrashDumpObserver::Create(); |
390 base::MakeUnique<breakpad::CrashDumpManager>(crash_dumps_dir)); | 394 breakpad::CrashDumpObserver::GetInstance()->RegisterClient( |
395 crash_dump_manager_ = new breakpad::CrashDumpManager( | |
boliu
2016/10/13 21:07:18
ditto
Tobias Sargeant
2016/12/08 16:41:41
Done.
| |
396 crash_dumps_dir, kAndroidMinidumpDescriptor)); | |
391 #else | 397 #else |
392 base::FilePath home_dir; | 398 base::FilePath home_dir; |
393 CHECK(PathService::Get(DIR_CAST_HOME, &home_dir)); | 399 CHECK(PathService::Get(DIR_CAST_HOME, &home_dir)); |
394 if (!base::CreateDirectory(home_dir)) | 400 if (!base::CreateDirectory(home_dir)) |
395 return 1; | 401 return 1; |
396 | 402 |
397 // Hook for internal code | 403 // Hook for internal code |
398 cast_browser_process_->browser_client()->PreCreateThreads(); | 404 cast_browser_process_->browser_client()->PreCreateThreads(); |
399 | 405 |
400 // Set GL strings so GPU config code can make correct feature blacklisting/ | 406 // Set GL strings so GPU config code can make correct feature blacklisting/ |
(...skipping 136 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
537 | 543 |
538 void CastBrowserMainParts::PostDestroyThreads() { | 544 void CastBrowserMainParts::PostDestroyThreads() { |
539 #if !defined(OS_ANDROID) | 545 #if !defined(OS_ANDROID) |
540 media_resource_tracker_->FinalizeAndDestroy(); | 546 media_resource_tracker_->FinalizeAndDestroy(); |
541 media_resource_tracker_ = nullptr; | 547 media_resource_tracker_ = nullptr; |
542 #endif | 548 #endif |
543 } | 549 } |
544 | 550 |
545 } // namespace shell | 551 } // namespace shell |
546 } // namespace chromecast | 552 } // namespace chromecast |
OLD | NEW |