blob: 5028e124bdfc0f1463669d6e665587182948f816 [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.
9 *
10 * Usage: this class will register multiple RtcpBitrateObserver's one at each
11 * RTCP module. It will aggregate the results and run one bandwidth estimation
12 * and push the result to the encoders via BitrateObserver(s).
13 */
14
mflodman0e7e2592015-11-12 21:02:42 -080015#ifndef WEBRTC_CALL_BITRATE_ALLOCATOR_H_
16#define WEBRTC_CALL_BITRATE_ALLOCATOR_H_
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000017
18#include <list>
19#include <map>
20#include <utility>
21
tommi63cb4342016-01-20 02:32:54 -080022#include "webrtc/base/criticalsection.h"
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000023#include "webrtc/base/scoped_ptr.h"
24#include "webrtc/base/thread_annotations.h"
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000025
26namespace webrtc {
27
28class BitrateObserver;
29
30class BitrateAllocator {
31 public:
32 BitrateAllocator();
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000033
sprang2f48d942015-11-05 04:25:49 -080034 // Allocate target_bitrate across the registered BitrateObservers.
35 // Returns actual bitrate allocated (might be higher than target_bitrate if
36 // for instance EnforceMinBitrate() is enabled.
37 uint32_t OnNetworkChanged(uint32_t target_bitrate,
38 uint8_t fraction_loss,
39 int64_t rtt);
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000040
41 // Set the start and max send bitrate used by the bandwidth management.
42 //
Peter Boström8e4e8b02015-09-15 15:08:03 +020043 // |observer| updates bitrates if already in use.
44 // |min_bitrate_bps| = 0 equals no min bitrate.
45 // |max_bitrate_bps| = 0 equals no max bitrate.
46 // Returns bitrate allocated for the bitrate observer.
Stefan Holmere5904162015-03-26 11:11:06 +010047 int AddBitrateObserver(BitrateObserver* observer,
Stefan Holmere5904162015-03-26 11:11:06 +010048 uint32_t min_bitrate_bps,
Peter Boström8e4e8b02015-09-15 15:08:03 +020049 uint32_t max_bitrate_bps);
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000050
Stefan Holmere5904162015-03-26 11:11:06 +010051 void RemoveBitrateObserver(BitrateObserver* observer);
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000052
53 void GetMinMaxBitrateSumBps(int* min_bitrate_sum_bps,
54 int* max_bitrate_sum_bps) const;
55
56 // This method controls the behavior when the available bitrate is lower than
57 // the minimum bitrate, or the sum of minimum bitrates.
58 // When true, the bitrate will never be set lower than the minimum bitrate(s).
59 // When false, the bitrate observers will be allocated rates up to their
60 // respective minimum bitrate, satisfying one observer after the other.
61 void EnforceMinBitrate(bool enforce_min_bitrate);
62
63 private:
64 struct BitrateConfiguration {
Peter Boström8e4e8b02015-09-15 15:08:03 +020065 BitrateConfiguration(uint32_t min_bitrate, uint32_t max_bitrate)
66 : min_bitrate(min_bitrate), max_bitrate(max_bitrate) {}
67 uint32_t min_bitrate;
68 uint32_t max_bitrate;
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000069 };
70 struct ObserverConfiguration {
71 ObserverConfiguration(BitrateObserver* observer, uint32_t bitrate)
Peter Boström8e4e8b02015-09-15 15:08:03 +020072 : observer(observer), min_bitrate(bitrate) {}
73 BitrateObserver* const observer;
74 uint32_t min_bitrate;
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000075 };
Stefan Holmere5904162015-03-26 11:11:06 +010076 typedef std::pair<BitrateObserver*, BitrateConfiguration>
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000077 BitrateObserverConfiguration;
78 typedef std::list<BitrateObserverConfiguration> BitrateObserverConfList;
Stefan Holmere5904162015-03-26 11:11:06 +010079 typedef std::multimap<uint32_t, ObserverConfiguration> ObserverSortingMap;
80 typedef std::map<BitrateObserver*, int> ObserverBitrateMap;
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000081
82 BitrateObserverConfList::iterator FindObserverConfigurationPair(
83 const BitrateObserver* observer) EXCLUSIVE_LOCKS_REQUIRED(crit_sect_);
Stefan Holmere5904162015-03-26 11:11:06 +010084 ObserverBitrateMap AllocateBitrates() EXCLUSIVE_LOCKS_REQUIRED(crit_sect_);
85 ObserverBitrateMap NormalRateAllocation(uint32_t bitrate,
86 uint32_t sum_min_bitrates)
87 EXCLUSIVE_LOCKS_REQUIRED(crit_sect_);
88
89 ObserverBitrateMap LowRateAllocation(uint32_t bitrate)
90 EXCLUSIVE_LOCKS_REQUIRED(crit_sect_);
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000091
pbos5ad935c2016-01-25 03:52:44 -080092 rtc::CriticalSection crit_sect_;
Stefan Holmere5904162015-03-26 11:11:06 +010093 // Stored in a list to keep track of the insertion order.
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000094 BitrateObserverConfList bitrate_observers_ GUARDED_BY(crit_sect_);
95 bool bitrate_observers_modified_ GUARDED_BY(crit_sect_);
96 bool enforce_min_bitrate_ GUARDED_BY(crit_sect_);
Stefan Holmere5904162015-03-26 11:11:06 +010097 uint32_t last_bitrate_bps_ GUARDED_BY(crit_sect_);
98 uint8_t last_fraction_loss_ GUARDED_BY(crit_sect_);
99 int64_t last_rtt_ GUARDED_BY(crit_sect_);
stefan@webrtc.org792f1a12015-03-04 12:24:26 +0000100};
101} // namespace webrtc
mflodman0e7e2592015-11-12 21:02:42 -0800102#endif // WEBRTC_CALL_BITRATE_ALLOCATOR_H_