blob: 1442c05fd115a4db9add2eb98f83daba5e80eb0d [file] [log] [blame]
ossuf515ab82016-12-07 04:52:58 -08001/*
2 * Copyright (c) 2013 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 */
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020010#ifndef CALL_CALL_H_
11#define CALL_CALL_H_
ossuf515ab82016-12-07 04:52:58 -080012
zsteina5e0df62017-06-14 11:41:48 -070013#include <algorithm>
zstein7cb69d52017-05-08 11:52:38 -070014#include <memory>
ossuf515ab82016-12-07 04:52:58 -080015#include <string>
16#include <vector>
17
Henrik Boströmf4a99912020-06-11 12:07:14 +020018#include "api/adaptation/resource.h"
Steve Anton10542f22019-01-11 09:11:00 -080019#include "api/media_types.h"
Tomas Gunnarssone984aa22021-04-19 09:21:06 +020020#include "api/task_queue/task_queue_base.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020021#include "call/audio_receive_stream.h"
22#include "call/audio_send_stream.h"
Paulina Hensman11b34f42018-04-09 14:24:52 +020023#include "call/call_config.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020024#include "call/flexfec_receive_stream.h"
Niels Möller70082872018-08-07 11:03:12 +020025#include "call/packet_receiver.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020026#include "call/rtp_transport_controller_send_interface.h"
27#include "call/video_receive_stream.h"
28#include "call/video_send_stream.h"
Sebastian Jansson896b47c2019-03-01 18:48:16 +010029#include "modules/utility/include/process_thread.h"
Steve Anton10542f22019-01-11 09:11:00 -080030#include "rtc_base/copy_on_write_buffer.h"
Sebastian Jansson12985412018-10-15 21:06:26 +020031#include "rtc_base/network/sent_packet.h"
Steve Anton10542f22019-01-11 09:11:00 -080032#include "rtc_base/network_route.h"
Tommi25c77c12020-05-25 17:44:55 +020033#include "rtc_base/ref_count.h"
ossuf515ab82016-12-07 04:52:58 -080034
35namespace webrtc {
36
Tommi25c77c12020-05-25 17:44:55 +020037// A restricted way to share the module process thread across multiple instances
38// of Call that are constructed on the same worker thread (which is what the
39// peer connection factory guarantees).
40// SharedModuleThread supports a callback that is issued when only one reference
41// remains, which is used to indicate to the original owner that the thread may
42// be discarded.
Niels Möller6b7b2552022-01-14 09:18:23 +010043class SharedModuleThread final {
Tommi25c77c12020-05-25 17:44:55 +020044 public:
Tommi25c77c12020-05-25 17:44:55 +020045 // Allows injection of an externally created process thread.
46 static rtc::scoped_refptr<SharedModuleThread> Create(
47 std::unique_ptr<ProcessThread> process_thread,
48 std::function<void()> on_one_ref_remaining);
49
50 void EnsureStarted();
51
52 ProcessThread* process_thread();
53
54 private:
Niels Möller6b7b2552022-01-14 09:18:23 +010055 friend class rtc::scoped_refptr<SharedModuleThread>;
56 SharedModuleThread(std::unique_ptr<ProcessThread> process_thread,
57 std::function<void()> on_one_ref_remaining);
58 ~SharedModuleThread();
59
60 void AddRef() const;
61 rtc::RefCountReleaseStatus Release() const;
Tommi25c77c12020-05-25 17:44:55 +020062
63 class Impl;
64 mutable std::unique_ptr<Impl> impl_;
65};
66
ossuf515ab82016-12-07 04:52:58 -080067// A Call instance can contain several send and/or receive streams. All streams
68// are assumed to have the same remote endpoint and will share bitrate estimates
69// etc.
70class Call {
71 public:
Niels Möller8366e172018-02-14 12:20:13 +010072 using Config = CallConfig;
ossuf515ab82016-12-07 04:52:58 -080073
74 struct Stats {
75 std::string ToString(int64_t time_ms) const;
76
77 int send_bandwidth_bps = 0; // Estimated available send bandwidth.
78 int max_padding_bitrate_bps = 0; // Cumulative configured max padding.
79 int recv_bandwidth_bps = 0; // Estimated available receive bandwidth.
80 int64_t pacer_delay_ms = 0;
81 int64_t rtt_ms = -1;
82 };
83
84 static Call* Create(const Call::Config& config);
Sebastian Jansson896b47c2019-03-01 18:48:16 +010085 static Call* Create(const Call::Config& config,
Sebastian Jansson4e5f5ed2019-03-01 18:13:27 +010086 Clock* clock,
Tommi25c77c12020-05-25 17:44:55 +020087 rtc::scoped_refptr<SharedModuleThread> call_thread,
Danil Chapovalov359fe332019-04-01 10:46:36 +020088 std::unique_ptr<ProcessThread> pacer_thread);
Vojin Ilic504fc192021-05-31 14:02:28 +020089 static Call* Create(const Call::Config& config,
90 Clock* clock,
91 rtc::scoped_refptr<SharedModuleThread> call_thread,
92 std::unique_ptr<RtpTransportControllerSendInterface>
93 transportControllerSend);
ossuf515ab82016-12-07 04:52:58 -080094
95 virtual AudioSendStream* CreateAudioSendStream(
96 const AudioSendStream::Config& config) = 0;
Piotr (Peter) Slatalacc8e8bb2018-11-15 08:26:19 -080097
ossuf515ab82016-12-07 04:52:58 -080098 virtual void DestroyAudioSendStream(AudioSendStream* send_stream) = 0;
99
100 virtual AudioReceiveStream* CreateAudioReceiveStream(
101 const AudioReceiveStream::Config& config) = 0;
102 virtual void DestroyAudioReceiveStream(
103 AudioReceiveStream* receive_stream) = 0;
104
105 virtual VideoSendStream* CreateVideoSendStream(
106 VideoSendStream::Config config,
107 VideoEncoderConfig encoder_config) = 0;
Ying Wang3b790f32018-01-19 17:58:57 +0100108 virtual VideoSendStream* CreateVideoSendStream(
109 VideoSendStream::Config config,
110 VideoEncoderConfig encoder_config,
111 std::unique_ptr<FecController> fec_controller);
ossuf515ab82016-12-07 04:52:58 -0800112 virtual void DestroyVideoSendStream(VideoSendStream* send_stream) = 0;
113
114 virtual VideoReceiveStream* CreateVideoReceiveStream(
115 VideoReceiveStream::Config configuration) = 0;
116 virtual void DestroyVideoReceiveStream(
117 VideoReceiveStream* receive_stream) = 0;
118
brandtrfb45c6c2017-01-27 06:47:55 -0800119 // In order for a created VideoReceiveStream to be aware that it is
120 // protected by a FlexfecReceiveStream, the latter should be created before
121 // the former.
ossuf515ab82016-12-07 04:52:58 -0800122 virtual FlexfecReceiveStream* CreateFlexfecReceiveStream(
brandtr446fcb62016-12-08 04:14:24 -0800123 const FlexfecReceiveStream::Config& config) = 0;
ossuf515ab82016-12-07 04:52:58 -0800124 virtual void DestroyFlexfecReceiveStream(
125 FlexfecReceiveStream* receive_stream) = 0;
126
Henrik Boströmf4a99912020-06-11 12:07:14 +0200127 // When a resource is overused, the Call will try to reduce the load on the
128 // sysem, for example by reducing the resolution or frame rate of encoded
129 // streams.
130 virtual void AddAdaptationResource(rtc::scoped_refptr<Resource> resource) = 0;
131
ossuf515ab82016-12-07 04:52:58 -0800132 // All received RTP and RTCP packets for the call should be inserted to this
133 // PacketReceiver. The PacketReceiver pointer is valid as long as the
134 // Call instance exists.
135 virtual PacketReceiver* Receiver() = 0;
136
Sebastian Jansson8f83b422018-02-21 13:07:13 +0100137 // This is used to access the transport controller send instance owned by
138 // Call. The send transport controller is currently owned by Call for legacy
139 // reasons. (for instance variants of call tests are built on this assumtion)
140 // TODO(srte): Move ownership of transport controller send out of Call and
141 // remove this method interface.
142 virtual RtpTransportControllerSendInterface* GetTransportControllerSend() = 0;
143
ossuf515ab82016-12-07 04:52:58 -0800144 // Returns the call statistics, such as estimated send and receive bandwidth,
145 // pacing delay, etc.
146 virtual Stats GetStats() const = 0;
147
ossuf515ab82016-12-07 04:52:58 -0800148 // TODO(skvlad): When the unbundled case with multiple streams for the same
149 // media type going over different networks is supported, track the state
150 // for each stream separately. Right now it's global per media type.
151 virtual void SignalChannelNetworkState(MediaType media,
152 NetworkState state) = 0;
153
Stefan Holmer64be7fa2018-10-04 15:21:55 +0200154 virtual void OnAudioTransportOverheadChanged(
ossuf515ab82016-12-07 04:52:58 -0800155 int transport_overhead_per_packet) = 0;
156
Tommi08be9ba2021-06-15 23:01:57 +0200157 // Called when a receive stream's local ssrc has changed and association with
158 // send streams needs to be updated.
159 virtual void OnLocalSsrcUpdated(AudioReceiveStream& stream,
160 uint32_t local_ssrc) = 0;
161
Tommi55107c82021-06-16 16:31:18 +0200162 virtual void OnUpdateSyncGroup(AudioReceiveStream& stream,
163 const std::string& sync_group) = 0;
164
ossuf515ab82016-12-07 04:52:58 -0800165 virtual void OnSentPacket(const rtc::SentPacket& sent_packet) = 0;
166
Piotr (Peter) Slatala7fbfaa42019-03-18 10:31:54 -0700167 virtual void SetClientBitratePreferences(
168 const BitrateSettings& preferences) = 0;
169
Erik Språngceb44952020-09-22 11:36:35 +0200170 virtual const WebRtcKeyValueConfig& trials() const = 0;
171
Tomas Gunnarssone984aa22021-04-19 09:21:06 +0200172 virtual TaskQueueBase* network_thread() const = 0;
173 virtual TaskQueueBase* worker_thread() const = 0;
174
ossuf515ab82016-12-07 04:52:58 -0800175 virtual ~Call() {}
176};
177
178} // namespace webrtc
179
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200180#endif // CALL_CALL_H_