blob: 3b082a5d25b9a68196f4b5f3be887abec2256f2a [file] [log] [blame]
Joachim Bauch6f2ef742015-05-21 17:52:01 +02001/*
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 06:47:31 +020011#include "rtc_base/bufferqueue.h"
Joachim Bauch6f2ef742015-05-21 17:52:01 +020012
ossub01c7812016-02-24 01:05:56 -080013#include <algorithm>
14
Joachim Bauch6f2ef742015-05-21 17:52:01 +020015namespace 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 11:10:06 -080037void 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 17:52:01 +020045bool 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 05:17:58 -080051 bool was_writable = queue_.size() < capacity_;
Joachim Bauch6f2ef742015-05-21 17:52:01 +020052 Buffer* packet = queue_.front();
53 queue_.pop_front();
54
jbauche488a0d2015-11-19 05:17:58 -080055 bytes = std::min(bytes, packet->size());
Joachim Bauch6f2ef742015-05-21 17:52:01 +020056 memcpy(buffer, packet->data(), bytes);
57 if (bytes_read) {
58 *bytes_read = bytes;
59 }
60 free_list_.push_back(packet);
jbauche488a0d2015-11-19 05:17:58 -080061 if (!was_writable) {
62 NotifyWritableForTest();
63 }
Joachim Bauch6f2ef742015-05-21 17:52:01 +020064 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 05:17:58 -080074 bool was_readable = !queue_.empty();
Joachim Bauch6f2ef742015-05-21 17:52:01 +020075 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 05:17:58 -080088 if (!was_readable) {
89 NotifyReadableForTest();
90 }
Joachim Bauch6f2ef742015-05-21 17:52:01 +020091 return true;
92}
93
94} // namespace rtc