blob: c12dbebcb9b1ee619c7e045c6d68f486871040d8 [file] [log] [blame]
pwestin@webrtc.org1cd11622012-04-19 12:13:52 +00001/*
2 * Copyright (c) 2012 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
15#ifndef WEBRTC_MODULES_BITRATE_CONTROLLER_INCLUDE_BITRATE_CONTROLLER_H_
16#define WEBRTC_MODULES_BITRATE_CONTROLLER_INCLUDE_BITRATE_CONTROLLER_H_
17
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000018#include <map>
19
andresp@webrtc.org44caf012014-03-26 21:00:21 +000020#include "webrtc/modules/interface/module.h"
pbos@webrtc.org2e10b8e2013-07-16 12:54:53 +000021#include "webrtc/modules/rtp_rtcp/interface/rtp_rtcp_defines.h"
pwestin@webrtc.org1cd11622012-04-19 12:13:52 +000022
23namespace webrtc {
24
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000025class CriticalSectionWrapper;
26
pwestin@webrtc.org1cd11622012-04-19 12:13:52 +000027class BitrateObserver {
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000028 // Observer class for bitrate changes announced due to change in bandwidth
29 // estimate or due to bitrate allocation changes. Fraction loss and rtt is
30 // also part of this callback to allow the obsevrer to optimize its settings
31 // for different types of network environments. The bitrate does not include
32 // packet headers and is measured in bits per second.
pwestin@webrtc.org1cd11622012-04-19 12:13:52 +000033 public:
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000034 virtual void OnNetworkChanged(uint32_t bitrate_bps,
stefan@webrtc.orgedeea912014-12-08 19:46:23 +000035 uint8_t fraction_loss, // 0 - 255.
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000036 int64_t rtt_ms) = 0;
pwestin@webrtc.org1cd11622012-04-19 12:13:52 +000037
pwestin@webrtc.org1cd11622012-04-19 12:13:52 +000038 virtual ~BitrateObserver() {}
39};
40
andresp@webrtc.org44caf012014-03-26 21:00:21 +000041class BitrateController : public Module {
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000042 // This class collects feedback from all streams sent to a peer (via
43 // RTCPBandwidthObservers). It does one aggregated send side bandwidth
44 // estimation and divide the available bitrate between all its registered
45 // BitrateObservers.
pwestin@webrtc.org1cd11622012-04-19 12:13:52 +000046 public:
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000047 static const int kDefaultStartBitrateKbps = 300;
48
andresp@webrtc.org44caf012014-03-26 21:00:21 +000049 static BitrateController* CreateBitrateController(Clock* clock,
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000050 BitrateObserver* observer);
pwestin@webrtc.org1cd11622012-04-19 12:13:52 +000051 virtual ~BitrateController() {}
52
53 virtual RtcpBandwidthObserver* CreateRtcpBandwidthObserver() = 0;
54
stefan@webrtc.org792f1a12015-03-04 12:24:26 +000055 virtual void SetStartBitrate(int start_bitrate_bps) = 0;
56 virtual void SetMinMaxBitrate(int min_bitrate_bps, int max_bitrate_bps) = 0;
57
stefan@webrtc.org42aa10e2012-11-13 15:02:13 +000058 // Gets the available payload bandwidth in bits per second. Note that
59 // this bandwidth excludes packet headers.
pwestin@webrtc.orga2cd7322012-04-23 08:32:47 +000060 virtual bool AvailableBandwidth(uint32_t* bandwidth) const = 0;
61
solenberg@webrtc.org4e656022014-03-26 14:32:47 +000062 virtual void SetReservedBitrate(uint32_t reserved_bitrate_bps) = 0;
sprang@webrtc.org9b791972014-12-18 11:53:59 +000063
64 virtual void SetBitrateSent(uint32_t bitrate_sent_bps) = 0;
65
66 virtual void SetCodecMode(webrtc::VideoCodecMode mode) = 0;
pwestin@webrtc.org1cd11622012-04-19 12:13:52 +000067};
68} // namespace webrtc
69#endif // WEBRTC_MODULES_BITRATE_CONTROLLER_INCLUDE_BITRATE_CONTROLLER_H_