blob: 8d577fe0cccab9279d3cdbb0354c5c61f7ccbd75 [file] [log] [blame]
niklase@google.com470e71d2011-07-07 08:21:25 +00001/*
2 * Copyright (c) 2011 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#ifndef MODULES_VIDEO_CODING_SESSION_INFO_H_
12#define MODULES_VIDEO_CODING_SESSION_INFO_H_
niklase@google.com470e71d2011-07-07 08:21:25 +000013
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000014#include <list>
stefana669a3a2016-10-06 05:04:52 -070015#include <vector>
niklase@google.com470e71d2011-07-07 08:21:25 +000016
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020017#include "modules/include/module_common_types.h"
18#include "modules/video_coding/include/video_coding.h"
19#include "modules/video_coding/packet.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000020
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000021namespace webrtc {
agalusza@google.comd818dcb2013-07-29 21:48:11 +000022// Used to pass data from jitter buffer to session info.
23// This data is then used in determining whether a frame is decodable.
24struct FrameData {
pkasting@chromium.org16825b12015-01-12 21:51:21 +000025 int64_t rtt_ms;
agalusza@google.comd818dcb2013-07-29 21:48:11 +000026 float rolling_average_packets_per_frame;
27};
stefan@webrtc.orgc3d89102011-09-08 06:50:28 +000028
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000029class VCMSessionInfo {
30 public:
31 VCMSessionInfo();
Stefan Holmerdbdb3a02018-07-17 16:03:46 +020032 ~VCMSessionInfo();
niklase@google.com470e71d2011-07-07 08:21:25 +000033
stefan@webrtc.orgb07aa402012-01-10 11:45:05 +000034 void UpdateDataPointers(const uint8_t* old_base_ptr,
35 const uint8_t* new_base_ptr);
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000036 void Reset();
37 int InsertPacket(const VCMPacket& packet,
38 uint8_t* frame_buffer,
agalusza@google.coma7e360e2013-08-01 03:15:08 +000039 VCMDecodeErrorMode enable_decodable_state,
agalusza@google.comd818dcb2013-07-29 21:48:11 +000040 const FrameData& frame_data);
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000041 bool complete() const;
42 bool decodable() const;
stefan@webrtc.orgc3d89102011-09-08 06:50:28 +000043
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000044 // Makes the frame decodable. I.e., only contain decodable NALUs. All
45 // non-decodable NALUs will be deleted and packets will be moved to in
46 // memory to remove any empty space.
47 // Returns the number of bytes deleted from the session.
pkasting@chromium.org4591fbd2014-11-20 22:28:14 +000048 size_t MakeDecodable();
agalusza@google.comd177c102013-08-08 01:12:33 +000049
Niels Möller425f7132018-06-08 15:17:41 +020050 // TODO(nisse): Used by tests only.
pkasting@chromium.org4591fbd2014-11-20 22:28:14 +000051 size_t SessionLength() const;
agalusza@google.comd818dcb2013-07-29 21:48:11 +000052 int NumPackets() const;
stefan@webrtc.org885cd132013-04-16 09:38:26 +000053 bool HaveFirstPacket() const;
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000054 bool HaveLastPacket() const;
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000055 webrtc::FrameType FrameType() const { return frame_type_; }
56 int LowSequenceNumber() const;
niklase@google.com470e71d2011-07-07 08:21:25 +000057
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000058 // Returns highest sequence number, media or empty.
59 int HighSequenceNumber() const;
60 int PictureId() const;
61 int TemporalId() const;
henrik.lundin@webrtc.orgeda86dc2011-12-13 14:11:06 +000062 bool LayerSync() const;
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000063 int Tl0PicId() const;
stefan@webrtc.orgc3d89102011-09-08 06:50:28 +000064
stefana669a3a2016-10-06 05:04:52 -070065 std::vector<NaluInfo> GetNaluInfos() const;
66
asapersson9a4cd872015-10-23 00:27:14 -070067 void SetGofInfo(const GofInfoVP9& gof_info, size_t idx);
68
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000069 private:
70 enum { kMaxVP8Partitions = 9 };
niklase@google.com470e71d2011-07-07 08:21:25 +000071
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000072 typedef std::list<VCMPacket> PacketList;
73 typedef PacketList::iterator PacketIterator;
74 typedef PacketList::const_iterator PacketIteratorConst;
75 typedef PacketList::reverse_iterator ReversePacketIterator;
niklase@google.com470e71d2011-07-07 08:21:25 +000076
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000077 void InformOfEmptyPacket(uint16_t seq_num);
niklase@google.com470e71d2011-07-07 08:21:25 +000078
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000079 // Finds the packet of the beginning of the next VP8 partition. If
80 // none is found the returned iterator points to |packets_.end()|.
81 // |it| is expected to point to the last packet of the previous partition,
82 // or to the first packet of the frame. |packets_skipped| is incremented
83 // for each packet found which doesn't have the beginning bit set.
mikhal@webrtc.org2b810bf2013-09-03 19:09:49 +000084 PacketIterator FindNextPartitionBeginning(PacketIterator it) const;
niklase@google.com470e71d2011-07-07 08:21:25 +000085
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000086 // Returns an iterator pointing to the last packet of the partition pointed to
87 // by |it|.
88 PacketIterator FindPartitionEnd(PacketIterator it) const;
89 static bool InSequence(const PacketIterator& it,
90 const PacketIterator& prev_it);
philipel9d3ab612015-12-21 04:12:39 -080091 size_t InsertBuffer(uint8_t* frame_buffer, PacketIterator packetIterator);
stefan@webrtc.org2ec56062014-07-31 14:59:24 +000092 size_t Insert(const uint8_t* buffer,
93 size_t length,
94 bool insert_start_code,
95 uint8_t* frame_buffer);
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +000096 void ShiftSubsequentPackets(PacketIterator it, int steps_to_shift);
97 PacketIterator FindNaluEnd(PacketIterator packet_iter) const;
98 // Deletes the data of all packets between |start| and |end|, inclusively.
99 // Note that this function doesn't delete the actual packets.
philipel9d3ab612015-12-21 04:12:39 -0800100 size_t DeletePacketData(PacketIterator start, PacketIterator end);
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +0000101 void UpdateCompleteSession();
niklase@google.com470e71d2011-07-07 08:21:25 +0000102
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +0000103 // When enabled, determine if session is decodable, i.e. incomplete but
104 // would be sent to the decoder.
agalusza@google.comd818dcb2013-07-29 21:48:11 +0000105 // Note: definition assumes random loss.
106 // A frame is defined to be decodable when:
107 // Round trip time is higher than threshold
108 // It is not a key frame
109 // It has the first packet: In VP8 the first packet contains all or part of
110 // the first partition, which consists of the most relevant information for
111 // decoding.
112 // Either more than the upper threshold of the average number of packets per
113 // frame is present
114 // or less than the lower threshold of the average number of packets per
115 // frame is present: suggests a small frame. Such a frame is unlikely
116 // to contain many motion vectors, so having the first packet will
117 // likely suffice. Once we have more than the lower threshold of the
118 // frame, we know that the frame is medium or large-sized.
119 void UpdateDecodableSession(const FrameData& frame_data);
niklase@google.com470e71d2011-07-07 08:21:25 +0000120
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +0000121 bool complete_;
122 bool decodable_;
123 webrtc::FrameType frame_type_;
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +0000124 // Packets in this frame.
125 PacketList packets_;
126 int empty_seq_num_low_;
127 int empty_seq_num_high_;
mikhal@webrtc.orgf31a47a2013-08-26 17:10:11 +0000128
129 // The following two variables correspond to the first and last media packets
130 // in a session defined by the first packet flag and the marker bit.
131 // They are not necessarily equal to the front and back packets, as packets
132 // may enter out of order.
133 // TODO(mikhal): Refactor the list to use a map.
134 int first_packet_seq_num_;
135 int last_packet_seq_num_;
niklase@google.com470e71d2011-07-07 08:21:25 +0000136};
137
stefan@webrtc.org076fa6e2011-12-13 07:54:56 +0000138} // namespace webrtc
niklase@google.com470e71d2011-07-07 08:21:25 +0000139
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200140#endif // MODULES_VIDEO_CODING_SESSION_INFO_H_