blob: ebc841e1fc5b648e636dfe472495b34f2fbebd12 [file] [log] [blame]
Jonas Oreland6d835922019-03-18 10:59:40 +01001/*
2 * Copyright (c) 2019 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
11#include "media/engine/unhandled_packets_buffer.h"
Steve Antonb118d422019-03-28 11:04:59 -070012
13#include "absl/algorithm/container.h"
Jonas Oreland6d835922019-03-18 10:59:40 +010014#include "rtc_base/logging.h"
15#include "rtc_base/strings/string_builder.h"
16
17namespace cricket {
18
19UnhandledPacketsBuffer::UnhandledPacketsBuffer() {
20 buffer_.reserve(kMaxStashedPackets);
21}
22
23UnhandledPacketsBuffer::~UnhandledPacketsBuffer() = default;
24
25// Store packet in buffer.
26void UnhandledPacketsBuffer::AddPacket(uint32_t ssrc,
27 int64_t packet_time_us,
28 rtc::CopyOnWriteBuffer packet) {
29 if (buffer_.size() < kMaxStashedPackets) {
30 buffer_.push_back({ssrc, packet_time_us, packet});
31 } else {
32 RTC_DCHECK_LT(insert_pos_, kMaxStashedPackets);
33 buffer_[insert_pos_] = {ssrc, packet_time_us, packet};
34 }
35 insert_pos_ = (insert_pos_ + 1) % kMaxStashedPackets;
36}
37
38// Backfill |consumer| with all stored packet related |ssrcs|.
39void UnhandledPacketsBuffer::BackfillPackets(
40 rtc::ArrayView<const uint32_t> ssrcs,
41 std::function<void(uint32_t, int64_t, rtc::CopyOnWriteBuffer)> consumer) {
42 size_t start;
43 if (buffer_.size() < kMaxStashedPackets) {
44 start = 0;
45 } else {
46 start = insert_pos_;
47 }
48
49 size_t count = 0;
50 std::vector<PacketWithMetadata> remaining;
51 remaining.reserve(kMaxStashedPackets);
52 for (size_t i = 0; i < buffer_.size(); ++i) {
53 const size_t pos = (i + start) % kMaxStashedPackets;
54
55 // One or maybe 2 ssrcs is expected => loop array instead of more elaborate
56 // scheme.
57 const uint32_t ssrc = buffer_[pos].ssrc;
Steve Antonb118d422019-03-28 11:04:59 -070058 if (absl::c_linear_search(ssrcs, ssrc)) {
Jonas Oreland6d835922019-03-18 10:59:40 +010059 ++count;
60 consumer(ssrc, buffer_[pos].packet_time_us, buffer_[pos].packet);
61 } else {
62 remaining.push_back(buffer_[pos]);
63 }
64 }
65
66 insert_pos_ = 0; // insert_pos is only used when buffer is full.
67 buffer_.swap(remaining);
68}
69
70} // namespace cricket