niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 1 | /* |
pwestin@webrtc.org | f6bb77a | 2012-01-24 17:16:59 +0000 | [diff] [blame] | 2 | * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 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 | */ |
| 10 | |
| 11 | #ifndef WEBRTC_MODULES_RTP_RTCP_SOURCE_RTP_SENDER_H_ |
| 12 | #define WEBRTC_MODULES_RTP_RTCP_SOURCE_RTP_SENDER_H_ |
| 13 | |
pbos@webrtc.org | 12dc1a3 | 2013-08-05 16:22:53 +0000 | [diff] [blame] | 14 | #include <assert.h> |
| 15 | #include <math.h> |
| 16 | |
pwestin@webrtc.org | 0074187 | 2012-01-19 15:56:10 +0000 | [diff] [blame] | 17 | #include <map> |
| 18 | |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 19 | #include "webrtc/common_types.h" |
stefan@webrtc.org | 508a84b | 2013-06-17 12:53:37 +0000 | [diff] [blame] | 20 | #include "webrtc/modules/pacing/include/paced_sender.h" |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 21 | #include "webrtc/modules/rtp_rtcp/interface/rtp_rtcp_defines.h" |
phoglund@webrtc.org | c38eef8 | 2013-01-07 10:18:30 +0000 | [diff] [blame] | 22 | #include "webrtc/modules/rtp_rtcp/source/bitrate.h" |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 23 | #include "webrtc/modules/rtp_rtcp/source/rtp_header_extension.h" |
stefan@webrtc.org | 7e9315b | 2013-12-04 10:24:26 +0000 | [diff] [blame] | 24 | #include "webrtc/modules/rtp_rtcp/source/rtp_packet_history.h" |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 25 | #include "webrtc/modules/rtp_rtcp/source/rtp_rtcp_config.h" |
| 26 | #include "webrtc/modules/rtp_rtcp/source/ssrc_database.h" |
| 27 | #include "webrtc/modules/rtp_rtcp/source/video_codec_information.h" |
sprang@webrtc.org | 5a320fb | 2014-03-13 15:12:37 +0000 | [diff] [blame] | 28 | #include "webrtc/system_wrappers/interface/thread_annotations.h" |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 29 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 30 | #define MAX_INIT_RTP_SEQ_NUMBER 32767 // 2^15 -1. |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 31 | |
| 32 | namespace webrtc { |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 33 | |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 34 | class CriticalSectionWrapper; |
| 35 | class RTPSenderAudio; |
| 36 | class RTPSenderVideo; |
| 37 | |
pwestin@webrtc.org | c66e8b3 | 2012-11-07 17:01:04 +0000 | [diff] [blame] | 38 | class RTPSenderInterface { |
| 39 | public: |
| 40 | RTPSenderInterface() {} |
| 41 | virtual ~RTPSenderInterface() {} |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 42 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 43 | virtual uint32_t SSRC() const = 0; |
| 44 | virtual uint32_t Timestamp() const = 0; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 45 | |
pbos@webrtc.org | 2bb1bda | 2014-07-07 13:06:48 +0000 | [diff] [blame] | 46 | virtual int32_t BuildRTPheader(uint8_t* data_buffer, |
| 47 | const int8_t payload_type, |
| 48 | const bool marker_bit, |
| 49 | const uint32_t capture_timestamp, |
| 50 | int64_t capture_time_ms, |
| 51 | const bool timestamp_provided = true, |
| 52 | const bool inc_sequence_number = true) = 0; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 53 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 54 | virtual uint16_t RTPHeaderLength() const = 0; |
| 55 | virtual uint16_t IncrementSequenceNumber() = 0; |
| 56 | virtual uint16_t SequenceNumber() const = 0; |
| 57 | virtual uint16_t MaxPayloadLength() const = 0; |
| 58 | virtual uint16_t MaxDataPayloadLength() const = 0; |
| 59 | virtual uint16_t PacketOverHead() const = 0; |
| 60 | virtual uint16_t ActualSendBitrateKbit() const = 0; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 61 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 62 | virtual int32_t SendToNetwork( |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 63 | uint8_t *data_buffer, int payload_length, int rtp_header_length, |
stefan@webrtc.org | 508a84b | 2013-06-17 12:53:37 +0000 | [diff] [blame] | 64 | int64_t capture_time_ms, StorageType storage, |
| 65 | PacedSender::Priority priority) = 0; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 66 | }; |
| 67 | |
sprang@webrtc.org | 6811b6e | 2013-12-13 09:46:59 +0000 | [diff] [blame] | 68 | class RTPSender : public RTPSenderInterface, public Bitrate::Observer { |
pwestin@webrtc.org | c66e8b3 | 2012-11-07 17:01:04 +0000 | [diff] [blame] | 69 | public: |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 70 | RTPSender(const int32_t id, const bool audio, Clock *clock, |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 71 | Transport *transport, RtpAudioFeedback *audio_feedback, |
andresp@webrtc.org | d11bec4 | 2014-07-08 14:32:58 +0000 | [diff] [blame] | 72 | PacedSender *paced_sender, |
andresp@webrtc.org | 8f15121 | 2014-07-10 09:39:23 +0000 | [diff] [blame] | 73 | BitrateStatisticsObserver* bitrate_callback, |
stefan@webrtc.org | 168f23f | 2014-07-11 13:44:02 +0000 | [diff] [blame] | 74 | FrameCountObserver* frame_count_observer, |
| 75 | SendSideDelayObserver* send_side_delay_observer); |
pwestin@webrtc.org | c66e8b3 | 2012-11-07 17:01:04 +0000 | [diff] [blame] | 76 | virtual ~RTPSender(); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 77 | |
pwestin@webrtc.org | c66e8b3 | 2012-11-07 17:01:04 +0000 | [diff] [blame] | 78 | void ProcessBitrate(); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 79 | |
pbos@webrtc.org | f3e4cee | 2013-07-31 15:17:19 +0000 | [diff] [blame] | 80 | virtual uint16_t ActualSendBitrateKbit() const OVERRIDE; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 81 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 82 | uint32_t VideoBitrateSent() const; |
| 83 | uint32_t FecOverheadRate() const; |
| 84 | uint32_t NackOverheadRate() const; |
stefan@webrtc.org | d0bdab0 | 2011-10-14 14:24:54 +0000 | [diff] [blame] | 85 | |
stefan@webrtc.org | 0a3c147 | 2013-12-05 14:05:07 +0000 | [diff] [blame] | 86 | // Returns true if the statistics have been calculated, and false if no frame |
| 87 | // was sent within the statistics window. |
| 88 | bool GetSendSideDelay(int* avg_send_delay_ms, int* max_send_delay_ms) const; |
| 89 | |
stefan@webrtc.org | a15fbfd | 2014-06-17 17:32:05 +0000 | [diff] [blame] | 90 | void SetTargetBitrate(uint32_t bitrate); |
| 91 | uint32_t GetTargetBitrate(); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 92 | |
pbos@webrtc.org | f3e4cee | 2013-07-31 15:17:19 +0000 | [diff] [blame] | 93 | virtual uint16_t MaxDataPayloadLength() const |
| 94 | OVERRIDE; // with RTP and FEC headers. |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 95 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 96 | int32_t RegisterPayload( |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 97 | const char payload_name[RTP_PAYLOAD_NAME_SIZE], |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 98 | const int8_t payload_type, const uint32_t frequency, |
| 99 | const uint8_t channels, const uint32_t rate); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 100 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 101 | int32_t DeRegisterSendPayload(const int8_t payload_type); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 102 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 103 | int8_t SendPayloadType() const; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 104 | |
pwestin@webrtc.org | c66e8b3 | 2012-11-07 17:01:04 +0000 | [diff] [blame] | 105 | int SendPayloadFrequency() const; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 106 | |
pbos@webrtc.org | 59f20bb | 2013-09-09 16:02:19 +0000 | [diff] [blame] | 107 | void SetSendingStatus(bool enabled); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 108 | |
pwestin@webrtc.org | c66e8b3 | 2012-11-07 17:01:04 +0000 | [diff] [blame] | 109 | void SetSendingMediaStatus(const bool enabled); |
| 110 | bool SendingMedia() const; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 111 | |
pbos@webrtc.org | 2f4b14e | 2014-07-15 15:25:39 +0000 | [diff] [blame] | 112 | void GetDataCounters(StreamDataCounters* rtp_stats, |
| 113 | StreamDataCounters* rtx_stats) const; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 114 | |
pwestin@webrtc.org | c66e8b3 | 2012-11-07 17:01:04 +0000 | [diff] [blame] | 115 | void ResetDataCounters(); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 116 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 117 | uint32_t StartTimestamp() const; |
| 118 | void SetStartTimestamp(uint32_t timestamp, bool force); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 119 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 120 | uint32_t GenerateNewSSRC(); |
| 121 | void SetSSRC(const uint32_t ssrc); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 122 | |
pbos@webrtc.org | f3e4cee | 2013-07-31 15:17:19 +0000 | [diff] [blame] | 123 | virtual uint16_t SequenceNumber() const OVERRIDE; |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 124 | void SetSequenceNumber(uint16_t seq); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 125 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 126 | int32_t CSRCs(uint32_t arr_of_csrc[kRtpCsrcSize]) const; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 127 | |
pwestin@webrtc.org | c66e8b3 | 2012-11-07 17:01:04 +0000 | [diff] [blame] | 128 | void SetCSRCStatus(const bool include); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 129 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 130 | void SetCSRCs(const uint32_t arr_of_csrc[kRtpCsrcSize], |
| 131 | const uint8_t arr_length); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 132 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 133 | int32_t SetMaxPayloadLength(const uint16_t length, |
| 134 | const uint16_t packet_over_head); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 135 | |
pbos@webrtc.org | 2bb1bda | 2014-07-07 13:06:48 +0000 | [diff] [blame] | 136 | int32_t SendOutgoingData(const FrameType frame_type, |
| 137 | const int8_t payload_type, |
| 138 | const uint32_t timestamp, |
| 139 | int64_t capture_time_ms, |
| 140 | const uint8_t* payload_data, |
| 141 | const uint32_t payload_size, |
| 142 | const RTPFragmentationHeader* fragmentation, |
| 143 | VideoCodecInformation* codec_info = NULL, |
| 144 | const RTPVideoTypeHeader* rtp_type_hdr = NULL); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 145 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 146 | // RTP header extension |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 147 | int32_t SetTransmissionTimeOffset( |
| 148 | const int32_t transmission_time_offset); |
solenberg@webrtc.org | 7ebbea1 | 2013-05-16 11:10:31 +0000 | [diff] [blame] | 149 | int32_t SetAbsoluteSendTime( |
| 150 | const uint32_t absolute_send_time); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 151 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 152 | int32_t RegisterRtpHeaderExtension(const RTPExtensionType type, |
| 153 | const uint8_t id); |
asapersson@webrtc.org | 5249cc8 | 2011-12-16 14:31:37 +0000 | [diff] [blame] | 154 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 155 | int32_t DeregisterRtpHeaderExtension(const RTPExtensionType type); |
asapersson@webrtc.org | 5249cc8 | 2011-12-16 14:31:37 +0000 | [diff] [blame] | 156 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 157 | uint16_t RtpHeaderExtensionTotalLength() const; |
asapersson@webrtc.org | 5249cc8 | 2011-12-16 14:31:37 +0000 | [diff] [blame] | 158 | |
stefan@webrtc.org | a817962 | 2013-06-04 13:47:36 +0000 | [diff] [blame] | 159 | uint16_t BuildRTPHeaderExtension(uint8_t* data_buffer) const; |
asapersson@webrtc.org | 5249cc8 | 2011-12-16 14:31:37 +0000 | [diff] [blame] | 160 | |
wu@webrtc.org | ebdb0e3 | 2014-03-06 23:49:08 +0000 | [diff] [blame] | 161 | uint8_t BuildTransmissionTimeOffsetExtension(uint8_t *data_buffer) const; |
| 162 | uint8_t BuildAudioLevelExtension(uint8_t* data_buffer) const; |
| 163 | uint8_t BuildAbsoluteSendTimeExtension(uint8_t* data_buffer) const; |
asapersson@webrtc.org | 5249cc8 | 2011-12-16 14:31:37 +0000 | [diff] [blame] | 164 | |
wu@webrtc.org | ebdb0e3 | 2014-03-06 23:49:08 +0000 | [diff] [blame] | 165 | bool UpdateAudioLevel(uint8_t *rtp_packet, |
| 166 | const uint16_t rtp_packet_length, |
| 167 | const RTPHeader &rtp_header, |
| 168 | const bool is_voiced, |
| 169 | const uint8_t dBov) const; |
asapersson@webrtc.org | 5249cc8 | 2011-12-16 14:31:37 +0000 | [diff] [blame] | 170 | |
stefan@webrtc.org | 9b82f5a | 2013-11-13 15:29:21 +0000 | [diff] [blame] | 171 | bool TimeToSendPacket(uint16_t sequence_number, int64_t capture_time_ms, |
| 172 | bool retransmission); |
stefan@webrtc.org | 508a84b | 2013-06-17 12:53:37 +0000 | [diff] [blame] | 173 | int TimeToSendPadding(int bytes); |
asapersson@webrtc.org | 0b3c35a | 2012-01-16 11:06:31 +0000 | [diff] [blame] | 174 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 175 | // NACK. |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 176 | int SelectiveRetransmissions() const; |
| 177 | int SetSelectiveRetransmissions(uint8_t settings); |
stefan@webrtc.org | becf9c8 | 2013-02-01 15:09:57 +0000 | [diff] [blame] | 178 | void OnReceivedNACK(const std::list<uint16_t>& nack_sequence_numbers, |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 179 | const uint16_t avg_rtt); |
asapersson@webrtc.org | 0b3c35a | 2012-01-16 11:06:31 +0000 | [diff] [blame] | 180 | |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 181 | void SetStorePacketsStatus(const bool enable, |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 182 | const uint16_t number_to_store); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 183 | |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 184 | bool StorePackets() const; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 185 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 186 | int32_t ReSendPacket(uint16_t packet_id, uint32_t min_resend_time = 0); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 187 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 188 | bool ProcessNACKBitRate(const uint32_t now); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 189 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 190 | // RTX. |
stefan@webrtc.org | ef92755 | 2014-06-05 08:25:29 +0000 | [diff] [blame] | 191 | void SetRTXStatus(int mode); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 192 | |
stefan@webrtc.org | 7e9315b | 2013-12-04 10:24:26 +0000 | [diff] [blame] | 193 | void RTXStatus(int* mode, uint32_t* ssrc, int* payload_type) const; |
mflodman@webrtc.org | 9f5ebb5 | 2013-04-12 14:55:46 +0000 | [diff] [blame] | 194 | |
pbos@webrtc.org | 2bb1bda | 2014-07-07 13:06:48 +0000 | [diff] [blame] | 195 | uint32_t RtxSsrc() const; |
stefan@webrtc.org | ef92755 | 2014-06-05 08:25:29 +0000 | [diff] [blame] | 196 | void SetRtxSsrc(uint32_t ssrc); |
| 197 | |
mflodman@webrtc.org | 9f5ebb5 | 2013-04-12 14:55:46 +0000 | [diff] [blame] | 198 | void SetRtxPayloadType(int payloadType); |
pwestin@webrtc.org | 8281e7d | 2012-01-10 14:09:18 +0000 | [diff] [blame] | 199 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 200 | // Functions wrapping RTPSenderInterface. |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 201 | virtual int32_t BuildRTPheader( |
pbos@webrtc.org | 2bb1bda | 2014-07-07 13:06:48 +0000 | [diff] [blame] | 202 | uint8_t* data_buffer, |
| 203 | const int8_t payload_type, |
| 204 | const bool marker_bit, |
| 205 | const uint32_t capture_timestamp, |
stefan@webrtc.org | 8ccb9f9 | 2013-06-19 14:13:42 +0000 | [diff] [blame] | 206 | int64_t capture_time_ms, |
pbos@webrtc.org | 2bb1bda | 2014-07-07 13:06:48 +0000 | [diff] [blame] | 207 | const bool timestamp_provided = true, |
pbos@webrtc.org | f3e4cee | 2013-07-31 15:17:19 +0000 | [diff] [blame] | 208 | const bool inc_sequence_number = true) OVERRIDE; |
pwestin@webrtc.org | 8281e7d | 2012-01-10 14:09:18 +0000 | [diff] [blame] | 209 | |
pbos@webrtc.org | f3e4cee | 2013-07-31 15:17:19 +0000 | [diff] [blame] | 210 | virtual uint16_t RTPHeaderLength() const OVERRIDE; |
| 211 | virtual uint16_t IncrementSequenceNumber() OVERRIDE; |
| 212 | virtual uint16_t MaxPayloadLength() const OVERRIDE; |
| 213 | virtual uint16_t PacketOverHead() const OVERRIDE; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 214 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 215 | // Current timestamp. |
pbos@webrtc.org | f3e4cee | 2013-07-31 15:17:19 +0000 | [diff] [blame] | 216 | virtual uint32_t Timestamp() const OVERRIDE; |
| 217 | virtual uint32_t SSRC() const OVERRIDE; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 218 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 219 | virtual int32_t SendToNetwork( |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 220 | uint8_t *data_buffer, int payload_length, int rtp_header_length, |
stefan@webrtc.org | 508a84b | 2013-06-17 12:53:37 +0000 | [diff] [blame] | 221 | int64_t capture_time_ms, StorageType storage, |
pbos@webrtc.org | f3e4cee | 2013-07-31 15:17:19 +0000 | [diff] [blame] | 222 | PacedSender::Priority priority) OVERRIDE; |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 223 | |
| 224 | // Audio. |
| 225 | |
| 226 | // Send a DTMF tone using RFC 2833 (4733). |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 227 | int32_t SendTelephoneEvent(const uint8_t key, |
| 228 | const uint16_t time_ms, |
| 229 | const uint8_t level); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 230 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 231 | bool SendTelephoneEventActive(int8_t *telephone_event) const; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 232 | |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 233 | // Set audio packet size, used to determine when it's time to send a DTMF |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 234 | // packet in silence (CNG). |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 235 | int32_t SetAudioPacketSize(const uint16_t packet_size_samples); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 236 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 237 | // Store the audio level in d_bov for |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 238 | // header-extension-for-audio-level-indication. |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 239 | int32_t SetAudioLevel(const uint8_t level_d_bov); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 240 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 241 | // Set payload type for Redundant Audio Data RFC 2198. |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 242 | int32_t SetRED(const int8_t payload_type); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 243 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 244 | // Get payload type for Redundant Audio Data RFC 2198. |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 245 | int32_t RED(int8_t *payload_type) const; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 246 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 247 | // Video. |
| 248 | VideoCodecInformation *CodecInformationVideo(); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 249 | |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 250 | RtpVideoCodecTypes VideoCodecType() const; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 251 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 252 | uint32_t MaxConfiguredBitrateVideo() const; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 253 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 254 | int32_t SendRTPIntraRequest(); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 255 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 256 | // FEC. |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 257 | int32_t SetGenericFECStatus(const bool enable, |
| 258 | const uint8_t payload_type_red, |
| 259 | const uint8_t payload_type_fec); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 260 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 261 | int32_t GenericFECStatus(bool *enable, uint8_t *payload_type_red, |
| 262 | uint8_t *payload_type_fec) const; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 263 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 264 | int32_t SetFecParameters(const FecProtectionParams *delta_params, |
| 265 | const FecProtectionParams *key_params); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 266 | |
pbos@webrtc.org | 72491b9 | 2014-07-10 16:24:54 +0000 | [diff] [blame] | 267 | int SendPadData(int payload_type, |
| 268 | uint32_t timestamp, |
| 269 | int64_t capture_time_ms, |
pbos@webrtc.org | 63c60ed | 2014-07-16 09:37:29 +0000 | [diff] [blame] | 270 | int32_t bytes); |
stefan@webrtc.org | c4726d0 | 2013-12-05 09:16:33 +0000 | [diff] [blame] | 271 | |
sprang@webrtc.org | ebad765 | 2013-12-05 14:29:02 +0000 | [diff] [blame] | 272 | // Called on update of RTP statistics. |
| 273 | void RegisterRtpStatisticsCallback(StreamDataCountersCallback* callback); |
| 274 | StreamDataCountersCallback* GetRtpStatisticsCallback() const; |
| 275 | |
sprang@webrtc.org | 6811b6e | 2013-12-13 09:46:59 +0000 | [diff] [blame] | 276 | uint32_t BitrateSent() const; |
| 277 | |
| 278 | virtual void BitrateUpdated(const BitrateStatistics& stats) OVERRIDE; |
| 279 | |
pbos@webrtc.org | 2bb1bda | 2014-07-07 13:06:48 +0000 | [diff] [blame] | 280 | void SetRtpState(const RtpState& rtp_state); |
| 281 | RtpState GetRtpState() const; |
| 282 | void SetRtxRtpState(const RtpState& rtp_state); |
| 283 | RtpState GetRtxRtpState() const; |
| 284 | |
pwestin@webrtc.org | c66e8b3 | 2012-11-07 17:01:04 +0000 | [diff] [blame] | 285 | protected: |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 286 | int32_t CheckPayloadType(const int8_t payload_type, |
| 287 | RtpVideoCodecTypes *video_type); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 288 | |
pwestin@webrtc.org | c66e8b3 | 2012-11-07 17:01:04 +0000 | [diff] [blame] | 289 | private: |
stefan@webrtc.org | 0a3c147 | 2013-12-05 14:05:07 +0000 | [diff] [blame] | 290 | // Maps capture time in milliseconds to send-side delay in milliseconds. |
| 291 | // Send-side delay is the difference between transmission time and capture |
| 292 | // time. |
| 293 | typedef std::map<int64_t, int> SendDelayMap; |
| 294 | |
stefan@webrtc.org | a817962 | 2013-06-04 13:47:36 +0000 | [diff] [blame] | 295 | int CreateRTPHeader(uint8_t* header, int8_t payload_type, |
| 296 | uint32_t ssrc, bool marker_bit, |
| 297 | uint32_t timestamp, uint16_t sequence_number, |
| 298 | const uint32_t* csrcs, uint8_t csrcs_length) const; |
| 299 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 300 | void UpdateNACKBitRate(const uint32_t bytes, const uint32_t now); |
pwestin@webrtc.org | 8281e7d | 2012-01-10 14:09:18 +0000 | [diff] [blame] | 301 | |
stefan@webrtc.org | 7e9315b | 2013-12-04 10:24:26 +0000 | [diff] [blame] | 302 | bool PrepareAndSendPacket(uint8_t* buffer, |
| 303 | uint16_t length, |
| 304 | int64_t capture_time_ms, |
stefan@webrtc.org | 7c6ff2d | 2014-03-19 18:14:52 +0000 | [diff] [blame] | 305 | bool send_over_rtx, |
| 306 | bool is_retransmit); |
stefan@webrtc.org | 7e9315b | 2013-12-04 10:24:26 +0000 | [diff] [blame] | 307 | |
| 308 | int SendRedundantPayloads(int payload_type, int bytes); |
| 309 | |
stefan@webrtc.org | 7e9315b | 2013-12-04 10:24:26 +0000 | [diff] [blame] | 310 | int BuildPaddingPacket(uint8_t* packet, int header_length, int32_t bytes); |
phoglund@webrtc.org | baaf243 | 2012-05-31 10:47:35 +0000 | [diff] [blame] | 311 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 312 | void BuildRtxPacket(uint8_t* buffer, uint16_t* length, |
| 313 | uint8_t* buffer_rtx); |
mikhal@webrtc.org | bda7f30 | 2013-03-15 23:21:52 +0000 | [diff] [blame] | 314 | |
pwestin@webrtc.org | b0061f9 | 2013-04-27 00:41:08 +0000 | [diff] [blame] | 315 | bool SendPacketToNetwork(const uint8_t *packet, uint32_t size); |
| 316 | |
stefan@webrtc.org | 0a3c147 | 2013-12-05 14:05:07 +0000 | [diff] [blame] | 317 | void UpdateDelayStatistics(int64_t capture_time_ms, int64_t now_ms); |
| 318 | |
stefan@webrtc.org | 420b256 | 2014-05-30 12:17:15 +0000 | [diff] [blame] | 319 | void UpdateTransmissionTimeOffset(uint8_t *rtp_packet, |
| 320 | const uint16_t rtp_packet_length, |
| 321 | const RTPHeader &rtp_header, |
| 322 | const int64_t time_diff_ms) const; |
| 323 | void UpdateAbsoluteSendTime(uint8_t *rtp_packet, |
| 324 | const uint16_t rtp_packet_length, |
| 325 | const RTPHeader &rtp_header, |
| 326 | const int64_t now_ms) const; |
| 327 | |
sprang@webrtc.org | ebad765 | 2013-12-05 14:29:02 +0000 | [diff] [blame] | 328 | void UpdateRtpStats(const uint8_t* buffer, |
| 329 | uint32_t size, |
| 330 | const RTPHeader& header, |
| 331 | bool is_rtx, |
| 332 | bool is_retransmit); |
| 333 | bool IsFecPacket(const uint8_t* buffer, const RTPHeader& header) const; |
| 334 | |
sprang@webrtc.org | 6811b6e | 2013-12-13 09:46:59 +0000 | [diff] [blame] | 335 | Clock* clock_; |
| 336 | Bitrate bitrate_sent_; |
| 337 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 338 | int32_t id_; |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 339 | const bool audio_configured_; |
| 340 | RTPSenderAudio *audio_; |
| 341 | RTPSenderVideo *video_; |
phoglund@webrtc.org | baaf243 | 2012-05-31 10:47:35 +0000 | [diff] [blame] | 342 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 343 | PacedSender *paced_sender_; |
| 344 | CriticalSectionWrapper *send_critsect_; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 345 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 346 | Transport *transport_; |
sprang@webrtc.org | 5a320fb | 2014-03-13 15:12:37 +0000 | [diff] [blame] | 347 | bool sending_media_ GUARDED_BY(send_critsect_); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 348 | |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 349 | uint16_t max_payload_length_; |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 350 | uint16_t packet_over_head_; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 351 | |
sprang@webrtc.org | efcad39 | 2014-03-25 16:51:35 +0000 | [diff] [blame] | 352 | int8_t payload_type_ GUARDED_BY(send_critsect_); |
pbos@webrtc.org | 62bafae | 2014-07-08 12:10:51 +0000 | [diff] [blame] | 353 | std::map<int8_t, RtpUtility::Payload*> payload_type_map_; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 354 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 355 | RtpHeaderExtensionMap rtp_header_extension_map_; |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 356 | int32_t transmission_time_offset_; |
solenberg@webrtc.org | 7ebbea1 | 2013-05-16 11:10:31 +0000 | [diff] [blame] | 357 | uint32_t absolute_send_time_; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 358 | |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 359 | // NACK |
pbos@webrtc.org | 2f44673 | 2013-04-08 11:08:41 +0000 | [diff] [blame] | 360 | uint32_t nack_byte_count_times_[NACK_BYTECOUNT_SIZE]; |
| 361 | int32_t nack_byte_count_[NACK_BYTECOUNT_SIZE]; |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 362 | Bitrate nack_bitrate_; |
asapersson@webrtc.org | 5249cc8 | 2011-12-16 14:31:37 +0000 | [diff] [blame] | 363 | |
stefan@webrtc.org | 7e9315b | 2013-12-04 10:24:26 +0000 | [diff] [blame] | 364 | RTPPacketHistory packet_history_; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 365 | |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 366 | // Statistics |
pbos@webrtc.org | e07049f | 2013-09-10 11:29:17 +0000 | [diff] [blame] | 367 | scoped_ptr<CriticalSectionWrapper> statistics_crit_; |
pbos@webrtc.org | 2bb1bda | 2014-07-07 13:06:48 +0000 | [diff] [blame] | 368 | SendDelayMap send_delays_ GUARDED_BY(statistics_crit_); |
| 369 | std::map<FrameType, uint32_t> frame_counts_ GUARDED_BY(statistics_crit_); |
pbos@webrtc.org | 2bb1bda | 2014-07-07 13:06:48 +0000 | [diff] [blame] | 370 | StreamDataCounters rtp_stats_ GUARDED_BY(statistics_crit_); |
| 371 | StreamDataCounters rtx_rtp_stats_ GUARDED_BY(statistics_crit_); |
| 372 | StreamDataCountersCallback* rtp_stats_callback_ GUARDED_BY(statistics_crit_); |
andresp@webrtc.org | d11bec4 | 2014-07-08 14:32:58 +0000 | [diff] [blame] | 373 | BitrateStatisticsObserver* const bitrate_callback_; |
andresp@webrtc.org | 8f15121 | 2014-07-10 09:39:23 +0000 | [diff] [blame] | 374 | FrameCountObserver* const frame_count_observer_; |
stefan@webrtc.org | 168f23f | 2014-07-11 13:44:02 +0000 | [diff] [blame] | 375 | SendSideDelayObserver* const send_side_delay_observer_; |
asapersson@webrtc.org | 0b3c35a | 2012-01-16 11:06:31 +0000 | [diff] [blame] | 376 | |
pwestin@webrtc.org | 571a1c0 | 2012-11-13 21:12:39 +0000 | [diff] [blame] | 377 | // RTP variables |
pbos@webrtc.org | 2bb1bda | 2014-07-07 13:06:48 +0000 | [diff] [blame] | 378 | bool start_timestamp_forced_ GUARDED_BY(send_critsect_); |
| 379 | uint32_t start_timestamp_ GUARDED_BY(send_critsect_); |
| 380 | SSRCDatabase& ssrc_db_ GUARDED_BY(send_critsect_); |
| 381 | uint32_t remote_ssrc_ GUARDED_BY(send_critsect_); |
| 382 | bool sequence_number_forced_ GUARDED_BY(send_critsect_); |
| 383 | uint16_t sequence_number_ GUARDED_BY(send_critsect_); |
| 384 | uint16_t sequence_number_rtx_ GUARDED_BY(send_critsect_); |
| 385 | bool ssrc_forced_ GUARDED_BY(send_critsect_); |
| 386 | uint32_t ssrc_ GUARDED_BY(send_critsect_); |
| 387 | uint32_t timestamp_ GUARDED_BY(send_critsect_); |
| 388 | int64_t capture_time_ms_ GUARDED_BY(send_critsect_); |
| 389 | int64_t last_timestamp_time_ms_ GUARDED_BY(send_critsect_); |
stefan@webrtc.org | 8b94e3d | 2014-07-17 16:10:14 +0000 | [diff] [blame^] | 390 | bool media_has_been_sent_ GUARDED_BY(send_critsect_); |
pbos@webrtc.org | 2bb1bda | 2014-07-07 13:06:48 +0000 | [diff] [blame] | 391 | bool last_packet_marker_bit_ GUARDED_BY(send_critsect_); |
| 392 | uint8_t num_csrcs_ GUARDED_BY(send_critsect_); |
| 393 | uint32_t csrcs_[kRtpCsrcSize] GUARDED_BY(send_critsect_); |
| 394 | bool include_csrcs_ GUARDED_BY(send_critsect_); |
| 395 | int rtx_ GUARDED_BY(send_critsect_); |
| 396 | uint32_t ssrc_rtx_ GUARDED_BY(send_critsect_); |
| 397 | int payload_type_rtx_ GUARDED_BY(send_critsect_); |
andresp@webrtc.org | d09d074 | 2014-03-26 14:27:34 +0000 | [diff] [blame] | 398 | |
| 399 | // Note: Don't access this variable directly, always go through |
| 400 | // SetTargetBitrateKbps or GetTargetBitrateKbps. Also remember |
| 401 | // that by the time the function returns there is no guarantee |
| 402 | // that the target bitrate is still valid. |
| 403 | scoped_ptr<CriticalSectionWrapper> target_bitrate_critsect_; |
stefan@webrtc.org | aa0e56e | 2014-06-26 11:44:49 +0000 | [diff] [blame] | 404 | uint32_t target_bitrate_ GUARDED_BY(target_bitrate_critsect_); |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 405 | }; |
niklase@google.com | 470e71d | 2011-07-07 08:21:25 +0000 | [diff] [blame] | 406 | |
phoglund@webrtc.org | 43da54a | 2013-01-25 10:53:38 +0000 | [diff] [blame] | 407 | } // namespace webrtc |
| 408 | |
| 409 | #endif // WEBRTC_MODULES_RTP_RTCP_SOURCE_RTP_SENDER_H_ |