2020-08-14 16:58:22 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2013 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 CALL_CALL_H_
|
|
|
|
#define CALL_CALL_H_
|
|
|
|
|
|
|
|
#include <algorithm>
|
|
|
|
#include <memory>
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "api/adaptation/resource.h"
|
|
|
|
#include "api/media_types.h"
|
2021-06-25 00:43:10 +00:00
|
|
|
#include "api/task_queue/task_queue_base.h"
|
2020-08-14 16:58:22 +00:00
|
|
|
#include "call/audio_receive_stream.h"
|
|
|
|
#include "call/audio_send_stream.h"
|
|
|
|
#include "call/call_config.h"
|
|
|
|
#include "call/flexfec_receive_stream.h"
|
|
|
|
#include "call/packet_receiver.h"
|
|
|
|
#include "call/rtp_transport_controller_send_interface.h"
|
|
|
|
#include "call/video_receive_stream.h"
|
|
|
|
#include "call/video_send_stream.h"
|
|
|
|
#include "modules/utility/include/process_thread.h"
|
|
|
|
#include "rtc_base/copy_on_write_buffer.h"
|
|
|
|
#include "rtc_base/network/sent_packet.h"
|
|
|
|
#include "rtc_base/network_route.h"
|
|
|
|
#include "rtc_base/ref_count.h"
|
|
|
|
|
|
|
|
namespace webrtc {
|
|
|
|
|
|
|
|
// A restricted way to share the module process thread across multiple instances
|
|
|
|
// of Call that are constructed on the same worker thread (which is what the
|
|
|
|
// peer connection factory guarantees).
|
|
|
|
// SharedModuleThread supports a callback that is issued when only one reference
|
|
|
|
// remains, which is used to indicate to the original owner that the thread may
|
|
|
|
// be discarded.
|
|
|
|
class SharedModuleThread : public rtc::RefCountInterface {
|
|
|
|
protected:
|
|
|
|
SharedModuleThread(std::unique_ptr<ProcessThread> process_thread,
|
|
|
|
std::function<void()> on_one_ref_remaining);
|
|
|
|
friend class rtc::scoped_refptr<SharedModuleThread>;
|
|
|
|
~SharedModuleThread() override;
|
|
|
|
|
|
|
|
public:
|
|
|
|
// Allows injection of an externally created process thread.
|
|
|
|
static rtc::scoped_refptr<SharedModuleThread> Create(
|
|
|
|
std::unique_ptr<ProcessThread> process_thread,
|
|
|
|
std::function<void()> on_one_ref_remaining);
|
|
|
|
|
|
|
|
void EnsureStarted();
|
|
|
|
|
|
|
|
ProcessThread* process_thread();
|
|
|
|
|
|
|
|
private:
|
|
|
|
void AddRef() const override;
|
|
|
|
rtc::RefCountReleaseStatus Release() const override;
|
|
|
|
|
|
|
|
class Impl;
|
|
|
|
mutable std::unique_ptr<Impl> impl_;
|
|
|
|
};
|
|
|
|
|
|
|
|
// A Call instance can contain several send and/or receive streams. All streams
|
|
|
|
// are assumed to have the same remote endpoint and will share bitrate estimates
|
|
|
|
// etc.
|
|
|
|
class Call {
|
|
|
|
public:
|
|
|
|
using Config = CallConfig;
|
|
|
|
|
|
|
|
struct Stats {
|
|
|
|
std::string ToString(int64_t time_ms) const;
|
|
|
|
|
|
|
|
int send_bandwidth_bps = 0; // Estimated available send bandwidth.
|
|
|
|
int max_padding_bitrate_bps = 0; // Cumulative configured max padding.
|
|
|
|
int recv_bandwidth_bps = 0; // Estimated available receive bandwidth.
|
|
|
|
int64_t pacer_delay_ms = 0;
|
|
|
|
int64_t rtt_ms = -1;
|
|
|
|
};
|
|
|
|
|
|
|
|
static Call* Create(const Call::Config& config);
|
|
|
|
static Call* Create(const Call::Config& config,
|
|
|
|
rtc::scoped_refptr<SharedModuleThread> call_thread);
|
|
|
|
static Call* Create(const Call::Config& config,
|
|
|
|
Clock* clock,
|
|
|
|
rtc::scoped_refptr<SharedModuleThread> call_thread,
|
|
|
|
std::unique_ptr<ProcessThread> pacer_thread);
|
|
|
|
|
|
|
|
virtual AudioSendStream* CreateAudioSendStream(
|
|
|
|
const AudioSendStream::Config& config) = 0;
|
|
|
|
|
|
|
|
virtual void DestroyAudioSendStream(AudioSendStream* send_stream) = 0;
|
|
|
|
|
|
|
|
virtual AudioReceiveStream* CreateAudioReceiveStream(
|
|
|
|
const AudioReceiveStream::Config& config) = 0;
|
|
|
|
virtual void DestroyAudioReceiveStream(
|
|
|
|
AudioReceiveStream* receive_stream) = 0;
|
|
|
|
|
|
|
|
virtual VideoSendStream* CreateVideoSendStream(
|
|
|
|
VideoSendStream::Config config,
|
|
|
|
VideoEncoderConfig encoder_config) = 0;
|
|
|
|
virtual VideoSendStream* CreateVideoSendStream(
|
|
|
|
VideoSendStream::Config config,
|
|
|
|
VideoEncoderConfig encoder_config,
|
|
|
|
std::unique_ptr<FecController> fec_controller);
|
|
|
|
virtual void DestroyVideoSendStream(VideoSendStream* send_stream) = 0;
|
|
|
|
|
|
|
|
virtual VideoReceiveStream* CreateVideoReceiveStream(
|
|
|
|
VideoReceiveStream::Config configuration) = 0;
|
|
|
|
virtual void DestroyVideoReceiveStream(
|
|
|
|
VideoReceiveStream* receive_stream) = 0;
|
|
|
|
|
|
|
|
// In order for a created VideoReceiveStream to be aware that it is
|
|
|
|
// protected by a FlexfecReceiveStream, the latter should be created before
|
|
|
|
// the former.
|
|
|
|
virtual FlexfecReceiveStream* CreateFlexfecReceiveStream(
|
|
|
|
const FlexfecReceiveStream::Config& config) = 0;
|
|
|
|
virtual void DestroyFlexfecReceiveStream(
|
|
|
|
FlexfecReceiveStream* receive_stream) = 0;
|
|
|
|
|
|
|
|
// When a resource is overused, the Call will try to reduce the load on the
|
|
|
|
// sysem, for example by reducing the resolution or frame rate of encoded
|
|
|
|
// streams.
|
|
|
|
virtual void AddAdaptationResource(rtc::scoped_refptr<Resource> resource) = 0;
|
|
|
|
|
|
|
|
// All received RTP and RTCP packets for the call should be inserted to this
|
|
|
|
// PacketReceiver. The PacketReceiver pointer is valid as long as the
|
|
|
|
// Call instance exists.
|
|
|
|
virtual PacketReceiver* Receiver() = 0;
|
|
|
|
|
|
|
|
// This is used to access the transport controller send instance owned by
|
|
|
|
// Call. The send transport controller is currently owned by Call for legacy
|
|
|
|
// reasons. (for instance variants of call tests are built on this assumtion)
|
|
|
|
// TODO(srte): Move ownership of transport controller send out of Call and
|
|
|
|
// remove this method interface.
|
|
|
|
virtual RtpTransportControllerSendInterface* GetTransportControllerSend() = 0;
|
|
|
|
|
|
|
|
// Returns the call statistics, such as estimated send and receive bandwidth,
|
|
|
|
// pacing delay, etc.
|
|
|
|
virtual Stats GetStats() const = 0;
|
|
|
|
|
|
|
|
// TODO(skvlad): When the unbundled case with multiple streams for the same
|
|
|
|
// media type going over different networks is supported, track the state
|
|
|
|
// for each stream separately. Right now it's global per media type.
|
|
|
|
virtual void SignalChannelNetworkState(MediaType media,
|
|
|
|
NetworkState state) = 0;
|
|
|
|
|
|
|
|
virtual void OnAudioTransportOverheadChanged(
|
|
|
|
int transport_overhead_per_packet) = 0;
|
|
|
|
|
|
|
|
virtual void OnSentPacket(const rtc::SentPacket& sent_packet) = 0;
|
|
|
|
|
|
|
|
virtual void SetClientBitratePreferences(
|
|
|
|
const BitrateSettings& preferences) = 0;
|
|
|
|
|
2020-12-23 07:48:30 +00:00
|
|
|
virtual const WebRtcKeyValueConfig& trials() const = 0;
|
|
|
|
|
2021-06-25 00:43:10 +00:00
|
|
|
virtual TaskQueueBase* network_thread() const = 0;
|
|
|
|
virtual TaskQueueBase* worker_thread() const = 0;
|
|
|
|
|
2020-08-14 16:58:22 +00:00
|
|
|
virtual ~Call() {}
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace webrtc
|
|
|
|
|
|
|
|
#endif // CALL_CALL_H_
|