blob: 8630815a95576f0925dabbdcbf220f89b401c75d [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
Ying Wang3b790f32018-01-19 17:58:57 +010018#include "api/fec_controller.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020019#include "api/rtcerror.h"
20#include "call/audio_receive_stream.h"
21#include "call/audio_send_stream.h"
22#include "call/audio_state.h"
Sebastian Janssonfc8d26b2018-02-21 09:52:06 +010023#include "call/bitrate_constraints.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020024#include "call/flexfec_receive_stream.h"
25#include "call/rtp_transport_controller_send_interface.h"
26#include "call/video_receive_stream.h"
27#include "call/video_send_stream.h"
Mirko Bonadei71207422017-09-15 13:58:09 +020028#include "common_types.h" // NOLINT(build/include)
Alex Narest78609d52017-10-20 10:37:47 +020029#include "rtc_base/bitrateallocationstrategy.h"
Danil Chapovalov292a73e2017-12-07 17:00:40 +010030#include "rtc_base/copyonwritebuffer.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020031#include "rtc_base/networkroute.h"
32#include "rtc_base/platform_file.h"
33#include "rtc_base/socket.h"
ossuf515ab82016-12-07 04:52:58 -080034
35namespace webrtc {
36
37class AudioProcessing;
38class RtcEventLog;
39
ossuf515ab82016-12-07 04:52:58 -080040enum class MediaType {
41 ANY,
42 AUDIO,
43 VIDEO,
44 DATA
45};
46
47class PacketReceiver {
48 public:
49 enum DeliveryStatus {
50 DELIVERY_OK,
51 DELIVERY_UNKNOWN_SSRC,
52 DELIVERY_PACKET_ERROR,
53 };
54
55 virtual DeliveryStatus DeliverPacket(MediaType media_type,
Danil Chapovalov292a73e2017-12-07 17:00:40 +010056 rtc::CopyOnWriteBuffer packet,
ossuf515ab82016-12-07 04:52:58 -080057 const PacketTime& packet_time) = 0;
58
59 protected:
60 virtual ~PacketReceiver() {}
61};
62
Niels Möller8366e172018-02-14 12:20:13 +010063struct CallConfig {
64 explicit CallConfig(RtcEventLog* event_log) : event_log(event_log) {
65 RTC_DCHECK(event_log);
66 }
67
Sebastian Janssonfc8d26b2018-02-21 09:52:06 +010068 RTC_DEPRECATED static constexpr int kDefaultStartBitrateBps = 300000;
Lu Liue4bf6002018-02-20 19:16:26 +000069
Niels Möller8366e172018-02-14 12:20:13 +010070 // Bitrate config used until valid bitrate estimates are calculated. Also
71 // used to cap total bitrate used. This comes from the remote connection.
Sebastian Janssonfc8d26b2018-02-21 09:52:06 +010072 BitrateConstraints bitrate_config;
Niels Möller8366e172018-02-14 12:20:13 +010073
74 // AudioState which is possibly shared between multiple calls.
75 // TODO(solenberg): Change this to a shared_ptr once we can use C++11.
76 rtc::scoped_refptr<AudioState> audio_state;
77
78 // Audio Processing Module to be used in this call.
79 // TODO(solenberg): Change this to a shared_ptr once we can use C++11.
80 AudioProcessing* audio_processing = nullptr;
81
82 // RtcEventLog to use for this call. Required.
83 // Use webrtc::RtcEventLog::CreateNull() for a null implementation.
84 RtcEventLog* event_log = nullptr;
Ying Wang0dd1b0a2018-02-20 12:50:27 +010085
86 // FecController to use for this call.
87 FecControllerFactoryInterface* fec_controller_factory = nullptr;
Niels Möller8366e172018-02-14 12:20:13 +010088};
89
ossuf515ab82016-12-07 04:52:58 -080090// A Call instance can contain several send and/or receive streams. All streams
91// are assumed to have the same remote endpoint and will share bitrate estimates
92// etc.
93class Call {
94 public:
Niels Möller8366e172018-02-14 12:20:13 +010095 using Config = CallConfig;
ossuf515ab82016-12-07 04:52:58 -080096
97 struct Stats {
98 std::string ToString(int64_t time_ms) const;
99
100 int send_bandwidth_bps = 0; // Estimated available send bandwidth.
101 int max_padding_bitrate_bps = 0; // Cumulative configured max padding.
102 int recv_bandwidth_bps = 0; // Estimated available receive bandwidth.
103 int64_t pacer_delay_ms = 0;
104 int64_t rtt_ms = -1;
105 };
106
107 static Call* Create(const Call::Config& config);
108
zstein7cb69d52017-05-08 11:52:38 -0700109 // Allows mocking |transport_send| for testing.
110 static Call* Create(
111 const Call::Config& config,
112 std::unique_ptr<RtpTransportControllerSendInterface> transport_send);
113
ossuf515ab82016-12-07 04:52:58 -0800114 virtual AudioSendStream* CreateAudioSendStream(
115 const AudioSendStream::Config& config) = 0;
116 virtual void DestroyAudioSendStream(AudioSendStream* send_stream) = 0;
117
118 virtual AudioReceiveStream* CreateAudioReceiveStream(
119 const AudioReceiveStream::Config& config) = 0;
120 virtual void DestroyAudioReceiveStream(
121 AudioReceiveStream* receive_stream) = 0;
122
123 virtual VideoSendStream* CreateVideoSendStream(
124 VideoSendStream::Config config,
125 VideoEncoderConfig encoder_config) = 0;
Ying Wang3b790f32018-01-19 17:58:57 +0100126 virtual VideoSendStream* CreateVideoSendStream(
127 VideoSendStream::Config config,
128 VideoEncoderConfig encoder_config,
129 std::unique_ptr<FecController> fec_controller);
ossuf515ab82016-12-07 04:52:58 -0800130 virtual void DestroyVideoSendStream(VideoSendStream* send_stream) = 0;
131
132 virtual VideoReceiveStream* CreateVideoReceiveStream(
133 VideoReceiveStream::Config configuration) = 0;
134 virtual void DestroyVideoReceiveStream(
135 VideoReceiveStream* receive_stream) = 0;
136
brandtrfb45c6c2017-01-27 06:47:55 -0800137 // In order for a created VideoReceiveStream to be aware that it is
138 // protected by a FlexfecReceiveStream, the latter should be created before
139 // the former.
ossuf515ab82016-12-07 04:52:58 -0800140 virtual FlexfecReceiveStream* CreateFlexfecReceiveStream(
brandtr446fcb62016-12-08 04:14:24 -0800141 const FlexfecReceiveStream::Config& config) = 0;
ossuf515ab82016-12-07 04:52:58 -0800142 virtual void DestroyFlexfecReceiveStream(
143 FlexfecReceiveStream* receive_stream) = 0;
144
145 // All received RTP and RTCP packets for the call should be inserted to this
146 // PacketReceiver. The PacketReceiver pointer is valid as long as the
147 // Call instance exists.
148 virtual PacketReceiver* Receiver() = 0;
149
Sebastian Jansson8f83b422018-02-21 13:07:13 +0100150 // This is used to access the transport controller send instance owned by
151 // Call. The send transport controller is currently owned by Call for legacy
152 // reasons. (for instance variants of call tests are built on this assumtion)
153 // TODO(srte): Move ownership of transport controller send out of Call and
154 // remove this method interface.
155 virtual RtpTransportControllerSendInterface* GetTransportControllerSend() = 0;
156
ossuf515ab82016-12-07 04:52:58 -0800157 // Returns the call statistics, such as estimated send and receive bandwidth,
158 // pacing delay, etc.
159 virtual Stats GetStats() const = 0;
160
Alex Narest78609d52017-10-20 10:37:47 +0200161 virtual void SetBitrateAllocationStrategy(
162 std::unique_ptr<rtc::BitrateAllocationStrategy>
163 bitrate_allocation_strategy) = 0;
164
ossuf515ab82016-12-07 04:52:58 -0800165 // TODO(skvlad): When the unbundled case with multiple streams for the same
166 // media type going over different networks is supported, track the state
167 // for each stream separately. Right now it's global per media type.
168 virtual void SignalChannelNetworkState(MediaType media,
169 NetworkState state) = 0;
170
171 virtual void OnTransportOverheadChanged(
172 MediaType media,
173 int transport_overhead_per_packet) = 0;
174
ossuf515ab82016-12-07 04:52:58 -0800175 virtual void OnSentPacket(const rtc::SentPacket& sent_packet) = 0;
176
177 virtual ~Call() {}
178};
179
180} // namespace webrtc
181
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200182#endif // CALL_CALL_H_