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 221 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
274 media_caps_(new media::MediaCapsImpl()) { | 275 media_caps_(new media::MediaCapsImpl()) { |
275 base::CommandLine* command_line = base::CommandLine::ForCurrentProcess(); | 276 base::CommandLine* command_line = base::CommandLine::ForCurrentProcess(); |
276 AddDefaultCommandLineSwitches(command_line); | 277 AddDefaultCommandLineSwitches(command_line); |
277 | 278 |
278 #if !defined(OS_ANDROID) | 279 #if !defined(OS_ANDROID) |
279 media_resource_tracker_ = nullptr; | 280 media_resource_tracker_ = nullptr; |
280 #endif // !defined(OS_ANDROID) | 281 #endif // !defined(OS_ANDROID) |
281 } | 282 } |
282 | 283 |
283 CastBrowserMainParts::~CastBrowserMainParts() { | 284 CastBrowserMainParts::~CastBrowserMainParts() { |
284 #if !defined(OS_ANDROID) | 285 #if defined(OS_ANDROID) |
| 286 breakpad::CrashDumpObserver::GetInstance()->UnregisterClient( |
| 287 crash_dump_manager_); |
| 288 #else |
285 if (media_thread_ && media_pipeline_backend_manager_) { | 289 if (media_thread_ && media_pipeline_backend_manager_) { |
286 // Make sure that media_pipeline_backend_manager_ is destroyed after any | 290 // Make sure that media_pipeline_backend_manager_ is destroyed after any |
287 // pending media thread tasks. The CastAudioOutputStream implementation | 291 // pending media thread tasks. The CastAudioOutputStream implementation |
288 // calls into media_pipeline_backend_manager_ when the stream is closed; | 292 // calls into media_pipeline_backend_manager_ when the stream is closed; |
289 // therefore, we must be sure that all CastAudioOutputStreams are gone | 293 // therefore, we must be sure that all CastAudioOutputStreams are gone |
290 // before destroying media_pipeline_backend_manager_. This is guaranteed | 294 // before destroying media_pipeline_backend_manager_. This is guaranteed |
291 // once the AudioManager is destroyed; the AudioManager destruction is | 295 // once the AudioManager is destroyed; the AudioManager destruction is |
292 // posted to the media thread in the BrowserMainLoop destructor, just before | 296 // posted to the media thread in the BrowserMainLoop destructor, just before |
293 // the BrowserMainParts are destroyed (ie, here). Therefore, if we delete | 297 // the BrowserMainParts are destroyed (ie, here). Therefore, if we delete |
294 // the media_pipeline_backend_manager_ using DeleteSoon on the media thread, | 298 // the media_pipeline_backend_manager_ using DeleteSoon on the media thread, |
295 // it is guaranteed that the AudioManager and all AudioOutputStreams have | 299 // it is guaranteed that the AudioManager and all AudioOutputStreams have |
296 // been destroyed before media_pipeline_backend_manager_ is destroyed. | 300 // been destroyed before media_pipeline_backend_manager_ is destroyed. |
297 media_thread_->task_runner()->DeleteSoon( | 301 media_thread_->task_runner()->DeleteSoon( |
298 FROM_HERE, media_pipeline_backend_manager_.release()); | 302 FROM_HERE, media_pipeline_backend_manager_.release()); |
299 } | 303 } |
300 #endif // !defined(OS_ANDROID) | 304 #endif // defined(OS_ANDROID) |
301 } | 305 } |
302 | 306 |
303 scoped_refptr<base::SingleThreadTaskRunner> | 307 scoped_refptr<base::SingleThreadTaskRunner> |
304 CastBrowserMainParts::GetMediaTaskRunner() { | 308 CastBrowserMainParts::GetMediaTaskRunner() { |
305 #if defined(OS_ANDROID) | 309 #if defined(OS_ANDROID) |
306 return nullptr; | 310 return nullptr; |
307 #else | 311 #else |
308 if (!media_thread_) { | 312 if (!media_thread_) { |
309 media_thread_.reset(new base::Thread("CastMediaThread")); | 313 media_thread_.reset(new base::Thread("CastMediaThread")); |
310 base::Thread::Options options; | 314 base::Thread::Options options; |
(...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
383 } | 387 } |
384 | 388 |
385 int CastBrowserMainParts::PreCreateThreads() { | 389 int CastBrowserMainParts::PreCreateThreads() { |
386 #if defined(OS_ANDROID) | 390 #if defined(OS_ANDROID) |
387 // GPU process is started immediately after threads are created, requiring | 391 // GPU process is started immediately after threads are created, requiring |
388 // CrashDumpManager to be initialized beforehand. | 392 // CrashDumpManager to be initialized beforehand. |
389 base::FilePath crash_dumps_dir; | 393 base::FilePath crash_dumps_dir; |
390 if (!chromecast::CrashHandler::GetCrashDumpLocation(&crash_dumps_dir)) { | 394 if (!chromecast::CrashHandler::GetCrashDumpLocation(&crash_dumps_dir)) { |
391 LOG(ERROR) << "Could not find crash dump location."; | 395 LOG(ERROR) << "Could not find crash dump location."; |
392 } | 396 } |
393 cast_browser_process_->SetCrashDumpManager( | 397 breakpad::CrashDumpObserver::Create(); |
394 base::MakeUnique<breakpad::CrashDumpManager>(crash_dumps_dir)); | 398 crash_dump_manager_ = new breakpad::CrashDumpManager( |
| 399 crash_dumps_dir, kAndroidMinidumpDescriptor); |
| 400 breakpad::CrashDumpObserver::GetInstance()->RegisterClient( |
| 401 crash_dump_manager_); |
395 #else | 402 #else |
396 base::FilePath home_dir; | 403 base::FilePath home_dir; |
397 CHECK(PathService::Get(DIR_CAST_HOME, &home_dir)); | 404 CHECK(PathService::Get(DIR_CAST_HOME, &home_dir)); |
398 if (!base::CreateDirectory(home_dir)) | 405 if (!base::CreateDirectory(home_dir)) |
399 return 1; | 406 return 1; |
400 | 407 |
401 // Hook for internal code | 408 // Hook for internal code |
402 cast_browser_process_->browser_client()->PreCreateThreads(); | 409 cast_browser_process_->browser_client()->PreCreateThreads(); |
403 | 410 |
404 // Set GL strings so GPU config code can make correct feature blacklisting/ | 411 // 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... |
541 | 548 |
542 void CastBrowserMainParts::PostDestroyThreads() { | 549 void CastBrowserMainParts::PostDestroyThreads() { |
543 #if !defined(OS_ANDROID) | 550 #if !defined(OS_ANDROID) |
544 media_resource_tracker_->FinalizeAndDestroy(); | 551 media_resource_tracker_->FinalizeAndDestroy(); |
545 media_resource_tracker_ = nullptr; | 552 media_resource_tracker_ = nullptr; |
546 #endif | 553 #endif |
547 } | 554 } |
548 | 555 |
549 } // namespace shell | 556 } // namespace shell |
550 } // namespace chromecast | 557 } // namespace chromecast |
OLD | NEW |