Add interface to signal a network down event.
- In real-time mode encoding will be paused until the network is back up. - In buffering mode the encoder will keep encoding, and packets will be buffered at the sender. When the buffer grows above the target delay encoding will be paused. - Fixes a couple of issues related to pacing which was found with the new test. - Introduces different max bitrates for pacing and for encoding. This allows the pacer to faster get rid of the queue after a network down event. (Work based on issue 1237004) BUG=1524 TESTS=trybots,vie_auto_test Review URL: https://webrtc-codereview.appspot.com/1258004 git-svn-id: http://webrtc.googlecode.com/svn/trunk@3730 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
		| @@ -94,6 +94,12 @@ VCMMediaOptimization::SetTargetRates(WebRtc_UWord32 target_bitrate, | ||||
|                                      WebRtc_UWord8 &fractionLost, | ||||
|                                      WebRtc_UWord32 roundTripTimeMs) | ||||
| { | ||||
|     // TODO(holmer): Consider putting this threshold only on the video bitrate, | ||||
|     // and not on protection. | ||||
|     if (_maxBitRate > 0 && | ||||
|         target_bitrate > static_cast<uint32_t>(_maxBitRate)) { | ||||
|       target_bitrate = _maxBitRate; | ||||
|     } | ||||
|     VCMProtectionMethod *selectedMethod = _lossProtLogic->SelectedMethod(); | ||||
|     float target_bitrate_kbps = static_cast<float>(target_bitrate) / 1000.0f; | ||||
|     _lossProtLogic->UpdateBitRate(target_bitrate_kbps); | ||||
|   | ||||
| @@ -47,50 +47,47 @@ VideoCodingModuleImpl::VideoCodingModuleImpl(const WebRtc_Word32 id, | ||||
|                                              Clock* clock, | ||||
|                                              EventFactory* event_factory, | ||||
|                                              bool owns_event_factory) | ||||
| : | ||||
| _id(id), | ||||
| clock_(clock), | ||||
| _receiveCritSect(CriticalSectionWrapper::CreateCriticalSection()), | ||||
| _receiverInited(false), | ||||
| _timing(clock_, id, 1), | ||||
| _dualTiming(clock_, id, 2, &_timing), | ||||
| _receiver(&_timing, clock_, event_factory, id, 1, true), | ||||
| _dualReceiver(&_dualTiming, clock_, event_factory, id, 2, false), | ||||
| _decodedFrameCallback(_timing, clock_), | ||||
| _dualDecodedFrameCallback(_dualTiming, clock_), | ||||
| _frameTypeCallback(NULL), | ||||
| _frameStorageCallback(NULL), | ||||
| _receiveStatsCallback(NULL), | ||||
| _packetRequestCallback(NULL), | ||||
| _decoder(NULL), | ||||
| _dualDecoder(NULL), | ||||
|     : _id(id), | ||||
|       clock_(clock), | ||||
|       _receiveCritSect(CriticalSectionWrapper::CreateCriticalSection()), | ||||
|       _receiverInited(false), | ||||
|       _timing(clock_, id, 1), | ||||
|       _dualTiming(clock_, id, 2, &_timing), | ||||
|       _receiver(&_timing, clock_, event_factory, id, 1, true), | ||||
|       _dualReceiver(&_dualTiming, clock_, event_factory, id, 2, false), | ||||
|       _decodedFrameCallback(_timing, clock_), | ||||
|       _dualDecodedFrameCallback(_dualTiming, clock_), | ||||
|       _frameTypeCallback(NULL), | ||||
|       _frameStorageCallback(NULL), | ||||
|       _receiveStatsCallback(NULL), | ||||
|       _packetRequestCallback(NULL), | ||||
|       _decoder(NULL), | ||||
|       _dualDecoder(NULL), | ||||
| #ifdef DEBUG_DECODER_BIT_STREAM | ||||
| _bitStreamBeforeDecoder(NULL), | ||||
|       _bitStreamBeforeDecoder(NULL), | ||||
| #endif | ||||
| _frameFromFile(), | ||||
| _keyRequestMode(kKeyOnError), | ||||
| _scheduleKeyRequest(false), | ||||
| max_nack_list_size_(0), | ||||
|  | ||||
| _sendCritSect(CriticalSectionWrapper::CreateCriticalSection()), | ||||
| _encoder(), | ||||
| _encodedFrameCallback(), | ||||
| _nextFrameTypes(1, kVideoFrameDelta), | ||||
| _mediaOpt(id, clock_), | ||||
| _sendCodecType(kVideoCodecUnknown), | ||||
| _sendStatsCallback(NULL), | ||||
| _encoderInputFile(NULL), | ||||
| _codecDataBase(id), | ||||
| _receiveStatsTimer(1000, clock_), | ||||
| _sendStatsTimer(1000, clock_), | ||||
| _retransmissionTimer(10, clock_), | ||||
| _keyRequestTimer(500, clock_), | ||||
| event_factory_(event_factory), | ||||
| owns_event_factory_(owns_event_factory) | ||||
| { | ||||
|     assert(clock_); | ||||
|       _frameFromFile(), | ||||
|       _keyRequestMode(kKeyOnError), | ||||
|       _scheduleKeyRequest(false), | ||||
|       max_nack_list_size_(0), | ||||
|       _sendCritSect(CriticalSectionWrapper::CreateCriticalSection()), | ||||
|       _encoder(), | ||||
|       _encodedFrameCallback(), | ||||
|       _nextFrameTypes(1, kVideoFrameDelta), | ||||
|       _mediaOpt(id, clock_), | ||||
|       _sendCodecType(kVideoCodecUnknown), | ||||
|       _sendStatsCallback(NULL), | ||||
|       _encoderInputFile(NULL), | ||||
|       _codecDataBase(id), | ||||
|       _receiveStatsTimer(1000, clock_), | ||||
|       _sendStatsTimer(1000, clock_), | ||||
|       _retransmissionTimer(10, clock_), | ||||
|       _keyRequestTimer(500, clock_), | ||||
|       event_factory_(event_factory), | ||||
|       owns_event_factory_(owns_event_factory) { | ||||
|   assert(clock_); | ||||
| #ifdef DEBUG_DECODER_BIT_STREAM | ||||
|     _bitStreamBeforeDecoder = fopen("decoderBitStream.bit", "wb"); | ||||
|   _bitStreamBeforeDecoder = fopen("decoderBitStream.bit", "wb"); | ||||
| #endif | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 stefan@webrtc.org
					stefan@webrtc.org