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

Side by Side Diff: content/browser/renderer_host/media/audio_input_device_manager.cc

Issue 10662049: Move the device enumerate/open/close work to device thread from IO thread (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: moved MediaStream to BrowserMainloop and addressed all the comments from Tommi and Magnus. Created 8 years, 5 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 | Annotate | Revision Log
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 "content/browser/renderer_host/media/audio_input_device_manager.h" 5 #include "content/browser/renderer_host/media/audio_input_device_manager.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/memory/scoped_ptr.h" 8 #include "base/memory/scoped_ptr.h"
9 #include "content/browser/renderer_host/media/audio_input_device_manager_event_h andler.h" 9 #include "content/browser/renderer_host/media/audio_input_device_manager_event_h andler.h"
10 #include "content/public/browser/browser_thread.h" 10 #include "content/public/browser/browser_thread.h"
(...skipping 13 matching lines...) Expand all
24 AudioInputDeviceManager::AudioInputDeviceManager( 24 AudioInputDeviceManager::AudioInputDeviceManager(
25 media::AudioManager* audio_manager) 25 media::AudioManager* audio_manager)
26 : listener_(NULL), 26 : listener_(NULL),
27 next_capture_session_id_(kFirstSessionId), 27 next_capture_session_id_(kFirstSessionId),
28 audio_manager_(audio_manager) { 28 audio_manager_(audio_manager) {
29 } 29 }
30 30
31 AudioInputDeviceManager::~AudioInputDeviceManager() { 31 AudioInputDeviceManager::~AudioInputDeviceManager() {
32 } 32 }
33 33
34 void AudioInputDeviceManager::Register(MediaStreamProviderListener* listener) { 34 void AudioInputDeviceManager::Register(MediaStreamProviderListener* listener,
35 base::MessageLoopProxy* message_loop) {
35 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 36 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
36 DCHECK(!listener_); 37 DCHECK(!listener_);
38 DCHECK(!device_loop_);
37 listener_ = listener; 39 listener_ = listener;
40 device_loop_ = message_loop;
38 } 41 }
39 42
40 void AudioInputDeviceManager::Unregister() { 43 void AudioInputDeviceManager::Unregister() {
41 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 44 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
42 DCHECK(listener_); 45 DCHECK(listener_);
43 listener_ = NULL; 46 listener_ = NULL;
44 } 47 }
45 48
46 void AudioInputDeviceManager::EnumerateDevices() { 49 void AudioInputDeviceManager::EnumerateDevices() {
47 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 50 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
48 DCHECK(listener_); 51 DCHECK(listener_);
49 52
53 device_loop_->PostTask(
54 FROM_HERE,
55 base::Bind(&AudioInputDeviceManager::EnumerateOnDeviceThread, this));
56 }
57
58 int AudioInputDeviceManager::Open(const StreamDeviceInfo& device) {
59 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
60 // Generates a new id for this device.
61 int session_id = next_capture_session_id_++;
62 device_loop_->PostTask(
63 FROM_HERE,
64 base::Bind(&AudioInputDeviceManager::OpenOnDeviceThread,
65 this, session_id, device));
66
67 return session_id;
68 }
69
70 void AudioInputDeviceManager::Close(int session_id) {
71 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
72 DCHECK(listener_);
73 device_loop_->PostTask(
74 FROM_HERE,
75 base::Bind(&AudioInputDeviceManager::CloseOnDeviceThread,
76 this, session_id));
77 }
78
79 void AudioInputDeviceManager::EnumerateOnDeviceThread() {
80 DCHECK(IsOnDeviceThread());
81 // AudioManager is deleted after FILE thread stops, so the device thread
tommi (sloooow) - chröme 2012/07/04 13:46:48 do we still use the FILE thread for something or d
no longer working on chromium 2012/07/04 14:31:39 Wrong comment from some previous upload.
82 // should never outlive the AudioManager.
50 media::AudioDeviceNames device_names; 83 media::AudioDeviceNames device_names;
51 audio_manager_->GetAudioInputDeviceNames(&device_names); 84 audio_manager_->GetAudioInputDeviceNames(&device_names);
52 85
53 StreamDeviceInfoArray* devices = new StreamDeviceInfoArray; 86 StreamDeviceInfoArray* devices = new StreamDeviceInfoArray;
54 for (media::AudioDeviceNames::iterator it = device_names.begin(); 87 for (media::AudioDeviceNames::iterator it = device_names.begin();
55 it != device_names.end(); 88 it != device_names.end();
56 ++it) { 89 ++it) {
57 devices->push_back(StreamDeviceInfo( 90 devices->push_back(StreamDeviceInfo(
58 content::MEDIA_STREAM_DEVICE_TYPE_AUDIO_CAPTURE, it->device_name, 91 content::MEDIA_STREAM_DEVICE_TYPE_AUDIO_CAPTURE, it->device_name,
59 it->unique_id, false)); 92 it->unique_id, false));
60 } 93 }
61 94
62 // Returns the device list through the listener by posting a task on 95 // Returns the device list through the listener by posting a task on
63 // IO thread since MediaStreamManager handles the callback asynchronously. 96 // IO thread since MediaStreamManager handles the callback asynchronously.
64 BrowserThread::PostTask( 97 BrowserThread::PostTask(
65 BrowserThread::IO, 98 BrowserThread::IO,
66 FROM_HERE, 99 FROM_HERE,
67 base::Bind(&AudioInputDeviceManager::DevicesEnumeratedOnIOThread, 100 base::Bind(&AudioInputDeviceManager::DevicesEnumeratedOnIOThread,
68 this, 101 this,
69 devices)); 102 devices));
70 } 103 }
71 104
72 int AudioInputDeviceManager::Open(const StreamDeviceInfo& device) { 105 void AudioInputDeviceManager::OpenOnDeviceThread(
73 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 106 int session_id, const StreamDeviceInfo& device) {
74 107 DCHECK(IsOnDeviceThread());
75 // Generates a new id for this device.
76 int session_id = next_capture_session_id_++;
77 DCHECK(devices_.find(session_id) == devices_.end()); 108 DCHECK(devices_.find(session_id) == devices_.end());
78 109
79 media::AudioDeviceName audio_input_device_name;
80 audio_input_device_name.device_name = device.name;
81 audio_input_device_name.unique_id = device.device_id;
82
83 // Adds the session_id and device to the list. 110 // Adds the session_id and device to the list.
84 devices_[session_id] = audio_input_device_name; 111 media::AudioDeviceName target_device(device.name, device.device_id);
112 devices_[session_id] = target_device;
85 113
86 // Returns the |session_id| through the listener by posting a task on 114 // Returns the |session_id| through the listener by posting a task on
87 // IO thread since MediaStreamManager handles the callback asynchronously. 115 // IO thread since MediaStreamManager handles the callback asynchronously.
88 BrowserThread::PostTask(BrowserThread::IO, 116 BrowserThread::PostTask(BrowserThread::IO,
89 FROM_HERE, 117 FROM_HERE,
90 base::Bind(&AudioInputDeviceManager::OpenedOnIOThread, 118 base::Bind(&AudioInputDeviceManager::OpenedOnIOThread,
91 this, 119 this,
92 session_id)); 120 session_id));
93
94 return session_id;
95 } 121 }
96 122
97 void AudioInputDeviceManager::Close(int session_id) { 123 void AudioInputDeviceManager::CloseOnDeviceThread(int session_id) {
98 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 124 DCHECK(IsOnDeviceThread());
99 DCHECK(listener_);
100 125
101 if (devices_.find(session_id) != devices_.end()) 126 if (devices_.find(session_id) != devices_.end())
102 devices_.erase(session_id); 127 devices_.erase(session_id);
103 128
104 // Checks if the device has been stopped, if not, send stop signal. 129 // Checks if the device has been stopped, if not, send stop signal.
105 EventHandlerMap::iterator it = event_handlers_.find(session_id); 130 EventHandlerMap::iterator it = event_handlers_.find(session_id);
106 if (it != event_handlers_.end()) { 131 if (it != event_handlers_.end()) {
107 it->second->OnDeviceStopped(session_id); 132 it->second->OnDeviceStopped(session_id);
108 event_handlers_.erase(session_id); 133 event_handlers_.erase(session_id);
109 } 134 }
(...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after
174 session_id); 199 session_id);
175 } 200 }
176 201
177 void AudioInputDeviceManager::ClosedOnIOThread(int session_id) { 202 void AudioInputDeviceManager::ClosedOnIOThread(int session_id) {
178 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 203 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
179 if (listener_) 204 if (listener_)
180 listener_->Closed(content::MEDIA_STREAM_DEVICE_TYPE_AUDIO_CAPTURE, 205 listener_->Closed(content::MEDIA_STREAM_DEVICE_TYPE_AUDIO_CAPTURE,
181 session_id); 206 session_id);
182 } 207 }
183 208
209 bool AudioInputDeviceManager::IsOnDeviceThread() const {
210 return device_loop_->BelongsToCurrentThread();
211 }
212
184 } // namespace media_stream 213 } // namespace media_stream
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698