blob: 67dad0d977beef1877d82ddf5821ea27ebb346be [file] [log] [blame]
niklase@google.com470e71d2011-07-07 08:21:25 +00001/*
pwestin@webrtc.orgf6bb77a2012-01-24 17:16:59 +00002 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
niklase@google.com470e71d2011-07-07 08:21:25 +00003 *
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
11#ifndef WEBRTC_MODULES_RTP_RTCP_INTERFACE_RTP_RTCP_H_
12#define WEBRTC_MODULES_RTP_RTCP_INTERFACE_RTP_RTCP_H_
13
perkj@webrtc.orgce5990c2012-01-11 13:00:08 +000014#include <vector>
15
turaj@webrtc.orgb7edd062013-03-12 22:27:27 +000016#include "webrtc/modules/interface/module.h"
17#include "webrtc/modules/rtp_rtcp/interface/rtp_rtcp_defines.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000018
19namespace webrtc {
pwestin@webrtc.org571a1c02012-11-13 21:12:39 +000020// Forward declarations.
21class PacedSender;
wu@webrtc.org822fbd82013-08-15 23:38:54 +000022class ReceiveStatistics;
stefan@webrtc.org9354cc92012-06-07 08:10:14 +000023class RemoteBitrateEstimator;
wu@webrtc.org822fbd82013-08-15 23:38:54 +000024class RtpReceiver;
niklase@google.com470e71d2011-07-07 08:21:25 +000025class Transport;
26
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +000027class RtpRtcp : public Module {
28 public:
29 struct Configuration {
phoglund@webrtc.orga22a9bd2013-01-14 10:01:55 +000030 Configuration();
31
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +000032 /* id - Unique identifier of this RTP/RTCP module object
33 * audio - True for a audio version of the RTP/RTCP module
34 * object false will create a video version
35 * clock - The clock to use to read time. If NULL object
36 * will be using the system clock.
37 * incoming_data - Callback object that will receive the incoming
phoglund@webrtc.orga22a9bd2013-01-14 10:01:55 +000038 * data. May not be NULL; default callback will do
39 * nothing.
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +000040 * incoming_messages - Callback object that will receive the incoming
phoglund@webrtc.orga22a9bd2013-01-14 10:01:55 +000041 * RTP messages. May not be NULL; default callback
42 * will do nothing.
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +000043 * outgoing_transport - Transport object that will be called when packets
44 * are ready to be sent out on the network
45 * rtcp_feedback - Callback object that will receive the incoming
mflodman@webrtc.org7c894b72012-11-26 12:40:15 +000046 * RTCP messages.
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +000047 * intra_frame_callback - Called when the receiver request a intra frame.
48 * bandwidth_callback - Called when we receive a changed estimate from
49 * the receiver of out stream.
phoglund@webrtc.orga22a9bd2013-01-14 10:01:55 +000050 * audio_messages - Telehone events. May not be NULL; default callback
51 * will do nothing.
stefan@webrtc.org9354cc92012-06-07 08:10:14 +000052 * remote_bitrate_estimator - Estimates the bandwidth available for a set of
53 * streams from the same client.
pwestin@webrtc.org571a1c02012-11-13 21:12:39 +000054 * paced_sender - Spread any bursts of packets into smaller
55 * bursts to minimize packet loss.
niklase@google.com470e71d2011-07-07 08:21:25 +000056 */
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +000057 int32_t id;
58 bool audio;
stefan@webrtc.org20ed36d2013-01-17 14:01:20 +000059 Clock* clock;
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +000060 RtpRtcp* default_module;
wu@webrtc.org822fbd82013-08-15 23:38:54 +000061 ReceiveStatistics* receive_statistics;
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +000062 Transport* outgoing_transport;
63 RtcpFeedback* rtcp_feedback;
64 RtcpIntraFrameObserver* intra_frame_callback;
65 RtcpBandwidthObserver* bandwidth_callback;
asapersson@webrtc.org1ae1d0c2013-11-20 12:46:11 +000066 RtcpRttStats* rtt_stats;
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +000067 RtpAudioFeedback* audio_messages;
stefan@webrtc.org9354cc92012-06-07 08:10:14 +000068 RemoteBitrateEstimator* remote_bitrate_estimator;
pwestin@webrtc.org571a1c02012-11-13 21:12:39 +000069 PacedSender* paced_sender;
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +000070 };
wu@webrtc.org822fbd82013-08-15 23:38:54 +000071
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +000072 /*
73 * Create a RTP/RTCP module object using the system clock.
74 *
75 * configuration - Configuration of the RTP/RTCP module.
76 */
77 static RtpRtcp* CreateRtpRtcp(const RtpRtcp::Configuration& configuration);
niklase@google.com470e71d2011-07-07 08:21:25 +000078
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +000079 /**************************************************************************
80 *
81 * Receiver functions
82 *
83 ***************************************************************************/
niklase@google.com470e71d2011-07-07 08:21:25 +000084
stefan@webrtc.orga5cb98c2013-05-29 12:12:51 +000085 virtual int32_t IncomingRtcpPacket(const uint8_t* incoming_packet,
86 uint16_t incoming_packet_length) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +000087
wu@webrtc.org822fbd82013-08-15 23:38:54 +000088 virtual void SetRemoteSSRC(const uint32_t ssrc) = 0;
89
niklase@google.com470e71d2011-07-07 08:21:25 +000090 /**************************************************************************
91 *
92 * Sender
93 *
94 ***************************************************************************/
95
96 /*
niklase@google.com470e71d2011-07-07 08:21:25 +000097 * set MTU
98 *
99 * size - Max transfer unit in bytes, default is 1500
100 *
101 * return -1 on failure else 0
102 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000103 virtual int32_t SetMaxTransferUnit(const uint16_t size) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000104
105 /*
106 * set transtport overhead
107 * default is IPv4 and UDP with no encryption
108 *
109 * TCP - true for TCP false UDP
110 * IPv6 - true for IP version 6 false for version 4
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000111 * authenticationOverhead - number of bytes to leave for an
112 * authentication header
niklase@google.com470e71d2011-07-07 08:21:25 +0000113 *
114 * return -1 on failure else 0
115 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000116 virtual int32_t SetTransportOverhead(
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000117 const bool TCP,
118 const bool IPV6,
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000119 const uint8_t authenticationOverhead = 0) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000120
121 /*
122 * Get max payload length
123 *
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000124 * A combination of the configuration MaxTransferUnit and
125 * TransportOverhead.
niklase@google.com470e71d2011-07-07 08:21:25 +0000126 * Does not account FEC/ULP/RED overhead if FEC is enabled.
127 * Does not account for RTP headers
128 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000129 virtual uint16_t MaxPayloadLength() const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000130
131 /*
132 * Get max data payload length
133 *
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000134 * A combination of the configuration MaxTransferUnit, headers and
135 * TransportOverhead.
niklase@google.com470e71d2011-07-07 08:21:25 +0000136 * Takes into account FEC/ULP/RED overhead if FEC is enabled.
137 * Takes into account RTP headers
138 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000139 virtual uint16_t MaxDataPayloadLength() const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000140
141 /*
niklase@google.com470e71d2011-07-07 08:21:25 +0000142 * set codec name and payload type
143 *
pwestin@webrtc.org1da1ce02011-10-13 15:19:55 +0000144 * return -1 on failure else 0
145 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000146 virtual int32_t RegisterSendPayload(
pwestin@webrtc.org1da1ce02011-10-13 15:19:55 +0000147 const CodecInst& voiceCodec) = 0;
148
149 /*
150 * set codec name and payload type
niklase@google.com470e71d2011-07-07 08:21:25 +0000151 *
152 * return -1 on failure else 0
153 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000154 virtual int32_t RegisterSendPayload(
pwestin@webrtc.org1da1ce02011-10-13 15:19:55 +0000155 const VideoCodec& videoCodec) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000156
157 /*
158 * Unregister a send payload
159 *
160 * payloadType - payload type of codec
161 *
162 * return -1 on failure else 0
163 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000164 virtual int32_t DeRegisterSendPayload(
165 const int8_t payloadType) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000166
asapersson@webrtc.org5249cc82011-12-16 14:31:37 +0000167 /*
168 * (De)register RTP header extension type and id.
169 *
170 * return -1 on failure else 0
171 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000172 virtual int32_t RegisterSendRtpHeaderExtension(
asapersson@webrtc.org5249cc82011-12-16 14:31:37 +0000173 const RTPExtensionType type,
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000174 const uint8_t id) = 0;
asapersson@webrtc.org5249cc82011-12-16 14:31:37 +0000175
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000176 virtual int32_t DeregisterSendRtpHeaderExtension(
asapersson@webrtc.org5249cc82011-12-16 14:31:37 +0000177 const RTPExtensionType type) = 0;
178
niklase@google.com470e71d2011-07-07 08:21:25 +0000179 /*
180 * get start timestamp
181 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000182 virtual uint32_t StartTimestamp() const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000183
184 /*
185 * configure start timestamp, default is a random number
186 *
187 * timestamp - start timestamp
188 *
189 * return -1 on failure else 0
190 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000191 virtual int32_t SetStartTimestamp(
192 const uint32_t timestamp) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000193
194 /*
195 * Get SequenceNumber
196 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000197 virtual uint16_t SequenceNumber() const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000198
199 /*
200 * Set SequenceNumber, default is a random number
201 *
202 * return -1 on failure else 0
203 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000204 virtual int32_t SetSequenceNumber(const uint16_t seq) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000205
206 /*
207 * Get SSRC
208 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000209 virtual uint32_t SSRC() const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000210
211 /*
212 * configure SSRC, default is a random number
213 *
214 * return -1 on failure else 0
215 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000216 virtual int32_t SetSSRC(const uint32_t ssrc) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000217
218 /*
219 * Get CSRC
220 *
221 * arrOfCSRC - array of CSRCs
222 *
223 * return -1 on failure else number of valid entries in the array
224 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000225 virtual int32_t CSRCs(
226 uint32_t arrOfCSRC[kRtpCsrcSize]) const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000227
228 /*
229 * Set CSRC
230 *
231 * arrOfCSRC - array of CSRCs
232 * arrLength - number of valid entries in the array
233 *
234 * return -1 on failure else 0
235 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000236 virtual int32_t SetCSRCs(
237 const uint32_t arrOfCSRC[kRtpCsrcSize],
238 const uint8_t arrLength) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000239
240 /*
241 * includes CSRCs in RTP header if enabled
242 *
243 * include CSRC - on/off
244 *
245 * default:on
246 *
247 * return -1 on failure else 0
248 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000249 virtual int32_t SetCSRCStatus(const bool include) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000250
251 /*
pwestin@webrtc.org8281e7d2012-01-10 14:09:18 +0000252 * Turn on/off sending RTX (RFC 4588) on a specific SSRC.
253 */
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000254 virtual int32_t SetRTXSendStatus(int modes, bool set_ssrc,
mflodman@webrtc.org9f5ebb52013-04-12 14:55:46 +0000255 uint32_t ssrc) = 0;
256
257 // Sets the payload type to use when sending RTX packets. Note that this
258 // doesn't enable RTX, only the payload type is set.
259 virtual void SetRtxSendPayloadType(int payload_type) = 0;
pwestin@webrtc.org8281e7d2012-01-10 14:09:18 +0000260
pwestin@webrtc.org8281e7d2012-01-10 14:09:18 +0000261 /*
262 * Get status of sending RTX (RFC 4588) on a specific SSRC.
263 */
stefan@webrtc.org7e9315b2013-12-04 10:24:26 +0000264 virtual int32_t RTXSendStatus(int* modes, uint32_t* ssrc,
mflodman@webrtc.org9f5ebb52013-04-12 14:55:46 +0000265 int* payloadType) const = 0;
pwestin@webrtc.org8281e7d2012-01-10 14:09:18 +0000266
267 /*
niklase@google.com470e71d2011-07-07 08:21:25 +0000268 * sends kRtcpByeCode when going from true to false
269 *
270 * sending - on/off
271 *
272 * return -1 on failure else 0
273 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000274 virtual int32_t SetSendingStatus(const bool sending) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000275
276 /*
277 * get send status
278 */
279 virtual bool Sending() const = 0;
280
281 /*
282 * Starts/Stops media packets, on by default
283 *
284 * sending - on/off
285 *
286 * return -1 on failure else 0
287 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000288 virtual int32_t SetSendingMediaStatus(const bool sending) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000289
290 /*
291 * get send status
292 */
293 virtual bool SendingMedia() const = 0;
294
295 /*
296 * get sent bitrate in Kbit/s
297 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000298 virtual void BitrateSent(uint32_t* totalRate,
299 uint32_t* videoRate,
300 uint32_t* fecRate,
301 uint32_t* nackRate) const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000302
303 /*
sprang@webrtc.org6811b6e2013-12-13 09:46:59 +0000304 * Called on any new send bitrate estimate.
305 */
306 virtual void RegisterVideoBitrateObserver(
307 BitrateStatisticsObserver* observer) = 0;
308 virtual BitrateStatisticsObserver* GetVideoBitrateObserver() const = 0;
309
310 /*
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000311 * Used by the codec module to deliver a video or audio frame for
312 * packetization.
niklase@google.com470e71d2011-07-07 08:21:25 +0000313 *
314 * frameType - type of frame to send
315 * payloadType - payload type of frame to send
316 * timestamp - timestamp of frame to send
317 * payloadData - payload buffer of frame to send
318 * payloadSize - size of payload buffer to send
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000319 * fragmentation - fragmentation offset data for fragmented frames such
320 * as layers or RED
niklase@google.com470e71d2011-07-07 08:21:25 +0000321 *
322 * return -1 on failure else 0
323 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000324 virtual int32_t SendOutgoingData(
pwestin@webrtc.org8281e7d2012-01-10 14:09:18 +0000325 const FrameType frameType,
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000326 const int8_t payloadType,
327 const uint32_t timeStamp,
stefan@webrtc.orgddfdfed2012-07-03 13:21:22 +0000328 int64_t capture_time_ms,
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000329 const uint8_t* payloadData,
330 const uint32_t payloadSize,
pwestin@webrtc.org8281e7d2012-01-10 14:09:18 +0000331 const RTPFragmentationHeader* fragmentation = NULL,
332 const RTPVideoHeader* rtpVideoHdr = NULL) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000333
stefan@webrtc.org9b82f5a2013-11-13 15:29:21 +0000334 virtual bool TimeToSendPacket(uint32_t ssrc,
335 uint16_t sequence_number,
336 int64_t capture_time_ms,
337 bool retransmission) = 0;
pwestin@webrtc.org571a1c02012-11-13 21:12:39 +0000338
stefan@webrtc.org508a84b2013-06-17 12:53:37 +0000339 virtual int TimeToSendPadding(int bytes) = 0;
340
sprang@webrtc.org71f055f2013-12-04 15:09:27 +0000341 virtual void RegisterSendFrameCountObserver(
342 FrameCountObserver* observer) = 0;
343 virtual FrameCountObserver* GetSendFrameCountObserver() const = 0;
344
stefan@webrtc.org0a3c1472013-12-05 14:05:07 +0000345 virtual bool GetSendSideDelay(int* avg_send_delay_ms,
346 int* max_send_delay_ms) const = 0;
347
sprang@webrtc.orgebad7652013-12-05 14:29:02 +0000348 // Called on generation of new statistics after an RTP send.
349 virtual void RegisterSendChannelRtpStatisticsCallback(
350 StreamDataCountersCallback* callback) = 0;
351 virtual StreamDataCountersCallback*
352 GetSendChannelRtpStatisticsCallback() const = 0;
353
niklase@google.com470e71d2011-07-07 08:21:25 +0000354 /**************************************************************************
355 *
356 * RTCP
357 *
358 ***************************************************************************/
359
360 /*
niklase@google.com470e71d2011-07-07 08:21:25 +0000361 * Get RTCP status
362 */
363 virtual RTCPMethod RTCP() const = 0;
364
365 /*
366 * configure RTCP status i.e on(compound or non- compound)/off
367 *
368 * method - RTCP method to use
369 *
370 * return -1 on failure else 0
371 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000372 virtual int32_t SetRTCPStatus(const RTCPMethod method) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000373
374 /*
375 * Set RTCP CName (i.e unique identifier)
376 *
377 * return -1 on failure else 0
378 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000379 virtual int32_t SetCNAME(const char cName[RTCP_CNAME_SIZE]) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000380
381 /*
382 * Get RTCP CName (i.e unique identifier)
383 *
384 * return -1 on failure else 0
385 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000386 virtual int32_t CNAME(char cName[RTCP_CNAME_SIZE]) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000387
388 /*
389 * Get remote CName
390 *
391 * return -1 on failure else 0
392 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000393 virtual int32_t RemoteCNAME(
394 const uint32_t remoteSSRC,
pwestin@webrtc.orgf6bb77a2012-01-24 17:16:59 +0000395 char cName[RTCP_CNAME_SIZE]) const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000396
397 /*
398 * Get remote NTP
399 *
400 * return -1 on failure else 0
401 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000402 virtual int32_t RemoteNTP(
403 uint32_t *ReceivedNTPsecs,
404 uint32_t *ReceivedNTPfrac,
405 uint32_t *RTCPArrivalTimeSecs,
406 uint32_t *RTCPArrivalTimeFrac,
407 uint32_t *rtcp_timestamp) const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000408
409 /*
410 * AddMixedCNAME
411 *
412 * return -1 on failure else 0
413 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000414 virtual int32_t AddMixedCNAME(
415 const uint32_t SSRC,
pwestin@webrtc.orgf6bb77a2012-01-24 17:16:59 +0000416 const char cName[RTCP_CNAME_SIZE]) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000417
418 /*
419 * RemoveMixedCNAME
420 *
421 * return -1 on failure else 0
422 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000423 virtual int32_t RemoveMixedCNAME(const uint32_t SSRC) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000424
425 /*
426 * Get RoundTripTime
427 *
428 * return -1 on failure else 0
429 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000430 virtual int32_t RTT(const uint32_t remoteSSRC,
431 uint16_t* RTT,
432 uint16_t* avgRTT,
433 uint16_t* minRTT,
434 uint16_t* maxRTT) const = 0 ;
niklase@google.com470e71d2011-07-07 08:21:25 +0000435
436 /*
437 * Reset RoundTripTime statistics
438 *
439 * return -1 on failure else 0
440 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000441 virtual int32_t ResetRTT(const uint32_t remoteSSRC)= 0 ;
niklase@google.com470e71d2011-07-07 08:21:25 +0000442
443 /*
444 * Force a send of a RTCP packet
445 * normal SR and RR are triggered via the process function
446 *
447 * return -1 on failure else 0
448 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000449 virtual int32_t SendRTCP(
450 uint32_t rtcpPacketType = kRtcpReport) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000451
452 /*
453 * Good state of RTP receiver inform sender
454 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000455 virtual int32_t SendRTCPReferencePictureSelection(
456 const uint64_t pictureID) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000457
458 /*
459 * Send a RTCP Slice Loss Indication (SLI)
460 * 6 least significant bits of pictureID
461 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000462 virtual int32_t SendRTCPSliceLossIndication(
463 const uint8_t pictureID) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000464
465 /*
niklase@google.com470e71d2011-07-07 08:21:25 +0000466 * Reset RTP data counters for the sending side
467 *
468 * return -1 on failure else 0
469 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000470 virtual int32_t ResetSendDataCountersRTP() = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000471
472 /*
473 * statistics of the amount of data sent and received
474 *
475 * return -1 on failure else 0
476 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000477 virtual int32_t DataCountersRTP(
478 uint32_t* bytesSent,
wu@webrtc.org822fbd82013-08-15 23:38:54 +0000479 uint32_t* packetsSent) const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000480 /*
481 * Get received RTCP sender info
482 *
483 * return -1 on failure else 0
484 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000485 virtual int32_t RemoteRTCPStat(RTCPSenderInfo* senderInfo) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000486
487 /*
488 * Get received RTCP report block
489 *
490 * return -1 on failure else 0
491 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000492 virtual int32_t RemoteRTCPStat(
perkj@webrtc.orgce5990c2012-01-11 13:00:08 +0000493 std::vector<RTCPReportBlock>* receiveBlocks) const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000494 /*
495 * Set received RTCP report block
496 *
497 * return -1 on failure else 0
498 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000499 virtual int32_t AddRTCPReportBlock(
500 const uint32_t SSRC,
perkj@webrtc.orgce5990c2012-01-11 13:00:08 +0000501 const RTCPReportBlock* receiveBlock) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000502
503 /*
504 * RemoveRTCPReportBlock
505 *
506 * return -1 on failure else 0
507 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000508 virtual int32_t RemoveRTCPReportBlock(const uint32_t SSRC) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000509
510 /*
511 * (APP) Application specific data
512 *
513 * return -1 on failure else 0
514 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000515 virtual int32_t SetRTCPApplicationSpecificData(
516 const uint8_t subType,
517 const uint32_t name,
518 const uint8_t* data,
519 const uint16_t length) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000520 /*
521 * (XR) VOIP metric
522 *
523 * return -1 on failure else 0
524 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000525 virtual int32_t SetRTCPVoIPMetrics(
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000526 const RTCPVoIPMetric* VoIPMetric) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000527
528 /*
asapersson@webrtc.org7d6bd222013-10-31 12:14:34 +0000529 * (XR) Receiver Reference Time Report
530 */
531 virtual void SetRtcpXrRrtrStatus(bool enable) = 0;
532
asapersson@webrtc.org8d02f5d2013-11-21 08:57:04 +0000533 virtual bool RtcpXrRrtrStatus() const = 0;
534
asapersson@webrtc.org7d6bd222013-10-31 12:14:34 +0000535 /*
pwestin@webrtc.org741da942011-09-20 13:52:04 +0000536 * (REMB) Receiver Estimated Max Bitrate
537 */
asapersson@webrtc.org5249cc82011-12-16 14:31:37 +0000538 virtual bool REMB() const = 0;
pwestin@webrtc.org741da942011-09-20 13:52:04 +0000539
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000540 virtual int32_t SetREMBStatus(const bool enable) = 0;
pwestin@webrtc.org741da942011-09-20 13:52:04 +0000541
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000542 virtual int32_t SetREMBData(const uint32_t bitrate,
543 const uint8_t numberOfSSRC,
544 const uint32_t* SSRC) = 0;
asapersson@webrtc.org5249cc82011-12-16 14:31:37 +0000545
546 /*
547 * (IJ) Extended jitter report.
548 */
549 virtual bool IJ() const = 0;
550
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000551 virtual int32_t SetIJStatus(const bool enable) = 0;
asapersson@webrtc.org5249cc82011-12-16 14:31:37 +0000552
pwestin@webrtc.org741da942011-09-20 13:52:04 +0000553 /*
niklase@google.com470e71d2011-07-07 08:21:25 +0000554 * (TMMBR) Temporary Max Media Bit Rate
555 */
asapersson@webrtc.org5249cc82011-12-16 14:31:37 +0000556 virtual bool TMMBR() const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000557
558 /*
559 *
560 * return -1 on failure else 0
561 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000562 virtual int32_t SetTMMBRStatus(const bool enable) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000563
564 /*
niklase@google.com470e71d2011-07-07 08:21:25 +0000565 * (NACK)
566 */
niklase@google.com470e71d2011-07-07 08:21:25 +0000567
568 /*
stefan@webrtc.org6a4bef42011-12-22 12:52:41 +0000569 * TODO(holmer): Propagate this API to VideoEngine.
570 * Returns the currently configured selective retransmission settings.
571 */
572 virtual int SelectiveRetransmissions() const = 0;
573
574 /*
575 * TODO(holmer): Propagate this API to VideoEngine.
576 * Sets the selective retransmission settings, which will decide which
577 * packets will be retransmitted if NACKed. Settings are constructed by
578 * combining the constants in enum RetransmissionMode with bitwise OR.
579 * All packets are retransmitted if kRetransmitAllPackets is set, while no
580 * packets are retransmitted if kRetransmitOff is set.
581 * By default all packets except FEC packets are retransmitted. For VP8
582 * with temporal scalability only base layer packets are retransmitted.
583 *
584 * Returns -1 on failure, otherwise 0.
585 */
586 virtual int SetSelectiveRetransmissions(uint8_t settings) = 0;
587
588 /*
niklase@google.com470e71d2011-07-07 08:21:25 +0000589 * Send a Negative acknowledgement packet
590 *
591 * return -1 on failure else 0
592 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000593 virtual int32_t SendNACK(const uint16_t* nackList,
594 const uint16_t size) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000595
596 /*
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000597 * Store the sent packets, needed to answer to a Negative acknowledgement
598 * requests
niklase@google.com470e71d2011-07-07 08:21:25 +0000599 *
600 * return -1 on failure else 0
601 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000602 virtual int32_t SetStorePacketsStatus(
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000603 const bool enable,
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000604 const uint16_t numberToStore) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000605
wu@webrtc.org822fbd82013-08-15 23:38:54 +0000606 // Returns true if the module is configured to store packets.
607 virtual bool StorePackets() const = 0;
608
sprang@webrtc.orga6ad6e52013-12-05 09:48:44 +0000609 // Called on receipt of RTCP report block from remote side.
610 virtual void RegisterSendChannelRtcpStatisticsCallback(
611 RtcpStatisticsCallback* callback) = 0;
612 virtual RtcpStatisticsCallback*
613 GetSendChannelRtcpStatisticsCallback() = 0;
614
niklase@google.com470e71d2011-07-07 08:21:25 +0000615 /**************************************************************************
616 *
617 * Audio
618 *
619 ***************************************************************************/
620
621 /*
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000622 * set audio packet size, used to determine when it's time to send a DTMF
623 * packet in silence (CNG)
niklase@google.com470e71d2011-07-07 08:21:25 +0000624 *
625 * return -1 on failure else 0
626 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000627 virtual int32_t SetAudioPacketSize(
628 const uint16_t packetSizeSamples) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000629
630 /*
niklase@google.com470e71d2011-07-07 08:21:25 +0000631 * SendTelephoneEventActive
632 *
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000633 * return true if we currently send a telephone event and 100 ms after an
634 * event is sent used to prevent the telephone event tone to be recorded
635 * by the microphone and send inband just after the tone has ended.
niklase@google.com470e71d2011-07-07 08:21:25 +0000636 */
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000637 virtual bool SendTelephoneEventActive(
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000638 int8_t& telephoneEvent) const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000639
640 /*
641 * Send a TelephoneEvent tone using RFC 2833 (4733)
642 *
643 * return -1 on failure else 0
644 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000645 virtual int32_t SendTelephoneEventOutband(
646 const uint8_t key,
647 const uint16_t time_ms,
648 const uint8_t level) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000649
650 /*
651 * Set payload type for Redundant Audio Data RFC 2198
652 *
653 * return -1 on failure else 0
654 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000655 virtual int32_t SetSendREDPayloadType(
656 const int8_t payloadType) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000657
658 /*
659 * Get payload type for Redundant Audio Data RFC 2198
660 *
661 * return -1 on failure else 0
662 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000663 virtual int32_t SendREDPayloadType(
664 int8_t& payloadType) const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000665
666 /*
667 * Set status and ID for header-extension-for-audio-level-indication.
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000668 * See http://tools.ietf.org/html/rfc6464 for more details.
niklase@google.com470e71d2011-07-07 08:21:25 +0000669 *
670 * return -1 on failure else 0
671 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000672 virtual int32_t SetRTPAudioLevelIndicationStatus(
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000673 const bool enable,
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000674 const uint8_t ID) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000675
676 /*
677 * Get status and ID for header-extension-for-audio-level-indication.
678 *
679 * return -1 on failure else 0
680 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000681 virtual int32_t GetRTPAudioLevelIndicationStatus(
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000682 bool& enable,
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000683 uint8_t& ID) const = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000684
685 /*
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000686 * Store the audio level in dBov for header-extension-for-audio-level-
687 * indication.
niklase@google.com470e71d2011-07-07 08:21:25 +0000688 * This API shall be called before transmision of an RTP packet to ensure
689 * that the |level| part of the extended RTP header is updated.
690 *
691 * return -1 on failure else 0.
692 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000693 virtual int32_t SetAudioLevel(const uint8_t level_dBov) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000694
695 /**************************************************************************
696 *
697 * Video
698 *
699 ***************************************************************************/
700
701 /*
stefan@webrtc.org7da34592013-04-09 14:56:29 +0000702 * Set the estimated camera delay in MS
703 *
704 * return -1 on failure else 0
705 */
706 virtual int32_t SetCameraDelay(const int32_t delayMS) = 0;
707
708 /*
pwestin@webrtc.org49888ce2012-04-27 05:25:53 +0000709 * Set the target send bitrate
niklase@google.com470e71d2011-07-07 08:21:25 +0000710 */
stefan@webrtc.orgb2c8a952013-09-06 13:58:01 +0000711 virtual void SetTargetSendBitrate(
712 const std::vector<uint32_t>& stream_bitrates) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000713
714 /*
715 * Turn on/off generic FEC
716 *
717 * return -1 on failure else 0
718 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000719 virtual int32_t SetGenericFECStatus(
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000720 const bool enable,
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000721 const uint8_t payloadTypeRED,
722 const uint8_t payloadTypeFEC) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000723
724 /*
725 * Get generic FEC setting
726 *
727 * return -1 on failure else 0
728 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000729 virtual int32_t GenericFECStatus(bool& enable,
730 uint8_t& payloadTypeRED,
731 uint8_t& payloadTypeFEC) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000732
marpan@google.com80c5d7a2011-07-15 21:32:40 +0000733
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000734 virtual int32_t SetFecParameters(
stefan@webrtc.orge0d6fa42012-03-20 22:10:56 +0000735 const FecProtectionParams* delta_params,
736 const FecProtectionParams* key_params) = 0;
marpan@google.com80c5d7a2011-07-15 21:32:40 +0000737
niklase@google.com470e71d2011-07-07 08:21:25 +0000738 /*
739 * Set method for requestion a new key frame
740 *
741 * return -1 on failure else 0
742 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000743 virtual int32_t SetKeyFrameRequestMethod(
pwestin@webrtc.org2853dde2012-05-11 11:08:54 +0000744 const KeyFrameRequestMethod method) = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000745
746 /*
747 * send a request for a keyframe
748 *
749 * return -1 on failure else 0
750 */
pbos@webrtc.org2f446732013-04-08 11:08:41 +0000751 virtual int32_t RequestKeyFrame() = 0;
niklase@google.com470e71d2011-07-07 08:21:25 +0000752};
pbos@webrtc.orgd900e8b2013-07-03 15:12:26 +0000753} // namespace webrtc
niklase@google.com470e71d2011-07-07 08:21:25 +0000754#endif // WEBRTC_MODULES_RTP_RTCP_INTERFACE_RTP_RTCP_H_