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

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| 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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698