blob: 8d9a1adb0e2351e9a96d91041b66b801c7c60c22 [file] [log] [blame]
stefan@webrtc.org792f1a12015-03-04 12:24:26 +00001/*
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:26 +00009 */
10
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#ifndef CALL_BITRATE_ALLOCATOR_H_
12#define CALL_BITRATE_ALLOCATOR_H_
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000013
kwibergb25345e2016-03-12 06:10:44 -080014#include <stdint.h>
15
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000016#include <map>
Alex Narest78609d52017-10-20 10:37:47 +020017#include <memory>
Alex Narestb3944f02017-10-13 14:56:18 +020018#include <string>
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000019#include <utility>
mflodman48a4beb2016-07-01 13:03:59 +020020#include <vector>
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000021
Sebastian Jansson6736df12018-11-21 19:18:39 +010022#include "api/call/bitrate_allocation.h"
Sebastian Jansson93b1ea22019-09-18 18:31:52 +020023#include "api/transport/network_types.h"
Sebastian Janssonb55015e2019-04-09 13:44:04 +020024#include "rtc_base/synchronization/sequence_checker.h"
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000025
26namespace webrtc {
27
mflodman48a4beb2016-07-01 13:03:59 +020028class Clock;
29
mflodman86aabb22016-03-11 15:44:32 +010030// Used by all send streams with adaptive bitrate, to get the currently
31// allocated bitrate for the send stream. The current network properties are
32// given at the same time, to let the send stream decide about possible loss
33// protection.
34class BitrateAllocatorObserver {
35 public:
mflodman48a4beb2016-07-01 13:03:59 +020036 // Returns the amount of protection used by the BitrateAllocatorObserver
37 // implementation, as bitrate in bps.
Sebastian Janssonc0e4d452018-10-25 15:08:32 +020038 virtual uint32_t OnBitrateUpdated(BitrateAllocationUpdate update) = 0;
minyue78b4d562016-11-30 04:47:39 -080039
perkj71ee44c2016-06-15 00:47:53 -070040 protected:
mflodman86aabb22016-03-11 15:44:32 +010041 virtual ~BitrateAllocatorObserver() {}
42};
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000043
Sebastian Jansson24ad7202018-04-19 08:25:12 +020044// Struct describing parameters for how a media stream should get bitrate
Sebastian Jansson4d461ba2019-09-17 20:53:26 +020045// allocated to it.
46
Sebastian Jansson24ad7202018-04-19 08:25:12 +020047struct MediaStreamAllocationConfig {
Sebastian Jansson4d461ba2019-09-17 20:53:26 +020048 // Minimum bitrate supported by track. 0 equals no min bitrate.
Sebastian Jansson24ad7202018-04-19 08:25:12 +020049 uint32_t min_bitrate_bps;
Sebastian Jansson4d461ba2019-09-17 20:53:26 +020050 // Maximum bitrate supported by track. 0 equals no max bitrate.
Sebastian Jansson24ad7202018-04-19 08:25:12 +020051 uint32_t max_bitrate_bps;
52 uint32_t pad_up_bitrate_bps;
Sebastian Jansson464a5572019-02-12 13:32:32 +010053 int64_t priority_bitrate_bps;
Sebastian Jansson4d461ba2019-09-17 20:53:26 +020054 // True means track may not be paused by allocating 0 bitrate will allocate at
55 // least |min_bitrate_bps| for this observer, even if the BWE is too low,
56 // false will allocate 0 to the observer if BWE doesn't allow
57 // |min_bitrate_bps|.
Sebastian Jansson24ad7202018-04-19 08:25:12 +020058 bool enforce_min_bitrate;
Sebastian Jansson4d461ba2019-09-17 20:53:26 +020059 // The amount of bitrate allocated to this observer relative to all other
60 // observers. If an observer has twice the bitrate_priority of other
61 // observers, it should be allocated twice the bitrate above its min.
Sebastian Jansson24ad7202018-04-19 08:25:12 +020062 double bitrate_priority;
Sebastian Jansson24ad7202018-04-19 08:25:12 +020063};
64
Sebastian Jansson83267802018-04-19 08:27:19 +020065// Interface used for mocking
66class BitrateAllocatorInterface {
67 public:
68 virtual void AddObserver(BitrateAllocatorObserver* observer,
69 MediaStreamAllocationConfig config) = 0;
70 virtual void RemoveObserver(BitrateAllocatorObserver* observer) = 0;
Sebastian Jansson44a262a2018-10-24 16:07:20 +020071 virtual int GetStartBitrate(BitrateAllocatorObserver* observer) const = 0;
Sebastian Jansson83267802018-04-19 08:27:19 +020072
73 protected:
74 virtual ~BitrateAllocatorInterface() = default;
75};
76
Sebastian Jansson538ca572019-09-24 19:47:26 +020077namespace bitrate_allocator_impl {
78struct AllocatableTrack {
79 AllocatableTrack(BitrateAllocatorObserver* observer,
80 MediaStreamAllocationConfig allocation_config)
81 : observer(observer),
82 config(allocation_config),
83 allocated_bitrate_bps(-1),
84 media_ratio(1.0) {}
85 BitrateAllocatorObserver* observer;
86 MediaStreamAllocationConfig config;
87 int64_t allocated_bitrate_bps;
88 double media_ratio; // Part of the total bitrate used for media [0.0, 1.0].
89
90 uint32_t LastAllocatedBitrate() const;
91 // The minimum bitrate required by this observer, including
92 // enable-hysteresis if the observer is in a paused state.
93 uint32_t MinBitrateWithHysteresis() const;
94};
95} // namespace bitrate_allocator_impl
96
mflodman86aabb22016-03-11 15:44:32 +010097// Usage: this class will register multiple RtcpBitrateObserver's one at each
98// RTCP module. It will aggregate the results and run one bandwidth estimation
99// and push the result to the encoders via BitrateAllocatorObserver(s).
Sebastian Jansson83267802018-04-19 08:27:19 +0200100class BitrateAllocator : public BitrateAllocatorInterface {
stefan@webrtc.org792f1a12015-03-04 12:24:26 +0000101 public:
perkj71ee44c2016-06-15 00:47:53 -0700102 // Used to get notified when send stream limits such as the minimum send
103 // bitrate and max padding bitrate is changed.
104 class LimitObserver {
105 public:
Sebastian Jansson93b1ea22019-09-18 18:31:52 +0200106 virtual void OnAllocationLimitsChanged(BitrateAllocationLimits limits) = 0;
perkj71ee44c2016-06-15 00:47:53 -0700107
108 protected:
Sebastian Jansson83267802018-04-19 08:27:19 +0200109 virtual ~LimitObserver() = default;
perkj71ee44c2016-06-15 00:47:53 -0700110 };
111
Sebastian Jansson40de3cc2019-09-19 14:54:43 +0200112 explicit BitrateAllocator(LimitObserver* limit_observer);
Stefan Holmerdbdb3a02018-07-17 16:03:46 +0200113 ~BitrateAllocator() override;
stefan@webrtc.org792f1a12015-03-04 12:24:26 +0000114
Sebastian Jansson2701bc92018-12-11 15:02:47 +0100115 void UpdateStartRate(uint32_t start_rate_bps);
116
mflodman86aabb22016-03-11 15:44:32 +0100117 // Allocate target_bitrate across the registered BitrateAllocatorObservers.
Sebastian Jansson40de3cc2019-09-19 14:54:43 +0200118 void OnNetworkEstimateChanged(TargetTransferRate msg);
stefan@webrtc.org792f1a12015-03-04 12:24:26 +0000119
Sebastian Jansson29b204e2018-03-21 12:45:27 +0100120 // Set the configuration used by the bandwidth management.
Peter Boström8e4e8b02015-09-15 15:08:03 +0200121 // |observer| updates bitrates if already in use.
Sebastian Jansson24ad7202018-04-19 08:25:12 +0200122 // |config| is the configuration to use for allocation.
Sebastian Jansson4d461ba2019-09-17 20:53:26 +0200123 // Note that |observer|->OnBitrateUpdated() will be called
124 // within the scope of this method with the current rtt, fraction_loss and
125 // available bitrate and that the bitrate in OnBitrateUpdated will be zero if
126 // the |observer| is currently not allowed to send data.
perkj57c21f92016-06-17 07:27:16 -0700127 void AddObserver(BitrateAllocatorObserver* observer,
Sebastian Jansson83267802018-04-19 08:27:19 +0200128 MediaStreamAllocationConfig config) override;
stefan@webrtc.org792f1a12015-03-04 12:24:26 +0000129
mflodman101f2502016-06-09 17:21:19 +0200130 // Removes a previously added observer, but will not trigger a new bitrate
131 // allocation.
Sebastian Jansson83267802018-04-19 08:27:19 +0200132 void RemoveObserver(BitrateAllocatorObserver* observer) override;
stefan@webrtc.org792f1a12015-03-04 12:24:26 +0000133
perkj57c21f92016-06-17 07:27:16 -0700134 // Returns initial bitrate allocated for |observer|. If |observer| is not in
135 // the list of added observers, a best guess is returned.
Sebastian Jansson44a262a2018-10-24 16:07:20 +0200136 int GetStartBitrate(BitrateAllocatorObserver* observer) const override;
perkj57c21f92016-06-17 07:27:16 -0700137
mflodman2ebe5b12016-05-13 01:43:51 -0700138 private:
Sebastian Jansson538ca572019-09-24 19:47:26 +0200139 using AllocatableTrack = bitrate_allocator_impl::AllocatableTrack;
mflodman2ebe5b12016-05-13 01:43:51 -0700140
perkj71ee44c2016-06-15 00:47:53 -0700141 // Calculates the minimum requested send bitrate and max padding bitrate and
142 // calls LimitObserver::OnAllocationLimitsChanged.
Niels Möllerd4043f62018-04-26 16:06:22 +0200143 void UpdateAllocationLimits() RTC_RUN_ON(&sequenced_checker_);
perkj71ee44c2016-06-15 00:47:53 -0700144
Ying Wanga646d302018-03-02 17:04:11 +0100145 // Allow packets to be transmitted in up to 2 times max video bitrate if the
146 // bandwidth estimate allows it.
147 // TODO(bugs.webrtc.org/8541): May be worth to refactor to keep this logic in
Jonas Olsson0182a032019-07-09 12:31:20 +0200148 // video send stream.
Niels Möller74e5f802018-04-25 14:03:46 +0200149 static uint8_t GetTransmissionMaxBitrateMultiplier();
Ying Wanga646d302018-03-02 17:04:11 +0100150
Sebastian Janssonb55015e2019-04-09 13:44:04 +0200151 SequenceChecker sequenced_checker_;
danilchapa37de392017-09-09 04:17:22 -0700152 LimitObserver* const limit_observer_ RTC_GUARDED_BY(&sequenced_checker_);
Stefan Holmere5904162015-03-26 11:11:06 +0100153 // Stored in a list to keep track of the insertion order.
Sebastian Jansson4d461ba2019-09-17 20:53:26 +0200154 std::vector<AllocatableTrack> allocatable_tracks_
155 RTC_GUARDED_BY(&sequenced_checker_);
Sebastian Jansson89c94b92018-11-20 17:16:36 +0100156 uint32_t last_target_bps_ RTC_GUARDED_BY(&sequenced_checker_);
Florent Castelli4e615d52019-08-22 16:09:06 +0200157 uint32_t last_stable_target_bps_ RTC_GUARDED_BY(&sequenced_checker_);
danilchapa37de392017-09-09 04:17:22 -0700158 uint32_t last_non_zero_bitrate_bps_ RTC_GUARDED_BY(&sequenced_checker_);
159 uint8_t last_fraction_loss_ RTC_GUARDED_BY(&sequenced_checker_);
160 int64_t last_rtt_ RTC_GUARDED_BY(&sequenced_checker_);
161 int64_t last_bwe_period_ms_ RTC_GUARDED_BY(&sequenced_checker_);
mflodman48a4beb2016-07-01 13:03:59 +0200162 // Number of mute events based on too low BWE, not network up/down.
danilchapa37de392017-09-09 04:17:22 -0700163 int num_pause_events_ RTC_GUARDED_BY(&sequenced_checker_);
danilchapa37de392017-09-09 04:17:22 -0700164 int64_t last_bwe_log_time_ RTC_GUARDED_BY(&sequenced_checker_);
Sebastian Jansson93b1ea22019-09-18 18:31:52 +0200165 BitrateAllocationLimits current_limits_ RTC_GUARDED_BY(&sequenced_checker_);
stefan@webrtc.org792f1a12015-03-04 12:24:26 +0000166};
Seth Hampsonfe73d6a2017-11-14 10:49:06 -0800167
stefan@webrtc.org792f1a12015-03-04 12:24:26 +0000168} // namespace webrtc
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200169#endif // CALL_BITRATE_ALLOCATOR_H_