• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  *  Copyright (c) 2012 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 #ifndef WEBRTC_MODULES_VIDEO_CODING_MAIN_SOURCE_FRAME_BUFFER_H_
12 #define WEBRTC_MODULES_VIDEO_CODING_MAIN_SOURCE_FRAME_BUFFER_H_
13 
14 #include "webrtc/modules/interface/module_common_types.h"
15 #include "webrtc/modules/video_coding/main/interface/video_coding.h"
16 #include "webrtc/modules/video_coding/main/source/encoded_frame.h"
17 #include "webrtc/modules/video_coding/main/source/jitter_buffer_common.h"
18 #include "webrtc/modules/video_coding/main/source/session_info.h"
19 #include "webrtc/typedefs.h"
20 
21 namespace webrtc {
22 
23 class VCMFrameBuffer : public VCMEncodedFrame {
24  public:
25   VCMFrameBuffer();
26   virtual ~VCMFrameBuffer();
27 
28   VCMFrameBuffer(const VCMFrameBuffer& rhs);
29 
30   virtual void Reset();
31 
32   VCMFrameBufferEnum InsertPacket(const VCMPacket& packet,
33                                   int64_t timeInMs,
34                                   VCMDecodeErrorMode decode_error_mode,
35                                   const FrameData& frame_data);
36 
37   // State
38   // Get current state of frame
39   VCMFrameBufferStateEnum GetState() const;
40   // Get current state and timestamp of frame
41   VCMFrameBufferStateEnum GetState(uint32_t& timeStamp) const;
42   void PrepareForDecode(bool continuous);
43 
44   bool IsRetransmitted() const;
45   bool IsSessionComplete() const;
46   bool HaveFirstPacket() const;
47   bool HaveLastPacket() const;
48   int NumPackets() const;
49   // Makes sure the session contain a decodable stream.
50   void MakeSessionDecodable();
51 
52   // Sequence numbers
53   // Get lowest packet sequence number in frame
54   int32_t GetLowSeqNum() const;
55   // Get highest packet sequence number in frame
56   int32_t GetHighSeqNum() const;
57 
58   int PictureId() const;
59   int TemporalId() const;
60   bool LayerSync() const;
61   int Tl0PicId() const;
62   bool NonReference() const;
63 
64   // Set counted status (as counted by JB or not)
65   void SetCountedFrame(bool frameCounted);
66   bool GetCountedFrame() const;
67 
68   // Increments a counter to keep track of the number of packets of this frame
69   // which were NACKed before they arrived.
70   void IncrementNackCount();
71   // Returns the number of packets of this frame which were NACKed before they
72   // arrived.
73   int16_t GetNackCount() const;
74 
75   int64_t LatestPacketTimeMs() const;
76 
77   webrtc::FrameType FrameType() const;
78   void SetPreviousFrameLoss();
79 
80   // The number of packets discarded because the decoder can't make use of
81   // them.
82   int NotDecodablePackets() const;
83 
84  private:
85   void SetState(VCMFrameBufferStateEnum state);  // Set state of frame
86 
87   VCMFrameBufferStateEnum    _state;         // Current state of the frame
88   bool                       _frameCounted;  // Was this frame counted by JB?
89   VCMSessionInfo             _sessionInfo;
90   uint16_t             _nackCount;
91   int64_t              _latestPacketTimeMs;
92 };
93 
94 }  // namespace webrtc
95 
96 #endif  // WEBRTC_MODULES_VIDEO_CODING_MAIN_SOURCE_FRAME_BUFFER_H_
97