1*d9f75844SAndroid Build Coastguard Worker /* 2*d9f75844SAndroid Build Coastguard Worker * Copyright (c) 2021 The WebRTC project authors. All Rights Reserved. 3*d9f75844SAndroid Build Coastguard Worker * 4*d9f75844SAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license 5*d9f75844SAndroid Build Coastguard Worker * that can be found in the LICENSE file in the root of the source 6*d9f75844SAndroid Build Coastguard Worker * tree. An additional intellectual property rights grant can be found 7*d9f75844SAndroid Build Coastguard Worker * in the file PATENTS. All contributing project authors may 8*d9f75844SAndroid Build Coastguard Worker * be found in the AUTHORS file in the root of the source tree. 9*d9f75844SAndroid Build Coastguard Worker */ 10*d9f75844SAndroid Build Coastguard Worker #ifndef MODULES_CONGESTION_CONTROLLER_REMB_THROTTLER_H_ 11*d9f75844SAndroid Build Coastguard Worker #define MODULES_CONGESTION_CONTROLLER_REMB_THROTTLER_H_ 12*d9f75844SAndroid Build Coastguard Worker 13*d9f75844SAndroid Build Coastguard Worker #include <functional> 14*d9f75844SAndroid Build Coastguard Worker #include <vector> 15*d9f75844SAndroid Build Coastguard Worker 16*d9f75844SAndroid Build Coastguard Worker #include "api/units/data_rate.h" 17*d9f75844SAndroid Build Coastguard Worker #include "api/units/time_delta.h" 18*d9f75844SAndroid Build Coastguard Worker #include "api/units/timestamp.h" 19*d9f75844SAndroid Build Coastguard Worker #include "modules/remote_bitrate_estimator/include/remote_bitrate_estimator.h" 20*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/synchronization/mutex.h" 21*d9f75844SAndroid Build Coastguard Worker 22*d9f75844SAndroid Build Coastguard Worker namespace webrtc { 23*d9f75844SAndroid Build Coastguard Worker 24*d9f75844SAndroid Build Coastguard Worker // RembThrottler is a helper class used for throttling RTCP REMB messages. 25*d9f75844SAndroid Build Coastguard Worker // Throttles small changes to the received BWE within 200ms. 26*d9f75844SAndroid Build Coastguard Worker class RembThrottler : public RemoteBitrateObserver { 27*d9f75844SAndroid Build Coastguard Worker public: 28*d9f75844SAndroid Build Coastguard Worker using RembSender = 29*d9f75844SAndroid Build Coastguard Worker std::function<void(int64_t bitrate_bps, std::vector<uint32_t> ssrcs)>; 30*d9f75844SAndroid Build Coastguard Worker RembThrottler(RembSender remb_sender, Clock* clock); 31*d9f75844SAndroid Build Coastguard Worker 32*d9f75844SAndroid Build Coastguard Worker // Ensures the remote party is notified of the receive bitrate no larger than 33*d9f75844SAndroid Build Coastguard Worker // `bitrate` using RTCP REMB. 34*d9f75844SAndroid Build Coastguard Worker void SetMaxDesiredReceiveBitrate(DataRate bitrate); 35*d9f75844SAndroid Build Coastguard Worker 36*d9f75844SAndroid Build Coastguard Worker // Implements RemoteBitrateObserver; 37*d9f75844SAndroid Build Coastguard Worker // Called every time there is a new bitrate estimate for a receive channel 38*d9f75844SAndroid Build Coastguard Worker // group. This call will trigger a new RTCP REMB packet if the bitrate 39*d9f75844SAndroid Build Coastguard Worker // estimate has decreased or if no RTCP REMB packet has been sent for 40*d9f75844SAndroid Build Coastguard Worker // a certain time interval. 41*d9f75844SAndroid Build Coastguard Worker void OnReceiveBitrateChanged(const std::vector<uint32_t>& ssrcs, 42*d9f75844SAndroid Build Coastguard Worker uint32_t bitrate_bps) override; 43*d9f75844SAndroid Build Coastguard Worker 44*d9f75844SAndroid Build Coastguard Worker private: 45*d9f75844SAndroid Build Coastguard Worker const RembSender remb_sender_; 46*d9f75844SAndroid Build Coastguard Worker Clock* const clock_; 47*d9f75844SAndroid Build Coastguard Worker mutable Mutex mutex_; 48*d9f75844SAndroid Build Coastguard Worker Timestamp last_remb_time_ RTC_GUARDED_BY(mutex_); 49*d9f75844SAndroid Build Coastguard Worker DataRate last_send_remb_bitrate_ RTC_GUARDED_BY(mutex_); 50*d9f75844SAndroid Build Coastguard Worker DataRate max_remb_bitrate_ RTC_GUARDED_BY(mutex_); 51*d9f75844SAndroid Build Coastguard Worker }; 52*d9f75844SAndroid Build Coastguard Worker 53*d9f75844SAndroid Build Coastguard Worker } // namespace webrtc 54*d9f75844SAndroid Build Coastguard Worker #endif // MODULES_CONGESTION_CONTROLLER_REMB_THROTTLER_H_ 55