blob: 5cb18d0220d72a85955ae26c3e746e0b8633ab54 [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
Steve Anton10542f22019-01-11 17:11:0011#ifndef RTC_BASE_BUFFER_QUEUE_H_
12#define RTC_BASE_BUFFER_QUEUE_H_
Joachim Bauch6f2ef742015-05-21 15:52:0113
Yves Gerey988cc082018-10-23 10:03:0114#include <stddef.h>
Jonas Olssona4d87372019-07-05 17:08:3315
Henrik Kjellanderec78f1c2017-06-29 05:52:5016#include <deque>
17#include <vector>
Joachim Bauch6f2ef742015-05-21 15:52:0118
Mirko Bonadei92ea95e2017-09-15 04:47:3119#include "rtc_base/buffer.h"
Steve Anton10542f22019-01-11 17:11:0020#include "rtc_base/constructor_magic.h"
21#include "rtc_base/critical_section.h"
Yves Gerey988cc082018-10-23 10:03:0122#include "rtc_base/thread_annotations.h"
Henrik Kjellanderec78f1c2017-06-29 05:52:5023
24namespace rtc {
25
26class BufferQueue {
27 public:
28 // Creates a buffer queue with a given capacity and default buffer size.
29 BufferQueue(size_t capacity, size_t default_size);
30 virtual ~BufferQueue();
31
32 // Return number of queued buffers.
33 size_t size() const;
34
35 // Clear the BufferQueue by moving all Buffers from |queue_| to |free_list_|.
36 void Clear();
37
38 // ReadFront will only read one buffer at a time and will truncate buffers
39 // that don't fit in the passed memory.
40 // Returns true unless no data could be returned.
41 bool ReadFront(void* data, size_t bytes, size_t* bytes_read);
42
43 // WriteBack always writes either the complete memory or nothing.
44 // Returns true unless no data could be written.
45 bool WriteBack(const void* data, size_t bytes, size_t* bytes_written);
46
47 protected:
48 // These methods are called when the state of the queue changes.
49 virtual void NotifyReadableForTest() {}
50 virtual void NotifyWritableForTest() {}
51
52 private:
53 size_t capacity_;
54 size_t default_size_;
55 CriticalSection crit_;
danilchap3c6abd22017-09-06 12:46:2956 std::deque<Buffer*> queue_ RTC_GUARDED_BY(crit_);
57 std::vector<Buffer*> free_list_ RTC_GUARDED_BY(crit_);
Henrik Kjellanderec78f1c2017-06-29 05:52:5058
59 RTC_DISALLOW_COPY_AND_ASSIGN(BufferQueue);
60};
61
62} // namespace rtc
Joachim Bauch6f2ef742015-05-21 15:52:0163
Steve Anton10542f22019-01-11 17:11:0064#endif // RTC_BASE_BUFFER_QUEUE_H_