| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "media/cast/net/rtcp/rtcp_builder.h" | 5 #include "media/cast/net/rtcp/rtcp_builder.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include <algorithm> | 9 #include <algorithm> |
| 10 #include <vector> | 10 #include <vector> |
| (...skipping 147 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 158 writer_ = base::BigEndianWriter(NULL, 0); | 158 writer_ = base::BigEndianWriter(NULL, 0); |
| 159 PacketRef ret = packet_; | 159 PacketRef ret = packet_; |
| 160 packet_ = NULL; | 160 packet_ = NULL; |
| 161 return ret; | 161 return ret; |
| 162 } | 162 } |
| 163 | 163 |
| 164 PacketRef RtcpBuilder::BuildRtcpFromReceiver( | 164 PacketRef RtcpBuilder::BuildRtcpFromReceiver( |
| 165 const RtcpReportBlock* report_block, | 165 const RtcpReportBlock* report_block, |
| 166 const RtcpReceiverReferenceTimeReport* rrtr, | 166 const RtcpReceiverReferenceTimeReport* rrtr, |
| 167 const RtcpCastMessage* cast_message, | 167 const RtcpCastMessage* cast_message, |
| 168 const RtcpPliMessage* pli_message, |
| 168 const ReceiverRtcpEventSubscriber::RtcpEvents* rtcp_events, | 169 const ReceiverRtcpEventSubscriber::RtcpEvents* rtcp_events, |
| 169 base::TimeDelta target_delay) { | 170 base::TimeDelta target_delay) { |
| 170 Start(); | 171 Start(); |
| 171 | 172 |
| 172 if (report_block) | 173 if (report_block) |
| 173 AddRR(report_block); | 174 AddRR(report_block); |
| 174 if (rrtr) | 175 if (rrtr) |
| 175 AddRrtr(rrtr); | 176 AddRrtr(rrtr); |
| 176 if (cast_message) | 177 if (cast_message) |
| 177 AddCast(cast_message, target_delay); | 178 AddCast(cast_message, target_delay); |
| 179 if (pli_message) |
| 180 AddPli(pli_message); |
| 178 if (rtcp_events) | 181 if (rtcp_events) |
| 179 AddReceiverLog(*rtcp_events); | 182 AddReceiverLog(*rtcp_events); |
| 180 | 183 |
| 181 return Finish(); | 184 return Finish(); |
| 182 } | 185 } |
| 183 | 186 |
| 184 PacketRef RtcpBuilder::BuildRtcpFromSender(const RtcpSenderInfo& sender_info) { | 187 PacketRef RtcpBuilder::BuildRtcpFromSender(const RtcpSenderInfo& sender_info) { |
| 185 Start(); | 188 Start(); |
| 186 AddSR(sender_info); | 189 AddSR(sender_info); |
| 187 return Finish(); | 190 return Finish(); |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 220 writer_.WriteU32(ssrc_); // Add our own SSRC. | 223 writer_.WriteU32(ssrc_); // Add our own SSRC. |
| 221 writer_.WriteU8(4); // Add block type. | 224 writer_.WriteU8(4); // Add block type. |
| 222 writer_.WriteU8(0); // Add reserved. | 225 writer_.WriteU8(0); // Add reserved. |
| 223 writer_.WriteU16(2); // Block length. | 226 writer_.WriteU16(2); // Block length. |
| 224 | 227 |
| 225 // Add the media (received RTP) SSRC. | 228 // Add the media (received RTP) SSRC. |
| 226 writer_.WriteU32(rrtr->ntp_seconds); | 229 writer_.WriteU32(rrtr->ntp_seconds); |
| 227 writer_.WriteU32(rrtr->ntp_fraction); | 230 writer_.WriteU32(rrtr->ntp_fraction); |
| 228 } | 231 } |
| 229 | 232 |
| 233 void RtcpBuilder::AddPli(const RtcpPliMessage* pli_message) { |
| 234 AddRtcpHeader(kPacketTypePayloadSpecific, 1); |
| 235 writer_.WriteU32(ssrc_); |
| 236 writer_.WriteU32(pli_message->sender_ssrc); |
| 237 } |
| 238 |
| 230 void RtcpBuilder::AddCast(const RtcpCastMessage* cast, | 239 void RtcpBuilder::AddCast(const RtcpCastMessage* cast, |
| 231 base::TimeDelta target_delay) { | 240 base::TimeDelta target_delay) { |
| 232 // See RTC 4585 Section 6.4 for application specific feedback messages. | 241 // See RTC 4585 Section 6.4 for application specific feedback messages. |
| 233 AddRtcpHeader(kPacketTypePayloadSpecific, 15); | 242 AddRtcpHeader(kPacketTypePayloadSpecific, 15); |
| 234 writer_.WriteU32(ssrc_); // Add our own SSRC. | 243 writer_.WriteU32(ssrc_); // Add our own SSRC. |
| 235 writer_.WriteU32(cast->media_ssrc); // Remote SSRC. | 244 writer_.WriteU32(cast->media_ssrc); // Remote SSRC. |
| 236 writer_.WriteU32(kCast); | 245 writer_.WriteU32(kCast); |
| 237 writer_.WriteU8(static_cast<uint8_t>(cast->ack_frame_id)); | 246 writer_.WriteU8(static_cast<uint8_t>(cast->ack_frame_id)); |
| 238 uint8_t* cast_loss_field_pos = reinterpret_cast<uint8_t*>(writer_.ptr()); | 247 uint8_t* cast_loss_field_pos = reinterpret_cast<uint8_t*>(writer_.ptr()); |
| 239 writer_.WriteU8(0); // Overwritten with number_of_loss_fields. | 248 writer_.WriteU8(0); // Overwritten with number_of_loss_fields. |
| (...skipping 237 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 477 receiver_log_message->push_front(frame_log); | 486 receiver_log_message->push_front(frame_log); |
| 478 } | 487 } |
| 479 | 488 |
| 480 VLOG(3) << "number of frames: " << number_of_frames; | 489 VLOG(3) << "number of frames: " << number_of_frames; |
| 481 VLOG(3) << "total messages to send: " << *total_number_of_messages_to_send; | 490 VLOG(3) << "total messages to send: " << *total_number_of_messages_to_send; |
| 482 return number_of_frames > 0; | 491 return number_of_frames > 0; |
| 483 } | 492 } |
| 484 | 493 |
| 485 } // namespace cast | 494 } // namespace cast |
| 486 } // namespace media | 495 } // namespace media |
| OLD | NEW |