This reverts commit 825eb58d59940a4c3c9837595c4b3b07059c93ca. This Relands the cl reviewed in https://codereview.webrtc.org/1917793002/ patchset #1 is a pure reland. patchset #2 fix an overflow in BitrateProber that caused WebRtcVideoChannel2BaseTest.TwoStreamsSendAndReceive to fail. Original cl description: Remove SendPacer from ViEEncoder This CL moves the logic where the ViEEncoder pause if the pacer is full to the BitrateController. If the queue is full, the controller reports a bitrate of zero to Call (and BitrateAllocator) R=stefan@webrtc.org TBR=mflodman@webrtc.org BUG=webrtc:5687 Review URL: https://codereview.webrtc.org/1947873002 . Cr-Commit-Position: refs/heads/master@{#12630}
112 lines
4.5 KiB
C++
112 lines
4.5 KiB
C++
/*
|
|
* Copyright (c) 2015 The WebRTC project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#ifndef WEBRTC_CALL_BITRATE_ALLOCATOR_H_
|
|
#define WEBRTC_CALL_BITRATE_ALLOCATOR_H_
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <list>
|
|
#include <map>
|
|
#include <utility>
|
|
|
|
#include "webrtc/base/criticalsection.h"
|
|
#include "webrtc/base/thread_annotations.h"
|
|
|
|
namespace webrtc {
|
|
|
|
// Used by all send streams with adaptive bitrate, to get the currently
|
|
// allocated bitrate for the send stream. The current network properties are
|
|
// given at the same time, to let the send stream decide about possible loss
|
|
// protection.
|
|
class BitrateAllocatorObserver {
|
|
public:
|
|
virtual void OnBitrateUpdated(uint32_t bitrate_bps,
|
|
uint8_t fraction_loss,
|
|
int64_t rtt) = 0;
|
|
virtual ~BitrateAllocatorObserver() {}
|
|
};
|
|
|
|
// Usage: this class will register multiple RtcpBitrateObserver's one at each
|
|
// RTCP module. It will aggregate the results and run one bandwidth estimation
|
|
// and push the result to the encoders via BitrateAllocatorObserver(s).
|
|
class BitrateAllocator {
|
|
public:
|
|
BitrateAllocator();
|
|
|
|
// Allocate target_bitrate across the registered BitrateAllocatorObservers.
|
|
// Returns actual bitrate allocated (might be higher than target_bitrate if
|
|
// for instance EnforceMinBitrate() is enabled.
|
|
uint32_t OnNetworkChanged(uint32_t target_bitrate,
|
|
uint8_t fraction_loss,
|
|
int64_t rtt);
|
|
|
|
// Set the start and max send bitrate used by the bandwidth management.
|
|
//
|
|
// |observer| updates bitrates if already in use.
|
|
// |min_bitrate_bps| = 0 equals no min bitrate.
|
|
// |max_bitrate_bps| = 0 equals no max bitrate.
|
|
// Returns bitrate allocated for the bitrate observer.
|
|
int AddObserver(BitrateAllocatorObserver* observer,
|
|
uint32_t min_bitrate_bps,
|
|
uint32_t max_bitrate_bps);
|
|
|
|
void RemoveObserver(BitrateAllocatorObserver* observer);
|
|
|
|
// This method controls the behavior when the available bitrate is lower than
|
|
// the minimum bitrate, or the sum of minimum bitrates.
|
|
// When true, the bitrate will never be set lower than the minimum bitrate(s).
|
|
// When false, the bitrate observers will be allocated rates up to their
|
|
// respective minimum bitrate, satisfying one observer after the other.
|
|
void EnforceMinBitrate(bool enforce_min_bitrate);
|
|
|
|
private:
|
|
struct BitrateConfiguration {
|
|
BitrateConfiguration(uint32_t min_bitrate, uint32_t max_bitrate)
|
|
: min_bitrate(min_bitrate), max_bitrate(max_bitrate) {}
|
|
uint32_t min_bitrate;
|
|
uint32_t max_bitrate;
|
|
};
|
|
struct ObserverConfiguration {
|
|
ObserverConfiguration(BitrateAllocatorObserver* observer, uint32_t bitrate)
|
|
: observer(observer), min_bitrate(bitrate) {}
|
|
BitrateAllocatorObserver* const observer;
|
|
uint32_t min_bitrate;
|
|
};
|
|
typedef std::pair<BitrateAllocatorObserver*, BitrateConfiguration>
|
|
BitrateObserverConfiguration;
|
|
typedef std::list<BitrateObserverConfiguration> BitrateObserverConfList;
|
|
typedef std::multimap<uint32_t, ObserverConfiguration> ObserverSortingMap;
|
|
typedef std::map<BitrateAllocatorObserver*, int> ObserverBitrateMap;
|
|
|
|
BitrateObserverConfList::iterator FindObserverConfigurationPair(
|
|
const BitrateAllocatorObserver* observer)
|
|
EXCLUSIVE_LOCKS_REQUIRED(crit_sect_);
|
|
ObserverBitrateMap AllocateBitrates() EXCLUSIVE_LOCKS_REQUIRED(crit_sect_);
|
|
ObserverBitrateMap NormalRateAllocation(uint32_t bitrate,
|
|
uint32_t sum_min_bitrates)
|
|
EXCLUSIVE_LOCKS_REQUIRED(crit_sect_);
|
|
|
|
ObserverBitrateMap ZeroRateAllocation() EXCLUSIVE_LOCKS_REQUIRED(crit_sect_);
|
|
ObserverBitrateMap LowRateAllocation(uint32_t bitrate)
|
|
EXCLUSIVE_LOCKS_REQUIRED(crit_sect_);
|
|
|
|
rtc::CriticalSection crit_sect_;
|
|
// Stored in a list to keep track of the insertion order.
|
|
BitrateObserverConfList bitrate_observers_ GUARDED_BY(crit_sect_);
|
|
bool bitrate_observers_modified_ GUARDED_BY(crit_sect_);
|
|
bool enforce_min_bitrate_ GUARDED_BY(crit_sect_);
|
|
uint32_t last_bitrate_bps_ GUARDED_BY(crit_sect_);
|
|
uint8_t last_fraction_loss_ GUARDED_BY(crit_sect_);
|
|
int64_t last_rtt_ GUARDED_BY(crit_sect_);
|
|
};
|
|
} // namespace webrtc
|
|
#endif // WEBRTC_CALL_BITRATE_ALLOCATOR_H_
|