blob: 204fc6f94d6320ddb7cc758760d31554328e1c6d [file] [log] [blame]
stefan@webrtc.org792f1a12015-03-04 12:24:261/*
2 * Copyright (c) 2015 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.
stefan@webrtc.org792f1a12015-03-04 12:24:269 */
10
Mirko Bonadei92ea95e2017-09-15 04:47:3111#ifndef CALL_BITRATE_ALLOCATOR_H_
12#define CALL_BITRATE_ALLOCATOR_H_
stefan@webrtc.org792f1a12015-03-04 12:24:2613
kwibergb25345e2016-03-12 14:10:4414#include <stdint.h>
15
stefan@webrtc.org792f1a12015-03-04 12:24:2616#include <map>
Alex Narest78609d52017-10-20 08:37:4717#include <memory>
Alex Narestb3944f02017-10-13 12:56:1818#include <string>
stefan@webrtc.org792f1a12015-03-04 12:24:2619#include <utility>
mflodman48a4beb2016-07-01 11:03:5920#include <vector>
stefan@webrtc.org792f1a12015-03-04 12:24:2621
Sebastian Jansson6736df12018-11-21 18:18:3922#include "api/call/bitrate_allocation.h"
Artem Titovd15a5752021-02-10 13:31:2423#include "api/sequence_checker.h"
Sebastian Jansson93b1ea22019-09-18 16:31:5224#include "api/transport/network_types.h"
Mirko Bonadei20e4c802020-11-23 10:07:4225#include "rtc_base/system/no_unique_address.h"
stefan@webrtc.org792f1a12015-03-04 12:24:2626
27namespace webrtc {
28
mflodman48a4beb2016-07-01 11:03:5929class Clock;
30
mflodman86aabb22016-03-11 14:44:3231// Used by all send streams with adaptive bitrate, to get the currently
32// allocated bitrate for the send stream. The current network properties are
33// given at the same time, to let the send stream decide about possible loss
34// protection.
35class BitrateAllocatorObserver {
36 public:
mflodman48a4beb2016-07-01 11:03:5937 // Returns the amount of protection used by the BitrateAllocatorObserver
38 // implementation, as bitrate in bps.
Sebastian Janssonc0e4d452018-10-25 13:08:3239 virtual uint32_t OnBitrateUpdated(BitrateAllocationUpdate update) = 0;
minyue78b4d562016-11-30 12:47:3940
perkj71ee44c2016-06-15 07:47:5341 protected:
mflodman86aabb22016-03-11 14:44:3242 virtual ~BitrateAllocatorObserver() {}
43};
stefan@webrtc.org792f1a12015-03-04 12:24:2644
Sebastian Jansson24ad7202018-04-19 06:25:1245// Struct describing parameters for how a media stream should get bitrate
Sebastian Jansson4d461ba2019-09-17 18:53:2646// allocated to it.
47
Sebastian Jansson24ad7202018-04-19 06:25:1248struct MediaStreamAllocationConfig {
Sebastian Jansson4d461ba2019-09-17 18:53:2649 // Minimum bitrate supported by track. 0 equals no min bitrate.
Sebastian Jansson24ad7202018-04-19 06:25:1250 uint32_t min_bitrate_bps;
Sebastian Jansson4d461ba2019-09-17 18:53:2651 // Maximum bitrate supported by track. 0 equals no max bitrate.
Sebastian Jansson24ad7202018-04-19 06:25:1252 uint32_t max_bitrate_bps;
53 uint32_t pad_up_bitrate_bps;
Sebastian Jansson464a5572019-02-12 12:32:3254 int64_t priority_bitrate_bps;
Sebastian Jansson4d461ba2019-09-17 18:53:2655 // True means track may not be paused by allocating 0 bitrate will allocate at
Artem Titovea240272021-07-26 10:40:2156 // least `min_bitrate_bps` for this observer, even if the BWE is too low,
Sebastian Jansson4d461ba2019-09-17 18:53:2657 // false will allocate 0 to the observer if BWE doesn't allow
Artem Titovea240272021-07-26 10:40:2158 // `min_bitrate_bps`.
Sebastian Jansson24ad7202018-04-19 06:25:1259 bool enforce_min_bitrate;
Sebastian Jansson4d461ba2019-09-17 18:53:2660 // The amount of bitrate allocated to this observer relative to all other
61 // observers. If an observer has twice the bitrate_priority of other
62 // observers, it should be allocated twice the bitrate above its min.
Sebastian Jansson24ad7202018-04-19 06:25:1263 double bitrate_priority;
Sebastian Jansson24ad7202018-04-19 06:25:1264};
65
Sebastian Jansson83267802018-04-19 06:27:1966// Interface used for mocking
67class BitrateAllocatorInterface {
68 public:
69 virtual void AddObserver(BitrateAllocatorObserver* observer,
70 MediaStreamAllocationConfig config) = 0;
71 virtual void RemoveObserver(BitrateAllocatorObserver* observer) = 0;
Sebastian Jansson44a262a2018-10-24 14:07:2072 virtual int GetStartBitrate(BitrateAllocatorObserver* observer) const = 0;
Sebastian Jansson83267802018-04-19 06:27:1973
74 protected:
75 virtual ~BitrateAllocatorInterface() = default;
76};
77
Sebastian Jansson538ca572019-09-24 17:47:2678namespace bitrate_allocator_impl {
79struct AllocatableTrack {
80 AllocatableTrack(BitrateAllocatorObserver* observer,
81 MediaStreamAllocationConfig allocation_config)
82 : observer(observer),
83 config(allocation_config),
84 allocated_bitrate_bps(-1),
85 media_ratio(1.0) {}
86 BitrateAllocatorObserver* observer;
87 MediaStreamAllocationConfig config;
88 int64_t allocated_bitrate_bps;
89 double media_ratio; // Part of the total bitrate used for media [0.0, 1.0].
90
91 uint32_t LastAllocatedBitrate() const;
92 // The minimum bitrate required by this observer, including
93 // enable-hysteresis if the observer is in a paused state.
94 uint32_t MinBitrateWithHysteresis() const;
95};
96} // namespace bitrate_allocator_impl
97
mflodman86aabb22016-03-11 14:44:3298// Usage: this class will register multiple RtcpBitrateObserver's one at each
99// RTCP module. It will aggregate the results and run one bandwidth estimation
100// and push the result to the encoders via BitrateAllocatorObserver(s).
Sebastian Jansson83267802018-04-19 06:27:19101class BitrateAllocator : public BitrateAllocatorInterface {
stefan@webrtc.org792f1a12015-03-04 12:24:26102 public:
perkj71ee44c2016-06-15 07:47:53103 // Used to get notified when send stream limits such as the minimum send
104 // bitrate and max padding bitrate is changed.
105 class LimitObserver {
106 public:
Sebastian Jansson93b1ea22019-09-18 16:31:52107 virtual void OnAllocationLimitsChanged(BitrateAllocationLimits limits) = 0;
perkj71ee44c2016-06-15 07:47:53108
109 protected:
Sebastian Jansson83267802018-04-19 06:27:19110 virtual ~LimitObserver() = default;
perkj71ee44c2016-06-15 07:47:53111 };
112
Sebastian Jansson40de3cc2019-09-19 12:54:43113 explicit BitrateAllocator(LimitObserver* limit_observer);
Stefan Holmerdbdb3a02018-07-17 14:03:46114 ~BitrateAllocator() override;
stefan@webrtc.org792f1a12015-03-04 12:24:26115
Sebastian Jansson2701bc92018-12-11 14:02:47116 void UpdateStartRate(uint32_t start_rate_bps);
117
mflodman86aabb22016-03-11 14:44:32118 // Allocate target_bitrate across the registered BitrateAllocatorObservers.
Sebastian Jansson40de3cc2019-09-19 12:54:43119 void OnNetworkEstimateChanged(TargetTransferRate msg);
stefan@webrtc.org792f1a12015-03-04 12:24:26120
Sebastian Jansson29b204e2018-03-21 11:45:27121 // Set the configuration used by the bandwidth management.
Artem Titovea240272021-07-26 10:40:21122 // `observer` updates bitrates if already in use.
123 // `config` is the configuration to use for allocation.
124 // Note that `observer`->OnBitrateUpdated() will be called
Sebastian Jansson4d461ba2019-09-17 18:53:26125 // within the scope of this method with the current rtt, fraction_loss and
126 // available bitrate and that the bitrate in OnBitrateUpdated will be zero if
Artem Titovea240272021-07-26 10:40:21127 // the `observer` is currently not allowed to send data.
perkj57c21f92016-06-17 14:27:16128 void AddObserver(BitrateAllocatorObserver* observer,
Sebastian Jansson83267802018-04-19 06:27:19129 MediaStreamAllocationConfig config) override;
stefan@webrtc.org792f1a12015-03-04 12:24:26130
mflodman101f2502016-06-09 15:21:19131 // Removes a previously added observer, but will not trigger a new bitrate
132 // allocation.
Sebastian Jansson83267802018-04-19 06:27:19133 void RemoveObserver(BitrateAllocatorObserver* observer) override;
stefan@webrtc.org792f1a12015-03-04 12:24:26134
Artem Titovea240272021-07-26 10:40:21135 // Returns initial bitrate allocated for `observer`. If `observer` is not in
perkj57c21f92016-06-17 14:27:16136 // the list of added observers, a best guess is returned.
Sebastian Jansson44a262a2018-10-24 14:07:20137 int GetStartBitrate(BitrateAllocatorObserver* observer) const override;
perkj57c21f92016-06-17 14:27:16138
mflodman2ebe5b12016-05-13 08:43:51139 private:
Sebastian Jansson538ca572019-09-24 17:47:26140 using AllocatableTrack = bitrate_allocator_impl::AllocatableTrack;
mflodman2ebe5b12016-05-13 08:43:51141
perkj71ee44c2016-06-15 07:47:53142 // Calculates the minimum requested send bitrate and max padding bitrate and
143 // calls LimitObserver::OnAllocationLimitsChanged.
Niels Möllerd4043f62018-04-26 14:06:22144 void UpdateAllocationLimits() RTC_RUN_ON(&sequenced_checker_);
perkj71ee44c2016-06-15 07:47:53145
Ying Wanga646d302018-03-02 16:04:11146 // Allow packets to be transmitted in up to 2 times max video bitrate if the
147 // bandwidth estimate allows it.
148 // TODO(bugs.webrtc.org/8541): May be worth to refactor to keep this logic in
Jonas Olsson0182a032019-07-09 10:31:20149 // video send stream.
Niels Möller74e5f802018-04-25 12:03:46150 static uint8_t GetTransmissionMaxBitrateMultiplier();
Ying Wanga646d302018-03-02 16:04:11151
Mirko Bonadei20e4c802020-11-23 10:07:42152 RTC_NO_UNIQUE_ADDRESS SequenceChecker sequenced_checker_;
danilchapa37de392017-09-09 11:17:22153 LimitObserver* const limit_observer_ RTC_GUARDED_BY(&sequenced_checker_);
Stefan Holmere5904162015-03-26 10:11:06154 // Stored in a list to keep track of the insertion order.
Sebastian Jansson4d461ba2019-09-17 18:53:26155 std::vector<AllocatableTrack> allocatable_tracks_
156 RTC_GUARDED_BY(&sequenced_checker_);
Sebastian Jansson89c94b92018-11-20 16:16:36157 uint32_t last_target_bps_ RTC_GUARDED_BY(&sequenced_checker_);
Florent Castelli4e615d52019-08-22 14:09:06158 uint32_t last_stable_target_bps_ RTC_GUARDED_BY(&sequenced_checker_);
danilchapa37de392017-09-09 11:17:22159 uint32_t last_non_zero_bitrate_bps_ RTC_GUARDED_BY(&sequenced_checker_);
160 uint8_t last_fraction_loss_ RTC_GUARDED_BY(&sequenced_checker_);
161 int64_t last_rtt_ RTC_GUARDED_BY(&sequenced_checker_);
162 int64_t last_bwe_period_ms_ RTC_GUARDED_BY(&sequenced_checker_);
mflodman48a4beb2016-07-01 11:03:59163 // Number of mute events based on too low BWE, not network up/down.
danilchapa37de392017-09-09 11:17:22164 int num_pause_events_ RTC_GUARDED_BY(&sequenced_checker_);
danilchapa37de392017-09-09 11:17:22165 int64_t last_bwe_log_time_ RTC_GUARDED_BY(&sequenced_checker_);
Sebastian Jansson93b1ea22019-09-18 16:31:52166 BitrateAllocationLimits current_limits_ RTC_GUARDED_BY(&sequenced_checker_);
stefan@webrtc.org792f1a12015-03-04 12:24:26167};
Seth Hampsonfe73d6a2017-11-14 18:49:06168
stefan@webrtc.org792f1a12015-03-04 12:24:26169} // namespace webrtc
Mirko Bonadei92ea95e2017-09-15 04:47:31170#endif // CALL_BITRATE_ALLOCATOR_H_