blob: 3b082a5d25b9a68196f4b5f3be887abec2256f2a [file] [log] [blame]
Joachim Bauch6f2ef742015-05-21 15:52:011/*
2 * Copyright 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
Mirko Bonadei92ea95e2017-09-15 04:47:3111#include "rtc_base/bufferqueue.h"
Joachim Bauch6f2ef742015-05-21 15:52:0112
ossub01c7812016-02-24 09:05:5613#include <algorithm>
14
Joachim Bauch6f2ef742015-05-21 15:52:0115namespace rtc {
16
17BufferQueue::BufferQueue(size_t capacity, size_t default_size)
18 : capacity_(capacity), default_size_(default_size) {
19}
20
21BufferQueue::~BufferQueue() {
22 CritScope cs(&crit_);
23
24 for (Buffer* buffer : queue_) {
25 delete buffer;
26 }
27 for (Buffer* buffer : free_list_) {
28 delete buffer;
29 }
30}
31
32size_t BufferQueue::size() const {
33 CritScope cs(&crit_);
34 return queue_.size();
35}
36
guoweis4cc9f982016-02-24 19:10:0637void BufferQueue::Clear() {
38 CritScope cs(&crit_);
39 while (!queue_.empty()) {
40 free_list_.push_back(queue_.front());
41 queue_.pop_front();
42 }
43}
44
Joachim Bauch6f2ef742015-05-21 15:52:0145bool BufferQueue::ReadFront(void* buffer, size_t bytes, size_t* bytes_read) {
46 CritScope cs(&crit_);
47 if (queue_.empty()) {
48 return false;
49 }
50
jbauche488a0d2015-11-19 13:17:5851 bool was_writable = queue_.size() < capacity_;
Joachim Bauch6f2ef742015-05-21 15:52:0152 Buffer* packet = queue_.front();
53 queue_.pop_front();
54
jbauche488a0d2015-11-19 13:17:5855 bytes = std::min(bytes, packet->size());
Joachim Bauch6f2ef742015-05-21 15:52:0156 memcpy(buffer, packet->data(), bytes);
57 if (bytes_read) {
58 *bytes_read = bytes;
59 }
60 free_list_.push_back(packet);
jbauche488a0d2015-11-19 13:17:5861 if (!was_writable) {
62 NotifyWritableForTest();
63 }
Joachim Bauch6f2ef742015-05-21 15:52:0164 return true;
65}
66
67bool BufferQueue::WriteBack(const void* buffer, size_t bytes,
68 size_t* bytes_written) {
69 CritScope cs(&crit_);
70 if (queue_.size() == capacity_) {
71 return false;
72 }
73
jbauche488a0d2015-11-19 13:17:5874 bool was_readable = !queue_.empty();
Joachim Bauch6f2ef742015-05-21 15:52:0175 Buffer* packet;
76 if (!free_list_.empty()) {
77 packet = free_list_.back();
78 free_list_.pop_back();
79 } else {
80 packet = new Buffer(bytes, default_size_);
81 }
82
83 packet->SetData(static_cast<const uint8_t*>(buffer), bytes);
84 if (bytes_written) {
85 *bytes_written = bytes;
86 }
87 queue_.push_back(packet);
jbauche488a0d2015-11-19 13:17:5888 if (!was_readable) {
89 NotifyReadableForTest();
90 }
Joachim Bauch6f2ef742015-05-21 15:52:0191 return true;
92}
93
94} // namespace rtc