blob: a29e53a61c626d7134302caefcc2354e5e0d0adf [file] [log] [blame]
andrew@webrtc.org041035b2015-01-26 21:23:53 +00001/*
2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
peahfaed4ab2016-04-05 14:57:48 -070011#include "webrtc/common_audio/audio_ring_buffer.h"
andrew@webrtc.org041035b2015-01-26 21:23:53 +000012
Henrik Kjellandera80c16a2017-07-01 16:48:15 +020013#include "webrtc/base/checks.h"
peahfaed4ab2016-04-05 14:57:48 -070014#include "webrtc/common_audio/ring_buffer.h"
andrew@webrtc.org041035b2015-01-26 21:23:53 +000015
16// This is a simple multi-channel wrapper over the ring_buffer.h C interface.
17
18namespace webrtc {
19
20AudioRingBuffer::AudioRingBuffer(size_t channels, size_t max_frames) {
andrewd40af692015-07-28 00:52:59 -070021 buffers_.reserve(channels);
andrew@webrtc.org041035b2015-01-26 21:23:53 +000022 for (size_t i = 0; i < channels; ++i)
23 buffers_.push_back(WebRtc_CreateBuffer(max_frames, sizeof(float)));
24}
25
26AudioRingBuffer::~AudioRingBuffer() {
27 for (auto buf : buffers_)
28 WebRtc_FreeBuffer(buf);
29}
30
31void AudioRingBuffer::Write(const float* const* data, size_t channels,
32 size_t frames) {
henrikg91d6ede2015-09-17 00:24:34 -070033 RTC_DCHECK_EQ(buffers_.size(), channels);
andrew@webrtc.org041035b2015-01-26 21:23:53 +000034 for (size_t i = 0; i < channels; ++i) {
andrewd40af692015-07-28 00:52:59 -070035 const size_t written = WebRtc_WriteBuffer(buffers_[i], data[i], frames);
henrikg91d6ede2015-09-17 00:24:34 -070036 RTC_CHECK_EQ(written, frames);
andrew@webrtc.org041035b2015-01-26 21:23:53 +000037 }
38}
39
40void AudioRingBuffer::Read(float* const* data, size_t channels, size_t frames) {
henrikg91d6ede2015-09-17 00:24:34 -070041 RTC_DCHECK_EQ(buffers_.size(), channels);
andrew@webrtc.org041035b2015-01-26 21:23:53 +000042 for (size_t i = 0; i < channels; ++i) {
andrewd40af692015-07-28 00:52:59 -070043 const size_t read =
44 WebRtc_ReadBuffer(buffers_[i], nullptr, data[i], frames);
henrikg91d6ede2015-09-17 00:24:34 -070045 RTC_CHECK_EQ(read, frames);
andrew@webrtc.org041035b2015-01-26 21:23:53 +000046 }
47}
48
49size_t AudioRingBuffer::ReadFramesAvailable() const {
50 // All buffers have the same amount available.
51 return WebRtc_available_read(buffers_[0]);
52}
53
54size_t AudioRingBuffer::WriteFramesAvailable() const {
55 // All buffers have the same amount available.
56 return WebRtc_available_write(buffers_[0]);
57}
58
andrewd40af692015-07-28 00:52:59 -070059void AudioRingBuffer::MoveReadPositionForward(size_t frames) {
andrew@webrtc.org041035b2015-01-26 21:23:53 +000060 for (auto buf : buffers_) {
andrewd40af692015-07-28 00:52:59 -070061 const size_t moved =
62 static_cast<size_t>(WebRtc_MoveReadPtr(buf, static_cast<int>(frames)));
henrikg91d6ede2015-09-17 00:24:34 -070063 RTC_CHECK_EQ(moved, frames);
andrewd40af692015-07-28 00:52:59 -070064 }
65}
66
67void AudioRingBuffer::MoveReadPositionBackward(size_t frames) {
68 for (auto buf : buffers_) {
69 const size_t moved = static_cast<size_t>(
70 -WebRtc_MoveReadPtr(buf, -static_cast<int>(frames)));
henrikg91d6ede2015-09-17 00:24:34 -070071 RTC_CHECK_EQ(moved, frames);
andrew@webrtc.org041035b2015-01-26 21:23:53 +000072 }
73}
74
75} // namespace webrtc