| Index: media/base/audio_pull_fifo.cc
|
| diff --git a/media/base/audio_pull_fifo.cc b/media/base/audio_pull_fifo.cc
|
| index 4943591b7c2cdd30c1b499b17250a083eb3654f9..cf25142d904f588d11164db363df4d0568ef0757 100644
|
| --- a/media/base/audio_pull_fifo.cc
|
| +++ b/media/base/audio_pull_fifo.cc
|
| @@ -7,53 +7,60 @@
|
| #include <algorithm>
|
|
|
| #include "base/logging.h"
|
| +#include "media/base/audio_bus.h"
|
|
|
| namespace media {
|
|
|
| AudioPullFifo::AudioPullFifo(int channels, int frames, const ReadCB& read_cb)
|
| - : read_cb_(read_cb) {
|
| - fifo_.reset(new AudioFifo(channels, frames));
|
| - bus_ = AudioBus::Create(channels, frames);
|
| -}
|
| + : read_cb_(read_cb),
|
| + fifo_(AudioBus::Create(channels, frames)),
|
| + fifo_index_(frames) {}
|
|
|
| -AudioPullFifo::~AudioPullFifo() {
|
| - read_cb_.Reset();
|
| -}
|
| +AudioPullFifo::~AudioPullFifo() {}
|
|
|
| void AudioPullFifo::Consume(AudioBus* destination, int frames_to_consume) {
|
| - DCHECK(destination);
|
| DCHECK_LE(frames_to_consume, destination->frames());
|
|
|
| - int write_pos = 0;
|
| int remaining_frames_to_provide = frames_to_consume;
|
|
|
| // Try to fulfill the request using what's available in the FIFO.
|
| - ReadFromFifo(destination, &remaining_frames_to_provide, &write_pos);
|
| + int frames_read = ReadFromFifo(destination, remaining_frames_to_provide, 0);
|
| + int write_pos = frames_read;
|
| + remaining_frames_to_provide -= frames_read;
|
|
|
| // Get the remaining audio frames from the producer using the callback.
|
| while (remaining_frames_to_provide > 0) {
|
| + DCHECK_EQ(fifo_index_, fifo_->frames());
|
| + fifo_index_ = 0;
|
| +
|
| // Fill up the FIFO by acquiring audio data from the producer.
|
| - read_cb_.Run(write_pos, bus_.get());
|
| - fifo_->Push(bus_.get());
|
| + read_cb_.Run(write_pos, fifo_.get());
|
|
|
| // Try to fulfill the request using what's available in the FIFO.
|
| - ReadFromFifo(destination, &remaining_frames_to_provide, &write_pos);
|
| + frames_read =
|
| + ReadFromFifo(destination, remaining_frames_to_provide, write_pos);
|
| + write_pos += frames_read;
|
| + remaining_frames_to_provide -= frames_read;
|
| }
|
| }
|
|
|
| -void AudioPullFifo::Clear() {
|
| - fifo_->Clear();
|
| -}
|
| +void AudioPullFifo::Clear() { fifo_index_ = fifo_->frames(); }
|
| +
|
| +int AudioPullFifo::ReadFromFifo(AudioBus* destination,
|
| + int frames_to_provide,
|
| + int write_pos) {
|
| + int frames = std::min(frames_to_provide, fifo_->frames() - fifo_index_);
|
| + if (frames <= 0)
|
| + return 0;
|
| +
|
| + for (int ch = 0; ch < fifo_->channels(); ++ch) {
|
| + const float* src = fifo_->channel(ch) + fifo_index_;
|
| + float* dest = destination->channel(ch) + write_pos;
|
| + memcpy(dest, src, frames * sizeof(*src));
|
| + }
|
|
|
| -void AudioPullFifo::ReadFromFifo(AudioBus* destination,
|
| - int* frames_to_provide,
|
| - int* write_pos) {
|
| - DCHECK(frames_to_provide);
|
| - DCHECK(write_pos);
|
| - int frames = std::min(fifo_->frames(), *frames_to_provide);
|
| - fifo_->Consume(destination, *write_pos, frames);
|
| - *write_pos += frames;
|
| - *frames_to_provide -= frames;
|
| + fifo_index_ += frames;
|
| + return frames;
|
| }
|
|
|
| } // namespace media
|
|
|