|  | /* | 
|  | *  Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. | 
|  | * | 
|  | *  Use of this source code is governed by a BSD-style license | 
|  | *  that can be found in the LICENSE file in the root of the source | 
|  | *  tree. An additional intellectual property rights grant can be found | 
|  | *  in the file PATENTS.  All contributing project authors may | 
|  | *  be found in the AUTHORS file in the root of the source tree. | 
|  | */ | 
|  |  | 
|  | #ifndef WEBRTC_MODULES_VIDEO_CODING_JITTER_BUFFER_COMMON_H_ | 
|  | #define WEBRTC_MODULES_VIDEO_CODING_JITTER_BUFFER_COMMON_H_ | 
|  |  | 
|  | #include "webrtc/typedefs.h" | 
|  |  | 
|  | namespace webrtc { | 
|  |  | 
|  | // Used to estimate rolling average of packets per frame. | 
|  | static const float kFastConvergeMultiplier = 0.4f; | 
|  | static const float kNormalConvergeMultiplier = 0.2f; | 
|  |  | 
|  | enum { kMaxNumberOfFrames = 300 }; | 
|  | enum { kStartNumberOfFrames = 6 }; | 
|  | enum { kMaxVideoDelayMs = 10000 }; | 
|  | enum { kPacketsPerFrameMultiplier = 5 }; | 
|  | enum { kFastConvergeThreshold = 5 }; | 
|  |  | 
|  | enum VCMJitterBufferEnum { | 
|  | kMaxConsecutiveOldFrames = 60, | 
|  | kMaxConsecutiveOldPackets = 300, | 
|  | // TODO(sprang): Reduce this limit once codecs don't sometimes wildly | 
|  | // overshoot bitrate target. | 
|  | kMaxPacketsInSession = 1400,      // Allows ~2MB frames. | 
|  | kBufferIncStepSizeBytes = 30000,  // >20 packets. | 
|  | kMaxJBFrameSizeBytes = 4000000    // sanity don't go above 4Mbyte. | 
|  | }; | 
|  |  | 
|  | enum VCMFrameBufferEnum { | 
|  | kOutOfBoundsPacket = -7, | 
|  | kNotInitialized = -6, | 
|  | kOldPacket = -5, | 
|  | kGeneralError = -4, | 
|  | kFlushIndicator = -3,  // Indicator that a flush has occurred. | 
|  | kTimeStampError = -2, | 
|  | kSizeError = -1, | 
|  | kNoError = 0, | 
|  | kIncomplete = 1,        // Frame incomplete. | 
|  | kCompleteSession = 3,   // at least one layer in the frame complete. | 
|  | kDecodableSession = 4,  // Frame incomplete, but ready to be decoded | 
|  | kDuplicatePacket = 5    // We're receiving a duplicate packet. | 
|  | }; | 
|  |  | 
|  | enum VCMFrameBufferStateEnum { | 
|  | kStateEmpty,       // frame popped by the RTP receiver | 
|  | kStateIncomplete,  // frame that have one or more packet(s) stored | 
|  | kStateComplete,    // frame that have all packets | 
|  | kStateDecodable    // Hybrid mode - frame can be decoded | 
|  | }; | 
|  |  | 
|  | enum { kH264StartCodeLengthBytes = 4 }; | 
|  |  | 
|  | // Used to indicate if a received packet contain a complete NALU (or equivalent) | 
|  | enum VCMNaluCompleteness { | 
|  | kNaluUnset = 0,     // Packet has not been filled. | 
|  | kNaluComplete = 1,  // Packet can be decoded as is. | 
|  | kNaluStart,         // Packet contain beginning of NALU | 
|  | kNaluIncomplete,    // Packet is not beginning or end of NALU | 
|  | kNaluEnd,           // Packet is the end of a NALU | 
|  | }; | 
|  | }  // namespace webrtc | 
|  |  | 
|  | #endif  // WEBRTC_MODULES_VIDEO_CODING_JITTER_BUFFER_COMMON_H_ |