Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(45)

Side by Side Diff: webrtc/media/engine/webrtcvoiceengine.cc

Issue 1813763005: Updated structures and functions for setting the max bitrate limit to take rtc::Optional<int> Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Code review feedback Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2004 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2004 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 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 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 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
(...skipping 1400 matching lines...) Expand 10 before | Expand all | Expand 10 after
1411 std::vector<webrtc::RtpExtension> filtered_extensions = 1411 std::vector<webrtc::RtpExtension> filtered_extensions =
1412 FilterRtpExtensions(params.extensions, 1412 FilterRtpExtensions(params.extensions,
1413 webrtc::RtpExtension::IsSupportedForAudio, true); 1413 webrtc::RtpExtension::IsSupportedForAudio, true);
1414 if (send_rtp_extensions_ != filtered_extensions) { 1414 if (send_rtp_extensions_ != filtered_extensions) {
1415 send_rtp_extensions_.swap(filtered_extensions); 1415 send_rtp_extensions_.swap(filtered_extensions);
1416 for (auto& it : send_streams_) { 1416 for (auto& it : send_streams_) {
1417 it.second->RecreateAudioSendStream(send_rtp_extensions_); 1417 it.second->RecreateAudioSendStream(send_rtp_extensions_);
1418 } 1418 }
1419 } 1419 }
1420 1420
1421 if (!SetMaxSendBandwidth(params.max_bandwidth_bps)) { 1421 if (!SetMaxSendBitrate(params.max_bitrate_bps)) {
1422 return false; 1422 return false;
1423 } 1423 }
1424 return SetOptions(params.options); 1424 return SetOptions(params.options);
1425 } 1425 }
1426 1426
1427 bool WebRtcVoiceMediaChannel::SetRecvParameters( 1427 bool WebRtcVoiceMediaChannel::SetRecvParameters(
1428 const AudioRecvParameters& params) { 1428 const AudioRecvParameters& params) {
1429 TRACE_EVENT0("webrtc", "WebRtcVoiceMediaChannel::SetRecvParameters"); 1429 TRACE_EVENT0("webrtc", "WebRtcVoiceMediaChannel::SetRecvParameters");
1430 RTC_DCHECK(worker_thread_checker_.CalledOnValidThread()); 1430 RTC_DCHECK(worker_thread_checker_.CalledOnValidThread());
1431 LOG(LS_INFO) << "WebRtcVoiceMediaChannel::SetRecvParameters: " 1431 LOG(LS_INFO) << "WebRtcVoiceMediaChannel::SetRecvParameters: "
(...skipping 303 matching lines...) Expand 10 before | Expand all | Expand 10 after
1735 << channel; 1735 << channel;
1736 if (engine()->voe()->codec()->SetOpusMaxPlaybackRate( 1736 if (engine()->voe()->codec()->SetOpusMaxPlaybackRate(
1737 channel, send_codec_spec_.opus_max_playback_rate) == -1) { 1737 channel, send_codec_spec_.opus_max_playback_rate) == -1) {
1738 LOG_RTCERR2(SetOpusMaxPlaybackRate, channel, 1738 LOG_RTCERR2(SetOpusMaxPlaybackRate, channel,
1739 send_codec_spec_.opus_max_playback_rate); 1739 send_codec_spec_.opus_max_playback_rate);
1740 return false; 1740 return false;
1741 } 1741 }
1742 } 1742 }
1743 } 1743 }
1744 1744
1745 if (send_bitrate_setting_) { 1745 if (send_bitrate_bps_) {
1746 SetSendBitrateInternal(send_bitrate_bps_); 1746 SetSendBitrateInternal(send_bitrate_bps_);
1747 } 1747 }
1748 1748
1749 // Set the CN payloadtype and the VAD status. 1749 // Set the CN payloadtype and the VAD status.
1750 if (send_codec_spec_.cng_payload_type != -1) { 1750 if (send_codec_spec_.cng_payload_type != -1) {
1751 // The CN payload type for 8000 Hz clockrate is fixed at 13. 1751 // The CN payload type for 8000 Hz clockrate is fixed at 13.
1752 if (send_codec_spec_.cng_plfreq != 8000) { 1752 if (send_codec_spec_.cng_plfreq != 8000) {
1753 webrtc::PayloadFrequencies cn_freq; 1753 webrtc::PayloadFrequencies cn_freq;
1754 switch (send_codec_spec_.cng_plfreq) { 1754 switch (send_codec_spec_.cng_plfreq) {
1755 case 16000: 1755 case 16000:
(...skipping 606 matching lines...) Expand 10 before | Expand all | Expand 10 after
2362 } 2362 }
2363 } 2363 }
2364 2364
2365 webrtc::AudioProcessing* ap = engine()->voe()->base()->audio_processing(); 2365 webrtc::AudioProcessing* ap = engine()->voe()->base()->audio_processing();
2366 if (ap) { 2366 if (ap) {
2367 ap->set_output_will_be_muted(all_muted); 2367 ap->set_output_will_be_muted(all_muted);
2368 } 2368 }
2369 return true; 2369 return true;
2370 } 2370 }
2371 2371
2372 // TODO(minyue): SetMaxSendBandwidth() is subject to be renamed to 2372 bool WebRtcVoiceMediaChannel::SetMaxSendBitrate(rtc::Optional<int> bps) {
2373 // SetMaxSendBitrate() in future. 2373 RTC_DCHECK(worker_thread_checker_.CalledOnValidThread());
2374 bool WebRtcVoiceMediaChannel::SetMaxSendBandwidth(int bps) {
2375 LOG(LS_INFO) << "WebRtcVoiceMediaChannel::SetMaxSendBandwidth."; 2374 LOG(LS_INFO) << "WebRtcVoiceMediaChannel::SetMaxSendBandwidth.";
2376 return SetSendBitrateInternal(bps); 2375 return SetSendBitrateInternal(bps);
2377 } 2376 }
2378 2377
2379 bool WebRtcVoiceMediaChannel::SetSendBitrateInternal(int bps) { 2378 bool WebRtcVoiceMediaChannel::SetSendBitrateInternal(rtc::Optional<int> bps) {
2380 LOG(LS_INFO) << "WebRtcVoiceMediaChannel::SetSendBitrateInternal."; 2379 LOG(LS_INFO) << "WebRtcVoiceMediaChannel::SetSendBitrateInternal.";
2381
2382 send_bitrate_setting_ = true;
2383 send_bitrate_bps_ = bps; 2380 send_bitrate_bps_ = bps;
2384 2381
2385 if (!HasSendCodec()) { 2382 if (!HasSendCodec()) {
2386 LOG(LS_INFO) << "The send codec has not been set up yet. " 2383 LOG(LS_INFO) << "The send codec has not been set up yet. "
2387 << "The send bitrate setting will be applied later."; 2384 << "The send bitrate setting will be applied later.";
2388 return true; 2385 return true;
2389 } 2386 }
2390 2387
2391 // Bitrate is auto by default. 2388 // Bitrate is auto by default.
2392 // TODO(bemasc): Fix this so that if SetMaxSendBandwidth(50) is followed by 2389 // TODO(bemasc): Fix this so that if SetMaxSendBandwidth(50) is followed by
2393 // SetMaxSendBandwith(0), the second call removes the previous limit. 2390 // SetMaxSendBandwith(0), the second call removes the previous limit.
2394 if (bps <= 0) 2391 if (!bps) {
2395 return true; 2392 return true;
2393 }
2396 2394
2397 webrtc::CodecInst codec = send_codec_spec_.codec_inst; 2395 webrtc::CodecInst codec = send_codec_spec_.codec_inst;
2398 bool is_multi_rate = WebRtcVoiceCodecs::IsCodecMultiRate(codec); 2396 bool is_multi_rate = WebRtcVoiceCodecs::IsCodecMultiRate(codec);
2399 2397
2400 if (is_multi_rate) { 2398 if (is_multi_rate) {
2401 // If codec is multi-rate then just set the bitrate. 2399 // If codec is multi-rate then just set the bitrate.
2402 codec.rate = bps; 2400 codec.rate = *bps;
2403 for (const auto& ch : send_streams_) { 2401 for (const auto& ch : send_streams_) {
2404 if (!SetSendCodec(ch.second->channel(), codec)) { 2402 if (!SetSendCodec(ch.second->channel(), codec)) {
2405 LOG(LS_INFO) << "Failed to set codec " << codec.plname 2403 LOG(LS_INFO) << "Failed to set codec " << codec.plname
2406 << " to bitrate " << bps << " bps."; 2404 << " to bitrate " << bps << " bps.";
2407 return false; 2405 return false;
2408 } 2406 }
2409 } 2407 }
2410 return true; 2408 return true;
2411 } else { 2409 } else {
2412 // If codec is not multi-rate and |bps| is less than the fixed bitrate 2410 // If codec is not multi-rate and |bps| is less than the fixed bitrate
2413 // then fail. If codec is not multi-rate and |bps| exceeds or equal the 2411 // then fail. If codec is not multi-rate and |bps| exceeds or equal the
2414 // fixed bitrate then ignore. 2412 // fixed bitrate then ignore.
2415 if (bps < codec.rate) { 2413 if (*bps < codec.rate) {
2416 LOG(LS_INFO) << "Failed to set codec " << codec.plname 2414 LOG(LS_INFO) << "Failed to set codec " << codec.plname
2417 << " to bitrate " << bps << " bps" 2415 << " to bitrate " << bps << " bps"
2418 << ", requires at least " << codec.rate << " bps."; 2416 << ", requires at least " << codec.rate << " bps.";
2419 return false; 2417 return false;
2420 } 2418 }
2421 return true; 2419 return true;
2422 } 2420 }
2423 } 2421 }
2424 2422
2425 void WebRtcVoiceMediaChannel::OnReadyToSend(bool ready) { 2423 void WebRtcVoiceMediaChannel::OnReadyToSend(bool ready) {
(...skipping 125 matching lines...) Expand 10 before | Expand all | Expand 10 after
2551 } 2549 }
2552 } else { 2550 } else {
2553 LOG(LS_INFO) << "Stopping playout for channel #" << channel; 2551 LOG(LS_INFO) << "Stopping playout for channel #" << channel;
2554 engine()->voe()->base()->StopPlayout(channel); 2552 engine()->voe()->base()->StopPlayout(channel);
2555 } 2553 }
2556 return true; 2554 return true;
2557 } 2555 }
2558 } // namespace cricket 2556 } // namespace cricket
2559 2557
2560 #endif // HAVE_WEBRTC_VOICE 2558 #endif // HAVE_WEBRTC_VOICE
OLDNEW
« no previous file with comments | « webrtc/media/engine/webrtcvoiceengine.h ('k') | webrtc/media/engine/webrtcvoiceengine_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698