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_utility.h" | 5 #include "media/cast/net/rtcp/rtcp_utility.h" |
6 | 6 |
7 #include <stdint.h> | 7 #include <stdint.h> |
8 | 8 |
9 #include <cmath> | 9 #include <cmath> |
10 | 10 |
(...skipping 19 matching lines...) Expand all Loading... |
30 : local_ssrc_(local_ssrc), | 30 : local_ssrc_(local_ssrc), |
31 remote_ssrc_(remote_ssrc), | 31 remote_ssrc_(remote_ssrc), |
32 has_sender_report_(false), | 32 has_sender_report_(false), |
33 has_last_report_(false), | 33 has_last_report_(false), |
34 has_cast_message_(false), | 34 has_cast_message_(false), |
35 has_receiver_reference_time_report_(false) {} | 35 has_receiver_reference_time_report_(false) {} |
36 | 36 |
37 RtcpParser::~RtcpParser() {} | 37 RtcpParser::~RtcpParser() {} |
38 | 38 |
39 bool RtcpParser::Parse(base::BigEndianReader* reader) { | 39 bool RtcpParser::Parse(base::BigEndianReader* reader) { |
| 40 // Reset. |
| 41 has_sender_report_ = false; |
| 42 sender_report_ = RtcpSenderInfo(); |
| 43 has_last_report_ = false; |
| 44 receiver_log_.clear(); |
| 45 has_cast_message_ = false; |
| 46 has_receiver_reference_time_report_ = false; |
| 47 |
40 while (reader->remaining()) { | 48 while (reader->remaining()) { |
41 RtcpCommonHeader header; | 49 RtcpCommonHeader header; |
42 if (!ParseCommonHeader(reader, &header)) | 50 if (!ParseCommonHeader(reader, &header)) |
43 return false; | 51 return false; |
44 | 52 |
45 base::StringPiece tmp; | 53 base::StringPiece tmp; |
46 if (!reader->ReadPiece(&tmp, header.length_in_octets - 4)) | 54 if (!reader->ReadPiece(&tmp, header.length_in_octets - 4)) |
47 return false; | 55 return false; |
48 base::BigEndianReader chunk(tmp.data(), tmp.size()); | 56 base::BigEndianReader chunk(tmp.data(), tmp.size()); |
49 | 57 |
(...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
115 | 123 |
116 bool RtcpParser::ParseSR(base::BigEndianReader* reader, | 124 bool RtcpParser::ParseSR(base::BigEndianReader* reader, |
117 const RtcpCommonHeader& header) { | 125 const RtcpCommonHeader& header) { |
118 uint32_t sender_ssrc; | 126 uint32_t sender_ssrc; |
119 if (!reader->ReadU32(&sender_ssrc)) | 127 if (!reader->ReadU32(&sender_ssrc)) |
120 return false; | 128 return false; |
121 | 129 |
122 if (sender_ssrc != remote_ssrc_) | 130 if (sender_ssrc != remote_ssrc_) |
123 return true; | 131 return true; |
124 | 132 |
125 uint32_t tmp; | 133 uint32_t truncated_rtp_timestamp; |
| 134 uint32_t send_octet_count; |
126 if (!reader->ReadU32(&sender_report_.ntp_seconds) || | 135 if (!reader->ReadU32(&sender_report_.ntp_seconds) || |
127 !reader->ReadU32(&sender_report_.ntp_fraction) || | 136 !reader->ReadU32(&sender_report_.ntp_fraction) || |
128 !reader->ReadU32(&sender_report_.rtp_timestamp) || | 137 !reader->ReadU32(&truncated_rtp_timestamp) || |
129 !reader->ReadU32(&sender_report_.send_packet_count) || | 138 !reader->ReadU32(&sender_report_.send_packet_count) || |
130 !reader->ReadU32(&tmp)) | 139 !reader->ReadU32(&send_octet_count)) |
131 return false; | 140 return false; |
132 sender_report_.send_octet_count = tmp; | 141 sender_report_.rtp_timestamp = last_parsed_sr_rtp_timestamp_ = |
| 142 last_parsed_sr_rtp_timestamp_.Expand(truncated_rtp_timestamp); |
| 143 sender_report_.send_octet_count = send_octet_count; |
133 has_sender_report_ = true; | 144 has_sender_report_ = true; |
134 | 145 |
135 for (size_t block = 0; block < header.IC; block++) | 146 for (size_t block = 0; block < header.IC; block++) |
136 if (!ParseReportBlock(reader)) | 147 if (!ParseReportBlock(reader)) |
137 return false; | 148 return false; |
138 | 149 |
139 return true; | 150 return true; |
140 } | 151 } |
141 | 152 |
142 bool RtcpParser::ParseRR(base::BigEndianReader* reader, | 153 bool RtcpParser::ParseRR(base::BigEndianReader* reader, |
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
192 return false; | 203 return false; |
193 break; | 204 break; |
194 } | 205 } |
195 return true; | 206 return true; |
196 } | 207 } |
197 | 208 |
198 bool RtcpParser::ParseCastReceiverLogFrameItem( | 209 bool RtcpParser::ParseCastReceiverLogFrameItem( |
199 base::BigEndianReader* reader) { | 210 base::BigEndianReader* reader) { |
200 | 211 |
201 while (reader->remaining()) { | 212 while (reader->remaining()) { |
202 uint32_t rtp_timestamp; | 213 uint32_t truncated_rtp_timestamp; |
203 uint32_t data; | 214 uint32_t data; |
204 if (!reader->ReadU32(&rtp_timestamp) || | 215 if (!reader->ReadU32(&truncated_rtp_timestamp) || !reader->ReadU32(&data)) |
205 !reader->ReadU32(&data)) | |
206 return false; | 216 return false; |
207 | 217 |
208 // We have 24 LSB of the event timestamp base on the wire. | 218 // We have 24 LSB of the event timestamp base on the wire. |
209 base::TimeTicks event_timestamp_base = base::TimeTicks() + | 219 base::TimeTicks event_timestamp_base = base::TimeTicks() + |
210 base::TimeDelta::FromMilliseconds(data & 0xffffff); | 220 base::TimeDelta::FromMilliseconds(data & 0xffffff); |
211 | 221 |
212 size_t num_events = 1 + static_cast<uint8_t>(data >> 24); | 222 size_t num_events = 1 + static_cast<uint8_t>(data >> 24); |
213 | 223 |
214 RtcpReceiverFrameLogMessage frame_log(rtp_timestamp); | 224 const RtpTimeTicks frame_log_rtp_timestamp = |
| 225 last_parsed_frame_log_rtp_timestamp_.Expand(truncated_rtp_timestamp); |
| 226 RtcpReceiverFrameLogMessage frame_log(frame_log_rtp_timestamp); |
215 for (size_t event = 0; event < num_events; event++) { | 227 for (size_t event = 0; event < num_events; event++) { |
216 uint16_t delay_delta_or_packet_id; | 228 uint16_t delay_delta_or_packet_id; |
217 uint16_t event_type_and_timestamp_delta; | 229 uint16_t event_type_and_timestamp_delta; |
218 if (!reader->ReadU16(&delay_delta_or_packet_id) || | 230 if (!reader->ReadU16(&delay_delta_or_packet_id) || |
219 !reader->ReadU16(&event_type_and_timestamp_delta)) | 231 !reader->ReadU16(&event_type_and_timestamp_delta)) |
220 return false; | 232 return false; |
221 | 233 |
222 RtcpReceiverEventLogMessage event_log; | 234 RtcpReceiverEventLogMessage event_log; |
223 event_log.type = TranslateToLogEventFromWireFormat( | 235 event_log.type = TranslateToLogEventFromWireFormat( |
224 static_cast<uint8_t>(event_type_and_timestamp_delta >> 12)); | 236 static_cast<uint8_t>(event_type_and_timestamp_delta >> 12)); |
225 event_log.event_timestamp = | 237 event_log.event_timestamp = |
226 event_timestamp_base + | 238 event_timestamp_base + |
227 base::TimeDelta::FromMilliseconds( | 239 base::TimeDelta::FromMilliseconds( |
228 event_type_and_timestamp_delta & 0xfff); | 240 event_type_and_timestamp_delta & 0xfff); |
229 if (event_log.type == PACKET_RECEIVED) { | 241 if (event_log.type == PACKET_RECEIVED) { |
230 event_log.packet_id = delay_delta_or_packet_id; | 242 event_log.packet_id = delay_delta_or_packet_id; |
231 } else { | 243 } else { |
232 event_log.delay_delta = base::TimeDelta::FromMilliseconds( | 244 event_log.delay_delta = base::TimeDelta::FromMilliseconds( |
233 static_cast<int16_t>(delay_delta_or_packet_id)); | 245 static_cast<int16_t>(delay_delta_or_packet_id)); |
234 } | 246 } |
235 frame_log.event_log_messages_.push_back(event_log); | 247 frame_log.event_log_messages_.push_back(event_log); |
236 } | 248 } |
237 | 249 |
| 250 last_parsed_frame_log_rtp_timestamp_ = frame_log_rtp_timestamp; |
238 receiver_log_.push_back(frame_log); | 251 receiver_log_.push_back(frame_log); |
239 } | 252 } |
240 | 253 |
241 return true; | 254 return true; |
242 } | 255 } |
243 | 256 |
244 // RFC 4585. | 257 // RFC 4585. |
245 bool RtcpParser::ParseFeedbackCommon(base::BigEndianReader* reader, | 258 bool RtcpParser::ParseFeedbackCommon(base::BigEndianReader* reader, |
246 const RtcpCommonHeader& header) { | 259 const RtcpCommonHeader& header) { |
247 // See RTC 4585 Section 6.4 for application specific feedback messages. | 260 // See RTC 4585 Section 6.4 for application specific feedback messages. |
(...skipping 188 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
436 static_cast<int64_t>(std::ceil(ntp_fractions / kMagicFractionalUnit)); | 449 static_cast<int64_t>(std::ceil(ntp_fractions / kMagicFractionalUnit)); |
437 | 450 |
438 base::TimeDelta elapsed_since_unix_epoch = base::TimeDelta::FromMicroseconds( | 451 base::TimeDelta elapsed_since_unix_epoch = base::TimeDelta::FromMicroseconds( |
439 ntp_time_us - | 452 ntp_time_us - |
440 (kUnixEpochInNtpSeconds * base::Time::kMicrosecondsPerSecond)); | 453 (kUnixEpochInNtpSeconds * base::Time::kMicrosecondsPerSecond)); |
441 return base::TimeTicks::UnixEpoch() + elapsed_since_unix_epoch; | 454 return base::TimeTicks::UnixEpoch() + elapsed_since_unix_epoch; |
442 } | 455 } |
443 | 456 |
444 } // namespace cast | 457 } // namespace cast |
445 } // namespace media | 458 } // namespace media |
OLD | NEW |