OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 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 | 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 | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
(...skipping 136 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
147 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | 147 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
148 // | extended highest sequence number received | | 148 // | extended highest sequence number received | |
149 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | 149 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
150 // | interarrival jitter | | 150 // | interarrival jitter | |
151 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | 151 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
152 // | last SR (LSR) | | 152 // | last SR (LSR) | |
153 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | 153 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
154 // | delay since last SR (DLSR) | | 154 // | delay since last SR (DLSR) | |
155 // +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+ | 155 // +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+ |
156 | 156 |
157 void CreateReportBlocks(const std::vector<RTCPPacketReportBlockItem>& blocks, | 157 void CreateReportBlocks(const std::vector<ReportBlock>& blocks, |
158 uint8_t* buffer, | 158 uint8_t* buffer, |
159 size_t* pos) { | 159 size_t* pos) { |
160 for (std::vector<RTCPPacketReportBlockItem>::const_iterator | 160 for (const ReportBlock& block : blocks) { |
161 it = blocks.begin(); it != blocks.end(); ++it) { | 161 size_t bytes_consumed = block.Create(buffer + *pos); |
162 AssignUWord32(buffer, pos, (*it).SSRC); | 162 RTC_CHECK_GT(bytes_consumed, 0u); |
åsapersson
2015/11/12 14:26:24
Maybe move check to when setting the field cum los
danilchap
2015/11/12 15:30:45
Moved check for CumulativeLost to ReportBlock::Wit
| |
163 AssignUWord8(buffer, pos, (*it).FractionLost); | 163 *pos += bytes_consumed; |
164 AssignUWord24(buffer, pos, (*it).CumulativeNumOfPacketsLost); | |
165 AssignUWord32(buffer, pos, (*it).ExtendedHighestSequenceNumber); | |
166 AssignUWord32(buffer, pos, (*it).Jitter); | |
167 AssignUWord32(buffer, pos, (*it).LastSR); | |
168 AssignUWord32(buffer, pos, (*it).DelayLastSR); | |
169 } | 164 } |
170 } | 165 } |
171 | 166 |
172 // Transmission Time Offsets in RTP Streams (RFC 5450). | 167 // Transmission Time Offsets in RTP Streams (RFC 5450). |
173 // | 168 // |
174 // 0 1 2 3 | 169 // 0 1 2 3 |
175 // 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 | 170 // 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 |
176 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | 171 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
177 // hdr |V=2|P| RC | PT=IJ=195 | length | | 172 // hdr |V=2|P| RC | PT=IJ=195 | length | |
178 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | 173 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
(...skipping 595 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
774 CreateSenderReport(sr_, packet, index); | 769 CreateSenderReport(sr_, packet, index); |
775 CreateReportBlocks(report_blocks_, packet, index); | 770 CreateReportBlocks(report_blocks_, packet, index); |
776 return true; | 771 return true; |
777 } | 772 } |
778 | 773 |
779 bool SenderReport::WithReportBlock(const ReportBlock& block) { | 774 bool SenderReport::WithReportBlock(const ReportBlock& block) { |
780 if (report_blocks_.size() >= kMaxNumberOfReportBlocks) { | 775 if (report_blocks_.size() >= kMaxNumberOfReportBlocks) { |
781 LOG(LS_WARNING) << "Max report blocks reached."; | 776 LOG(LS_WARNING) << "Max report blocks reached."; |
782 return false; | 777 return false; |
783 } | 778 } |
784 report_blocks_.push_back(block.report_block_); | 779 report_blocks_.push_back(block); |
785 sr_.NumberOfReportBlocks = report_blocks_.size(); | 780 sr_.NumberOfReportBlocks = report_blocks_.size(); |
786 return true; | 781 return true; |
787 } | 782 } |
788 | 783 |
789 bool ReceiverReport::Create(uint8_t* packet, | 784 bool ReceiverReport::Create(uint8_t* packet, |
790 size_t* index, | 785 size_t* index, |
791 size_t max_length, | 786 size_t max_length, |
792 RtcpPacket::PacketReadyCallback* callback) const { | 787 RtcpPacket::PacketReadyCallback* callback) const { |
793 while (*index + BlockLength() > max_length) { | 788 while (*index + BlockLength() > max_length) { |
794 if (!OnBufferFull(packet, index, callback)) | 789 if (!OnBufferFull(packet, index, callback)) |
795 return false; | 790 return false; |
796 } | 791 } |
797 CreateHeader(rr_.NumberOfReportBlocks, PT_RR, HeaderLength(), packet, index); | 792 CreateHeader(rr_.NumberOfReportBlocks, PT_RR, HeaderLength(), packet, index); |
798 CreateReceiverReport(rr_, packet, index); | 793 CreateReceiverReport(rr_, packet, index); |
799 CreateReportBlocks(report_blocks_, packet, index); | 794 CreateReportBlocks(report_blocks_, packet, index); |
800 return true; | 795 return true; |
801 } | 796 } |
802 | 797 |
803 bool ReceiverReport::WithReportBlock(const ReportBlock& block) { | 798 bool ReceiverReport::WithReportBlock(const ReportBlock& block) { |
804 if (report_blocks_.size() >= kMaxNumberOfReportBlocks) { | 799 if (report_blocks_.size() >= kMaxNumberOfReportBlocks) { |
805 LOG(LS_WARNING) << "Max report blocks reached."; | 800 LOG(LS_WARNING) << "Max report blocks reached."; |
806 return false; | 801 return false; |
807 } | 802 } |
808 report_blocks_.push_back(block.report_block_); | 803 report_blocks_.push_back(block); |
809 rr_.NumberOfReportBlocks = report_blocks_.size(); | 804 rr_.NumberOfReportBlocks = report_blocks_.size(); |
810 return true; | 805 return true; |
811 } | 806 } |
812 | 807 |
813 bool Ij::Create(uint8_t* packet, | 808 bool Ij::Create(uint8_t* packet, |
814 size_t* index, | 809 size_t* index, |
815 size_t max_length, | 810 size_t max_length, |
816 RtcpPacket::PacketReadyCallback* callback) const { | 811 RtcpPacket::PacketReadyCallback* callback) const { |
817 while (*index + BlockLength() > max_length) { | 812 while (*index + BlockLength() > max_length) { |
818 if (!OnBufferFull(packet, index, callback)) | 813 if (!OnBufferFull(packet, index, callback)) |
(...skipping 401 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1220 return length_; | 1215 return length_; |
1221 } | 1216 } |
1222 | 1217 |
1223 void RawPacket::SetLength(size_t length) { | 1218 void RawPacket::SetLength(size_t length) { |
1224 assert(length <= buffer_length_); | 1219 assert(length <= buffer_length_); |
1225 length_ = length; | 1220 length_ = length; |
1226 } | 1221 } |
1227 | 1222 |
1228 } // namespace rtcp | 1223 } // namespace rtcp |
1229 } // namespace webrtc | 1224 } // namespace webrtc |
OLD | NEW |