blob: 5cb18d0220d72a85955ae26c3e746e0b8633ab54 [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
Steve Anton10542f22019-01-11 09:11:00 -080011#ifndef RTC_BASE_BUFFER_QUEUE_H_
12#define RTC_BASE_BUFFER_QUEUE_H_
Joachim Bauch6f2ef742015-05-21 17:52:01 +020013
Yves Gerey988cc082018-10-23 12:03:01 +020014#include <stddef.h>
Jonas Olssona4d87372019-07-05 19:08:33 +020015
Henrik Kjellanderec78f1c2017-06-29 07:52:50 +020016#include <deque>
17#include <vector>
Joachim Bauch6f2ef742015-05-21 17:52:01 +020018
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020019#include "rtc_base/buffer.h"
Steve Anton10542f22019-01-11 09:11:00 -080020#include "rtc_base/constructor_magic.h"
21#include "rtc_base/critical_section.h"
Yves Gerey988cc082018-10-23 12:03:01 +020022#include "rtc_base/thread_annotations.h"
Henrik Kjellanderec78f1c2017-06-29 07:52:50 +020023
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 05:46:29 -070056 std::deque<Buffer*> queue_ RTC_GUARDED_BY(crit_);
57 std::vector<Buffer*> free_list_ RTC_GUARDED_BY(crit_);
Henrik Kjellanderec78f1c2017-06-29 07:52:50 +020058
59 RTC_DISALLOW_COPY_AND_ASSIGN(BufferQueue);
60};
61
62} // namespace rtc
Joachim Bauch6f2ef742015-05-21 17:52:01 +020063
Steve Anton10542f22019-01-11 09:11:00 -080064#endif // RTC_BASE_BUFFER_QUEUE_H_