| 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 "media/audio/audio_output_stream_sink.h" | 5 #include "media/audio/audio_output_stream_sink.h" | 
| 6 | 6 | 
| 7 #include <cmath> | 7 #include <cmath> | 
| 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 66 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 77   return OutputDeviceInfo(); | 77   return OutputDeviceInfo(); | 
| 78 } | 78 } | 
| 79 | 79 | 
| 80 bool AudioOutputStreamSink::CurrentThreadIsRenderingThread() { | 80 bool AudioOutputStreamSink::CurrentThreadIsRenderingThread() { | 
| 81   NOTIMPLEMENTED(); | 81   NOTIMPLEMENTED(); | 
| 82   return false; | 82   return false; | 
| 83 } | 83 } | 
| 84 | 84 | 
| 85 int AudioOutputStreamSink::OnMoreData(AudioBus* dest, | 85 int AudioOutputStreamSink::OnMoreData(AudioBus* dest, | 
| 86                                       uint32_t total_bytes_delay, | 86                                       uint32_t total_bytes_delay, | 
| 87                                       uint32_t frames_skipped) { | 87                                       uint32_t frames_skipped, | 
|  | 88                                       const AudioTimestamp& timestamp) { | 
| 88   // Note: Runs on the audio thread created by the OS. | 89   // Note: Runs on the audio thread created by the OS. | 
| 89   base::AutoLock al(callback_lock_); | 90   base::AutoLock al(callback_lock_); | 
| 90   if (!active_render_callback_) | 91   if (!active_render_callback_) | 
| 91     return 0; | 92     return 0; | 
| 92 | 93 | 
| 93   uint32_t frames_delayed = std::round(static_cast<double>(total_bytes_delay) / | 94   uint32_t frames_delayed = std::round(static_cast<double>(total_bytes_delay) / | 
| 94                                        active_params_.GetBytesPerFrame()); | 95                                        active_params_.GetBytesPerFrame()); | 
| 95 | 96 | 
| 96   return active_render_callback_->Render(dest, frames_delayed, frames_skipped); | 97   return active_render_callback_->Render(dest, frames_delayed, frames_skipped, | 
|  | 98                                          timestamp); | 
| 97 } | 99 } | 
| 98 | 100 | 
| 99 void AudioOutputStreamSink::OnError(AudioOutputStream* stream) { | 101 void AudioOutputStreamSink::OnError(AudioOutputStream* stream) { | 
| 100   // Note: Runs on the audio thread created by the OS. | 102   // Note: Runs on the audio thread created by the OS. | 
| 101   base::AutoLock al(callback_lock_); | 103   base::AutoLock al(callback_lock_); | 
| 102   if (active_render_callback_) | 104   if (active_render_callback_) | 
| 103     active_render_callback_->OnRenderError(); | 105     active_render_callback_->OnRenderError(); | 
| 104 } | 106 } | 
| 105 | 107 | 
| 106 void AudioOutputStreamSink::DoStart(const AudioParameters& params) { | 108 void AudioOutputStreamSink::DoStart(const AudioParameters& params) { | 
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 148   DCHECK(audio_task_runner_->BelongsToCurrentThread()); | 150   DCHECK(audio_task_runner_->BelongsToCurrentThread()); | 
| 149   stream_->SetVolume(volume); | 151   stream_->SetVolume(volume); | 
| 150 } | 152 } | 
| 151 | 153 | 
| 152 void AudioOutputStreamSink::ClearCallback() { | 154 void AudioOutputStreamSink::ClearCallback() { | 
| 153   base::AutoLock al(callback_lock_); | 155   base::AutoLock al(callback_lock_); | 
| 154   active_render_callback_ = NULL; | 156   active_render_callback_ = NULL; | 
| 155 } | 157 } | 
| 156 | 158 | 
| 157 }  // namepace media | 159 }  // namepace media | 
| OLD | NEW | 
|---|