blob: 1c956d788b26871e3e7c72351dc43b5dedea3912 [file] [log] [blame]
sprangcd349d92016-07-13 09:11:28 -07001/*
2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
3 *
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
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#ifndef RTC_BASE_RATE_LIMITER_H_
12#define RTC_BASE_RATE_LIMITER_H_
sprangcd349d92016-07-13 09:11:28 -070013
Yves Gerey988cc082018-10-23 12:03:01 +020014#include <stddef.h>
15#include <stdint.h>
sprangcd349d92016-07-13 09:11:28 -070016
Steve Anton10542f22019-01-11 09:11:00 -080017#include "rtc_base/constructor_magic.h"
18#include "rtc_base/critical_section.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020019#include "rtc_base/rate_statistics.h"
Yves Gerey988cc082018-10-23 12:03:01 +020020#include "rtc_base/thread_annotations.h"
Henrik Kjellanderec78f1c2017-06-29 07:52:50 +020021
22namespace webrtc {
23
24class Clock;
25
26// Class used to limit a bitrate, making sure the average does not exceed a
27// maximum as measured over a sliding window. This class is thread safe; all
28// methods will acquire (the same) lock befeore executing.
29class RateLimiter {
30 public:
Sebastian Janssonaa01f272019-01-30 11:28:59 +010031 RateLimiter(Clock* clock, int64_t max_window_ms);
Henrik Kjellanderec78f1c2017-06-29 07:52:50 +020032 ~RateLimiter();
33
34 // Try to use rate to send bytes. Returns true on success and if so updates
35 // current rate.
36 bool TryUseRate(size_t packet_size_bytes);
37
38 // Set the maximum bitrate, in bps, that this limiter allows to send.
39 void SetMaxRate(uint32_t max_rate_bps);
40
41 // Set the window size over which to measure the current bitrate.
42 // For example, irt retransmissions, this is typically the RTT.
43 // Returns true on success and false if window_size_ms is out of range.
44 bool SetWindowSize(int64_t window_size_ms);
45
46 private:
Sebastian Janssonaa01f272019-01-30 11:28:59 +010047 Clock* const clock_;
Henrik Kjellanderec78f1c2017-06-29 07:52:50 +020048 rtc::CriticalSection lock_;
danilchap3c6abd22017-09-06 05:46:29 -070049 RateStatistics current_rate_ RTC_GUARDED_BY(lock_);
50 int64_t window_size_ms_ RTC_GUARDED_BY(lock_);
51 uint32_t max_rate_bps_ RTC_GUARDED_BY(lock_);
Henrik Kjellanderec78f1c2017-06-29 07:52:50 +020052
53 RTC_DISALLOW_IMPLICIT_CONSTRUCTORS(RateLimiter);
54};
55
56} // namespace webrtc
sprangcd349d92016-07-13 09:11:28 -070057
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020058#endif // RTC_BASE_RATE_LIMITER_H_