Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(289)

Side by Side Diff: webrtc/modules/rtp_rtcp/source/rtp_header_extensions.cc

Issue 3000753002: Add a flags field to video timing extension. (Closed)
Patch Set: Addressed comments Created 3 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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| flags | encode start ms delta |
256 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 262 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
257 // | ms delta | packetizer finish ms delta | pacer exit | 263 // | encode finish ms delta | packetizer finish ms delta |
258 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 264 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
259 // | ms delta | network timestamp ms delta | network2 time-| 265 // | pacer exit ms delta | network timestamp ms delta |
260 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 266 // +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
261 // | stamp ms delta| 267 // | network2 timestamp ms delta |
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.
272 return false; 278 ptrdiff_t off = 0;
273 timing->encode_start_delta_ms = 279 if (data.size() == (kValueSizeBytes - 1)) {
danilchap 2017/08/11 15:18:47 rather than if else if may be use simpler switch:
sprang_webrtc 2017/08/11 15:44:32 Done.
274 ByteReader<uint16_t>::ReadBigEndian(data.data()); 280 // Old wire format without the flags field.
281 off = 1;
282 } else {
283 if (data.size() != kValueSizeBytes)
284 return false;
285 timing->flags = ByteReader<uint8_t>::ReadBigEndian(data.data());
286 }
287
288 timing->encode_start_delta_ms = ByteReader<uint16_t>::ReadBigEndian(
289 data.data() + VideoSendTiming::kEncodeStartDeltaOffset - off);
275 timing->encode_finish_delta_ms = ByteReader<uint16_t>::ReadBigEndian( 290 timing->encode_finish_delta_ms = ByteReader<uint16_t>::ReadBigEndian(
276 data.data() + 2 * VideoSendTiming::kEncodeFinishDeltaIdx); 291 data.data() + VideoSendTiming::kEncodeFinishDeltaOffset - off);
277 timing->packetization_finish_delta_ms = ByteReader<uint16_t>::ReadBigEndian( 292 timing->packetization_finish_delta_ms = ByteReader<uint16_t>::ReadBigEndian(
278 data.data() + 2 * VideoSendTiming::kPacketizationFinishDeltaIdx); 293 data.data() + VideoSendTiming::kPacketizationFinishDeltaOffset - off);
279 timing->pacer_exit_delta_ms = ByteReader<uint16_t>::ReadBigEndian( 294 timing->pacer_exit_delta_ms = ByteReader<uint16_t>::ReadBigEndian(
280 data.data() + 2 * VideoSendTiming::kPacerExitDeltaIdx); 295 data.data() + VideoSendTiming::kPacerExitDeltaOffset - off);
281 timing->network_timstamp_delta_ms = ByteReader<uint16_t>::ReadBigEndian( 296 timing->network_timstamp_delta_ms = ByteReader<uint16_t>::ReadBigEndian(
282 data.data() + 2 * VideoSendTiming::kNetworkTimestampDeltaIdx); 297 data.data() + VideoSendTiming::kNetworkTimestampDeltaOffset - off);
283 timing->network2_timstamp_delta_ms = ByteReader<uint16_t>::ReadBigEndian( 298 timing->network2_timstamp_delta_ms = ByteReader<uint16_t>::ReadBigEndian(
284 data.data() + 2 * VideoSendTiming::kNetwork2TimestampDeltaIdx); 299 data.data() + VideoSendTiming::kNetwork2TimestampDeltaOffset - off);
285 timing->is_timing_frame = true;
286 return true; 300 return true;
287 } 301 }
288 302
289 bool VideoTimingExtension::Write(uint8_t* data, const VideoSendTiming& timing) { 303 bool VideoTimingExtension::Write(uint8_t* data, const VideoSendTiming& timing) {
290 ByteWriter<uint16_t>::WriteBigEndian(data, timing.encode_start_delta_ms); 304 ByteWriter<uint8_t>::WriteBigEndian(data + VideoSendTiming::kFlagsOffset,
305 timing.flags);
291 ByteWriter<uint16_t>::WriteBigEndian( 306 ByteWriter<uint16_t>::WriteBigEndian(
292 data + 2 * VideoSendTiming::kEncodeFinishDeltaIdx, 307 data + VideoSendTiming::kEncodeStartDeltaOffset,
308 timing.encode_start_delta_ms);
309 ByteWriter<uint16_t>::WriteBigEndian(
310 data + VideoSendTiming::kEncodeFinishDeltaOffset,
293 timing.encode_finish_delta_ms); 311 timing.encode_finish_delta_ms);
294 ByteWriter<uint16_t>::WriteBigEndian( 312 ByteWriter<uint16_t>::WriteBigEndian(
295 data + 2 * VideoSendTiming::kPacketizationFinishDeltaIdx, 313 data + VideoSendTiming::kPacketizationFinishDeltaOffset,
296 timing.packetization_finish_delta_ms); 314 timing.packetization_finish_delta_ms);
297 ByteWriter<uint16_t>::WriteBigEndian( 315 ByteWriter<uint16_t>::WriteBigEndian(
298 data + 2 * VideoSendTiming::kPacerExitDeltaIdx, 316 data + VideoSendTiming::kPacerExitDeltaOffset,
299 timing.pacer_exit_delta_ms); 317 timing.pacer_exit_delta_ms);
300 ByteWriter<uint16_t>::WriteBigEndian( 318 ByteWriter<uint16_t>::WriteBigEndian(
301 data + 2 * VideoSendTiming::kNetworkTimestampDeltaIdx, 0); // reserved 319 data + VideoSendTiming::kNetworkTimestampDeltaOffset, 0); // reserved
302 ByteWriter<uint16_t>::WriteBigEndian( 320 ByteWriter<uint16_t>::WriteBigEndian(
303 data + 2 * VideoSendTiming::kNetwork2TimestampDeltaIdx, 0); // reserved 321 data + VideoSendTiming::kNetwork2TimestampDeltaOffset, 0); // reserved
304 return true; 322 return true;
305 } 323 }
306 324
307 bool VideoTimingExtension::Write(uint8_t* data, 325 bool VideoTimingExtension::Write(uint8_t* data,
308 uint16_t time_delta_ms, 326 uint16_t time_delta_ms,
309 uint8_t idx) { 327 uint8_t offset) {
310 RTC_DCHECK_LT(idx, 6); 328 RTC_DCHECK_LT(offset, kValueSizeBytes - sizeof(uint16_t));
311 ByteWriter<uint16_t>::WriteBigEndian(data + 2 * idx, time_delta_ms); 329 ByteWriter<uint16_t>::WriteBigEndian(data + offset, time_delta_ms);
312 return true; 330 return true;
313 } 331 }
314 332
315 bool BaseRtpStringExtension::Parse(rtc::ArrayView<const uint8_t> data, 333 bool BaseRtpStringExtension::Parse(rtc::ArrayView<const uint8_t> data,
316 StringRtpHeaderExtension* str) { 334 StringRtpHeaderExtension* str) {
317 if (data.empty() || data[0] == 0) // Valid string extension can't be empty. 335 if (data.empty() || data[0] == 0) // Valid string extension can't be empty.
318 return false; 336 return false;
319 str->Set(data); 337 str->Set(data);
320 RTC_DCHECK(!str->empty()); 338 RTC_DCHECK(!str->empty());
321 return true; 339 return true;
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
353 constexpr RTPExtensionType RtpStreamId::kId; 371 constexpr RTPExtensionType RtpStreamId::kId;
354 constexpr const char RtpStreamId::kUri[]; 372 constexpr const char RtpStreamId::kUri[];
355 373
356 constexpr RTPExtensionType RepairedRtpStreamId::kId; 374 constexpr RTPExtensionType RepairedRtpStreamId::kId;
357 constexpr const char RepairedRtpStreamId::kUri[]; 375 constexpr const char RepairedRtpStreamId::kUri[];
358 376
359 constexpr RTPExtensionType RtpMid::kId; 377 constexpr RTPExtensionType RtpMid::kId;
360 constexpr const char RtpMid::kUri[]; 378 constexpr const char RtpMid::kUri[];
361 379
362 } // namespace webrtc 380 } // namespace webrtc
OLDNEW
« no previous file with comments | « webrtc/modules/rtp_rtcp/source/rtp_header_extensions.h ('k') | webrtc/modules/rtp_rtcp/source/rtp_packet_to_send.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698