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 // Audio rendering unit utilizing audio output stream provided by browser | 5 // Audio rendering unit utilizing audio output stream provided by browser |
6 // process through IPC. | 6 // process through IPC. |
7 // | 7 // |
8 // Relationship of classes. | 8 // Relationship of classes. |
9 // | 9 // |
10 // AudioOutputController AudioOutputDevice | 10 // AudioOutputController AudioOutputDevice |
(...skipping 180 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
191 // If |device_id_| is empty and |session_id_| is not, |matched_device_id_| is | 191 // If |device_id_| is empty and |session_id_| is not, |matched_device_id_| is |
192 // received in OnDeviceAuthorized(). | 192 // received in OnDeviceAuthorized(). |
193 std::string matched_device_id_; | 193 std::string matched_device_id_; |
194 | 194 |
195 // Our audio thread callback class. See source file for details. | 195 // Our audio thread callback class. See source file for details. |
196 class AudioThreadCallback; | 196 class AudioThreadCallback; |
197 | 197 |
198 // In order to avoid a race between OnStreamCreated and Stop(), we use this | 198 // In order to avoid a race between OnStreamCreated and Stop(), we use this |
199 // guard to control stopping and starting the audio thread. | 199 // guard to control stopping and starting the audio thread. |
200 base::Lock audio_thread_lock_; | 200 base::Lock audio_thread_lock_; |
201 AudioDeviceThread audio_thread_; | |
202 std::unique_ptr<AudioOutputDevice::AudioThreadCallback> audio_callback_; | 201 std::unique_ptr<AudioOutputDevice::AudioThreadCallback> audio_callback_; |
| 202 std::unique_ptr<AudioDeviceThread> audio_thread_; |
203 | 203 |
204 // Temporary hack to ignore OnStreamCreated() due to the user calling Stop() | 204 // Temporary hack to ignore OnStreamCreated() due to the user calling Stop() |
205 // so we don't start the audio thread pointing to a potentially freed | 205 // so we don't start the audio thread pointing to a potentially freed |
206 // |callback_|. | 206 // |callback_|. |
207 // | 207 // |
208 // TODO(scherkus): Replace this by changing AudioRendererSink to either accept | 208 // TODO(scherkus): Replace this by changing AudioRendererSink to either accept |
209 // the callback via Start(). See http://crbug.com/151051 for details. | 209 // the callback via Start(). See http://crbug.com/151051 for details. |
210 bool stopping_hack_; | 210 bool stopping_hack_; |
211 | 211 |
212 base::WaitableEvent did_receive_auth_; | 212 base::WaitableEvent did_receive_auth_; |
213 AudioParameters output_params_; | 213 AudioParameters output_params_; |
214 OutputDeviceStatus device_status_; | 214 OutputDeviceStatus device_status_; |
215 | 215 |
216 const base::TimeDelta auth_timeout_; | 216 const base::TimeDelta auth_timeout_; |
217 std::unique_ptr<base::OneShotTimer> auth_timeout_action_; | 217 std::unique_ptr<base::OneShotTimer> auth_timeout_action_; |
218 | 218 |
219 DISALLOW_COPY_AND_ASSIGN(AudioOutputDevice); | 219 DISALLOW_COPY_AND_ASSIGN(AudioOutputDevice); |
220 }; | 220 }; |
221 | 221 |
222 } // namespace media | 222 } // namespace media |
223 | 223 |
224 #endif // MEDIA_AUDIO_AUDIO_OUTPUT_DEVICE_H_ | 224 #endif // MEDIA_AUDIO_AUDIO_OUTPUT_DEVICE_H_ |
OLD | NEW |