OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2016 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 230 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
241 | 241 |
242 bool VideoContentTypeExtension::Write(uint8_t* data, | 242 bool VideoContentTypeExtension::Write(uint8_t* data, |
243 VideoContentType content_type) { | 243 VideoContentType content_type) { |
244 data[0] = static_cast<uint8_t>(content_type); | 244 data[0] = static_cast<uint8_t>(content_type); |
245 return true; | 245 return true; |
246 } | 246 } |
247 | 247 |
248 // Video Timing. | 248 // Video Timing. |
249 // 6 timestamps in milliseconds counted from capture time stored in rtp header: | 249 // 6 timestamps in milliseconds counted from capture time stored in rtp header: |
250 // encode start/finish, packetization complete, pacer exit and reserved for | 250 // encode start/finish, packetization complete, pacer exit and reserved for |
251 // modification by the network modification. | 251 // modification by the network modification. |flags| is a bitmask and has the |
252 // following allowed values: | |
253 // 0 = Valid data, but no flags available (backwards compatibility) | |
254 // 1 = Frame marked as timing frame due to cyclic timer. | |
255 // 2 = Frame marked as timing frame due to size being outside limit. | |
256 // 255 = Invalid. The whole timing frame extension should be ignored. | |
257 // | |
252 // 0 1 2 3 | 258 // 0 1 2 3 |
253 // 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 2 | 259 // 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 2 |
254 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | 260 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
255 // | ID | len=11| encode start ms delta | encode finish | | 261 // | ID | len=12| encode start ms delta | encode finish | |
256 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | 262 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
257 // | ms delta | packetizer finish ms delta | pacer exit | | 263 // | ms delta | packetizer finish ms delta | pacer exit | |
258 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | 264 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
259 // | ms delta | network timestamp ms delta | network2 time-| | 265 // | ms delta | network timestamp ms delta | network2 time-| |
260 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | 266 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
261 // | stamp ms delta| | 267 // | stamp ms delta| flags | |
danilchap
2017/08/11 13:51:16
did you consider putting flags first?
it would mak
sprang_webrtc
2017/08/11 15:06:33
I did, mainly abstained because of the Write metho
| |
262 // +-+-+-+-+-+-+-+-+ | 268 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |
263 | 269 |
264 constexpr RTPExtensionType VideoTimingExtension::kId; | 270 constexpr RTPExtensionType VideoTimingExtension::kId; |
265 constexpr uint8_t VideoTimingExtension::kValueSizeBytes; | 271 constexpr uint8_t VideoTimingExtension::kValueSizeBytes; |
266 constexpr const char VideoTimingExtension::kUri[]; | 272 constexpr const char VideoTimingExtension::kUri[]; |
267 | 273 |
268 bool VideoTimingExtension::Parse(rtc::ArrayView<const uint8_t> data, | 274 bool VideoTimingExtension::Parse(rtc::ArrayView<const uint8_t> data, |
269 VideoSendTiming* timing) { | 275 VideoSendTiming* timing) { |
270 RTC_DCHECK(timing); | 276 RTC_DCHECK(timing); |
271 if (data.size() != kValueSizeBytes) | 277 // TODO(sprang): Deprecate support for old wire format. |
278 const bool is_old_protocol = data.size() == (kValueSizeBytes - 1); | |
279 | |
280 if (!(data.size() == kValueSizeBytes || is_old_protocol)) | |
272 return false; | 281 return false; |
273 timing->encode_start_delta_ms = | 282 timing->encode_start_delta_ms = ByteReader<uint16_t>::ReadBigEndian( |
274 ByteReader<uint16_t>::ReadBigEndian(data.data()); | 283 data.data() + VideoSendTiming::kEncodeStartDeltaOffset); |
275 timing->encode_finish_delta_ms = ByteReader<uint16_t>::ReadBigEndian( | 284 timing->encode_finish_delta_ms = ByteReader<uint16_t>::ReadBigEndian( |
276 data.data() + 2 * VideoSendTiming::kEncodeFinishDeltaIdx); | 285 data.data() + VideoSendTiming::kEncodeFinishDeltaOffset); |
277 timing->packetization_finish_delta_ms = ByteReader<uint16_t>::ReadBigEndian( | 286 timing->packetization_finish_delta_ms = ByteReader<uint16_t>::ReadBigEndian( |
278 data.data() + 2 * VideoSendTiming::kPacketizationFinishDeltaIdx); | 287 data.data() + VideoSendTiming::kPacketizationFinishDeltaOffset); |
279 timing->pacer_exit_delta_ms = ByteReader<uint16_t>::ReadBigEndian( | 288 timing->pacer_exit_delta_ms = ByteReader<uint16_t>::ReadBigEndian( |
280 data.data() + 2 * VideoSendTiming::kPacerExitDeltaIdx); | 289 data.data() + VideoSendTiming::kPacerExitDeltaOffset); |
281 timing->network_timstamp_delta_ms = ByteReader<uint16_t>::ReadBigEndian( | 290 timing->network_timstamp_delta_ms = ByteReader<uint16_t>::ReadBigEndian( |
282 data.data() + 2 * VideoSendTiming::kNetworkTimestampDeltaIdx); | 291 data.data() + VideoSendTiming::kNetworkTimestampDeltaOffset); |
283 timing->network2_timstamp_delta_ms = ByteReader<uint16_t>::ReadBigEndian( | 292 timing->network2_timstamp_delta_ms = ByteReader<uint16_t>::ReadBigEndian( |
284 data.data() + 2 * VideoSendTiming::kNetwork2TimestampDeltaIdx); | 293 data.data() + VideoSendTiming::kNetwork2TimestampDeltaOffset); |
285 timing->is_timing_frame = true; | 294 timing->flags = is_old_protocol |
295 ? 0 | |
296 : ByteReader<uint8_t>::ReadBigEndian( | |
297 data.data() + VideoSendTiming::kFLagsOffset); | |
286 return true; | 298 return true; |
287 } | 299 } |
288 | 300 |
289 bool VideoTimingExtension::Write(uint8_t* data, const VideoSendTiming& timing) { | 301 bool VideoTimingExtension::Write(uint8_t* data, const VideoSendTiming& timing) { |
290 ByteWriter<uint16_t>::WriteBigEndian(data, timing.encode_start_delta_ms); | |
291 ByteWriter<uint16_t>::WriteBigEndian( | 302 ByteWriter<uint16_t>::WriteBigEndian( |
292 data + 2 * VideoSendTiming::kEncodeFinishDeltaIdx, | 303 data + VideoSendTiming::kEncodeStartDeltaOffset, |
304 timing.encode_start_delta_ms); | |
305 ByteWriter<uint16_t>::WriteBigEndian( | |
306 data + VideoSendTiming::kEncodeFinishDeltaOffset, | |
293 timing.encode_finish_delta_ms); | 307 timing.encode_finish_delta_ms); |
294 ByteWriter<uint16_t>::WriteBigEndian( | 308 ByteWriter<uint16_t>::WriteBigEndian( |
295 data + 2 * VideoSendTiming::kPacketizationFinishDeltaIdx, | 309 data + VideoSendTiming::kPacketizationFinishDeltaOffset, |
296 timing.packetization_finish_delta_ms); | 310 timing.packetization_finish_delta_ms); |
297 ByteWriter<uint16_t>::WriteBigEndian( | 311 ByteWriter<uint16_t>::WriteBigEndian( |
298 data + 2 * VideoSendTiming::kPacerExitDeltaIdx, | 312 data + VideoSendTiming::kPacerExitDeltaOffset, |
299 timing.pacer_exit_delta_ms); | 313 timing.pacer_exit_delta_ms); |
300 ByteWriter<uint16_t>::WriteBigEndian( | 314 ByteWriter<uint16_t>::WriteBigEndian( |
301 data + 2 * VideoSendTiming::kNetworkTimestampDeltaIdx, 0); // reserved | 315 data + VideoSendTiming::kNetworkTimestampDeltaOffset, 0); // reserved |
302 ByteWriter<uint16_t>::WriteBigEndian( | 316 ByteWriter<uint16_t>::WriteBigEndian( |
303 data + 2 * VideoSendTiming::kNetwork2TimestampDeltaIdx, 0); // reserved | 317 data + VideoSendTiming::kNetwork2TimestampDeltaOffset, 0); // reserved |
318 ByteWriter<uint8_t>::WriteBigEndian(data + VideoSendTiming::kFLagsOffset, | |
319 timing.flags); | |
304 return true; | 320 return true; |
305 } | 321 } |
306 | 322 |
307 bool VideoTimingExtension::Write(uint8_t* data, | 323 bool VideoTimingExtension::Write(uint8_t* data, |
308 uint16_t time_delta_ms, | 324 uint16_t time_delta_ms, |
309 uint8_t idx) { | 325 uint8_t offset) { |
310 RTC_DCHECK_LT(idx, 6); | 326 RTC_DCHECK_LT(offset, kValueSizeBytes - sizeof(uint16_t)); |
311 ByteWriter<uint16_t>::WriteBigEndian(data + 2 * idx, time_delta_ms); | 327 ByteWriter<uint16_t>::WriteBigEndian(data + offset, time_delta_ms); |
312 return true; | 328 return true; |
313 } | 329 } |
314 | 330 |
315 bool BaseRtpStringExtension::Parse(rtc::ArrayView<const uint8_t> data, | 331 bool BaseRtpStringExtension::Parse(rtc::ArrayView<const uint8_t> data, |
316 StringRtpHeaderExtension* str) { | 332 StringRtpHeaderExtension* str) { |
317 if (data.empty() || data[0] == 0) // Valid string extension can't be empty. | 333 if (data.empty() || data[0] == 0) // Valid string extension can't be empty. |
318 return false; | 334 return false; |
319 str->Set(data); | 335 str->Set(data); |
320 RTC_DCHECK(!str->empty()); | 336 RTC_DCHECK(!str->empty()); |
321 return true; | 337 return true; |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
353 constexpr RTPExtensionType RtpStreamId::kId; | 369 constexpr RTPExtensionType RtpStreamId::kId; |
354 constexpr const char RtpStreamId::kUri[]; | 370 constexpr const char RtpStreamId::kUri[]; |
355 | 371 |
356 constexpr RTPExtensionType RepairedRtpStreamId::kId; | 372 constexpr RTPExtensionType RepairedRtpStreamId::kId; |
357 constexpr const char RepairedRtpStreamId::kUri[]; | 373 constexpr const char RepairedRtpStreamId::kUri[]; |
358 | 374 |
359 constexpr RTPExtensionType RtpMid::kId; | 375 constexpr RTPExtensionType RtpMid::kId; |
360 constexpr const char RtpMid::kUri[]; | 376 constexpr const char RtpMid::kUri[]; |
361 | 377 |
362 } // namespace webrtc | 378 } // namespace webrtc |
OLD | NEW |