Update all child modules of with received bandwidth estimate.
BUG=224 Review URL: http://webrtc-codereview.appspot.com/347007 git-svn-id: http://webrtc.googlecode.com/svn/trunk@1391 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
		| @@ -2650,8 +2650,9 @@ void ModuleRtpRtcpImpl::OnReceivedIntraFrameRequest(const RtpRtcp* caller) { | ||||
| void ModuleRtpRtcpImpl::OnReceivedEstimatedMaxBitrate( | ||||
|     const WebRtc_UWord32 maxBitrate) { | ||||
|  | ||||
|     // We received a REMB | ||||
|   // We received a REMB. | ||||
|   if (_defaultModule) { | ||||
|     // Let the default module handle this. | ||||
|     CriticalSectionScoped lock(_criticalSectionModulePtrs); | ||||
|     if (_defaultModule) { | ||||
|       // if we use a default module pass this info to the default module | ||||
| @@ -2667,29 +2668,25 @@ void ModuleRtpRtcpImpl::OnReceivedEstimatedMaxBitrate( | ||||
|                                                    &newBitrate, | ||||
|                                                    &fractionLost, | ||||
|                                                    &roundTripTime) == 0) { | ||||
|       // TODO(mflodman) When encoding two streams, we need to split the bitrate | ||||
|       // between REMB sending channels. | ||||
|       // might trigger a OnNetworkChanged in video callback | ||||
|     // TODO(mflodman) When encoding two streams, we need to split the | ||||
|     // bitrate between REMB sending channels. | ||||
|     _rtpReceiver.UpdateBandwidthManagement(newBitrate, | ||||
|                                            fractionLost, | ||||
|                                            roundTripTime); | ||||
|         if (newBitrate <= 0) { | ||||
|             return; | ||||
|         } | ||||
|         const bool defaultInstance = !_childModules.empty(); | ||||
|         if (!defaultInstance) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|     // We've received a new bandwidth estimate lower than the current send | ||||
|     // bitrate. For simulcast we need to update the sending bitrate for all | ||||
|     // streams. | ||||
|     if (_simulcast) { | ||||
|       CriticalSectionScoped lock(_criticalSectionModulePtrsFeedback); | ||||
|         std::list<ModuleRtpRtcpImpl*>::iterator it = _childModules.begin(); | ||||
|       WebRtc_UWord8 idx = 0; | ||||
|         while (it != _childModules.end()) { | ||||
|       for (std::list<ModuleRtpRtcpImpl*>::iterator it = _childModules.begin(); | ||||
|            it != _childModules.end(); ++it) { | ||||
|         // sanity | ||||
|         if (idx >= (_sendVideoCodec.numberOfSimulcastStreams - 1)) { | ||||
|           return; | ||||
|         } | ||||
|         ModuleRtpRtcpImpl* module = *it; | ||||
|             // update all child modules | ||||
|         if (newBitrate >= _sendVideoCodec.simulcastStream[idx].maxBitrate) { | ||||
|           module->_bandwidthManagement.SetSendBitrate( | ||||
|               _sendVideoCodec.simulcastStream[idx].maxBitrate, 0, 0); | ||||
| @@ -2706,6 +2703,28 @@ void ModuleRtpRtcpImpl::OnReceivedEstimatedMaxBitrate( | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   // For non-simulcast, update all child modules with the new bandwidth estimate | ||||
|   // regardless of the new estimate. | ||||
|   if (!_simulcast) { | ||||
|     // Update all child modules with the new max bitrate before exiting. | ||||
|     CriticalSectionScoped lock(_criticalSectionModulePtrsFeedback); | ||||
|     for (std::list<ModuleRtpRtcpImpl*>::iterator it = _childModules.begin(); | ||||
|         it != _childModules.end(); ++it) { | ||||
|       // Update all child modules with the maximum bitrate estimate. | ||||
|       ModuleRtpRtcpImpl* module = *it; | ||||
|       WebRtc_UWord32 ignoreBitrate = 0; | ||||
|       WebRtc_UWord8 ignoreFractionLost = 0; | ||||
|       WebRtc_UWord16 ignoreRoundTripTime = 0; | ||||
|       module->_bandwidthManagement.UpdateBandwidthEstimate( | ||||
|           bwEstimateKbit, | ||||
|           &ignoreBitrate, | ||||
|           &ignoreFractionLost, | ||||
|           &ignoreRoundTripTime); | ||||
|       // We don't need to take care of a possible lowered bitrate, that is | ||||
|       // handled earlier in this function for the default module. | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| // received a request for a new SLI | ||||
| void ModuleRtpRtcpImpl::OnReceivedSliceLossIndication( | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 mflodman@webrtc.org
					mflodman@webrtc.org