OLD | NEW |
| (Empty) |
1 /* | |
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 | |
11 #ifndef WEBRTC_MODULES_VIDEO_CODING_DECODING_STATE_H_ | |
12 #define WEBRTC_MODULES_VIDEO_CODING_DECODING_STATE_H_ | |
13 | |
14 #include "webrtc/typedefs.h" | |
15 | |
16 namespace webrtc { | |
17 | |
18 // Forward declarations | |
19 class VCMFrameBuffer; | |
20 class VCMPacket; | |
21 | |
22 class VCMDecodingState { | |
23 public: | |
24 // The max number of bits used to reference back | |
25 // to a previous frame when using flexible mode. | |
26 static const uint16_t kNumRefBits = 7; | |
27 static const uint16_t kFrameDecodedLength = 1 << kNumRefBits; | |
28 | |
29 VCMDecodingState(); | |
30 ~VCMDecodingState(); | |
31 // Check for old frame | |
32 bool IsOldFrame(const VCMFrameBuffer* frame) const; | |
33 // Check for old packet | |
34 bool IsOldPacket(const VCMPacket* packet) const; | |
35 // Check for frame continuity based on current decoded state. Use best method | |
36 // possible, i.e. temporal info, picture ID or sequence number. | |
37 bool ContinuousFrame(const VCMFrameBuffer* frame) const; | |
38 void SetState(const VCMFrameBuffer* frame); | |
39 void CopyFrom(const VCMDecodingState& state); | |
40 bool UpdateEmptyFrame(const VCMFrameBuffer* frame); | |
41 // Update the sequence number if the timestamp matches current state and the | |
42 // sequence number is higher than the current one. This accounts for packets | |
43 // arriving late. | |
44 void UpdateOldPacket(const VCMPacket* packet); | |
45 void SetSeqNum(uint16_t new_seq_num); | |
46 void Reset(); | |
47 uint32_t time_stamp() const; | |
48 uint16_t sequence_num() const; | |
49 // Return true if at initial state. | |
50 bool in_initial_state() const; | |
51 // Return true when sync is on - decode all layers. | |
52 bool full_sync() const; | |
53 | |
54 private: | |
55 void UpdateSyncState(const VCMFrameBuffer* frame); | |
56 // Designated continuity functions | |
57 bool ContinuousPictureId(int picture_id) const; | |
58 bool ContinuousSeqNum(uint16_t seq_num) const; | |
59 bool ContinuousLayer(int temporal_id, int tl0_pic_id) const; | |
60 bool ContinuousFrameRefs(const VCMFrameBuffer* frame) const; | |
61 bool UsingPictureId(const VCMFrameBuffer* frame) const; | |
62 bool UsingFlexibleMode(const VCMFrameBuffer* frame) const; | |
63 bool AheadOfFramesDecodedClearedTo(uint16_t index) const; | |
64 | |
65 // Keep state of last decoded frame. | |
66 // TODO(mikhal/stefan): create designated classes to handle these types. | |
67 uint16_t sequence_num_; | |
68 uint32_t time_stamp_; | |
69 int picture_id_; | |
70 int temporal_id_; | |
71 int tl0_pic_id_; | |
72 bool full_sync_; // Sync flag when temporal layers are used. | |
73 bool in_initial_state_; | |
74 | |
75 // Used to check references in flexible mode. | |
76 bool frame_decoded_[kFrameDecodedLength]; | |
77 uint16_t frame_decoded_cleared_to_; | |
78 }; | |
79 | |
80 } // namespace webrtc | |
81 | |
82 #endif // WEBRTC_MODULES_VIDEO_CODING_DECODING_STATE_H_ | |
OLD | NEW |