Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(39)

Side by Side Diff: media/audio/audio_manager.cc

Issue 2077983003: Intiialize AudioManager and related class lazily (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: check if StartHangTimer() is called earlier Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 "media/audio/audio_manager.h" 5 #include "media/audio/audio_manager.h"
6 6
7 #include <stdint.h> 7 #include <stdint.h>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/bind_helpers.h" 10 #include "base/bind_helpers.h"
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after
55 THREAD_HUNG, 55 THREAD_HUNG,
56 THREAD_RECOVERED, 56 THREAD_RECOVERED,
57 THREAD_MAX = THREAD_RECOVERED 57 THREAD_MAX = THREAD_RECOVERED
58 }; 58 };
59 59
60 AudioManagerHelper() {} 60 AudioManagerHelper() {}
61 ~AudioManagerHelper() override {} 61 ~AudioManagerHelper() override {}
62 62
63 void StartHangTimer( 63 void StartHangTimer(
64 scoped_refptr<base::SingleThreadTaskRunner> monitor_task_runner) { 64 scoped_refptr<base::SingleThreadTaskRunner> monitor_task_runner) {
65 CHECK(!monitor_task_runner_); 65 if (monitor_task_runner_)
66 return;
66 CHECK(!audio_task_runner_); 67 CHECK(!audio_task_runner_);
67 monitor_task_runner_ = std::move(monitor_task_runner); 68 monitor_task_runner_ = std::move(monitor_task_runner);
68 audio_task_runner_ = AudioManager::Get()->GetTaskRunner(); 69 audio_task_runner_ = AudioManager::Get()->GetTaskRunner();
69 base::PowerMonitor::Get()->AddObserver(this); 70 base::PowerMonitor::Get()->AddObserver(this);
70 71
71 io_task_running_ = audio_task_running_ = true; 72 io_task_running_ = audio_task_running_ = true;
72 audio_task_runner_->PostTask( 73 audio_task_runner_->PostTask(
73 FROM_HERE, 74 FROM_HERE,
74 base::Bind(&AudioManagerHelper::UpdateLastAudioThreadTimeTick, 75 base::Bind(&AudioManagerHelper::UpdateLastAudioThreadTimeTick,
75 base::Unretained(this))); 76 base::Unretained(this)));
(...skipping 277 matching lines...) Expand 10 before | Expand all | Expand 10 after
353 return g_helper.Pointer()->app_name(); 354 return g_helper.Pointer()->app_name();
354 } 355 }
355 #endif 356 #endif
356 357
357 // static 358 // static
358 AudioManager* AudioManager::Get() { 359 AudioManager* AudioManager::Get() {
359 return g_last_created; 360 return g_last_created;
360 } 361 }
361 362
362 } // namespace media 363 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698