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

Side by Side Diff: media/cast/net/rtp_sender/rtp_packetizer/test/rtp_header_parser.cc

Issue 100823015: Cast: move net->transport (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Updating transport callback Created 6 years, 11 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 | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "media/cast/net/rtp_sender/rtp_packetizer/test/rtp_header_parser.h"
6
7 #include <cstddef>
8
9 #include "net/base/big_endian.h"
10
11 namespace media {
12 namespace cast {
13
14 static const uint8 kCastKeyFrameBitMask = 0x80;
15 static const uint8 kCastReferenceFrameIdBitMask = 0x40;
16 static const size_t kRtpCommonHeaderLength = 12;
17 static const size_t kRtpCastHeaderLength = 12;
18
19 RtpCastTestHeader::RtpCastTestHeader()
20 : is_key_frame(false),
21 frame_id(0),
22 packet_id(0),
23 max_packet_id(0),
24 is_reference(false),
25 reference_frame_id(0),
26 marker(false),
27 sequence_number(0),
28 rtp_timestamp(0),
29 ssrc(0),
30 payload_type(0),
31 num_csrcs(0),
32 audio_num_energy(0),
33 header_length(0) {}
34
35 RtpCastTestHeader::~RtpCastTestHeader() {}
36
37 RtpHeaderParser::RtpHeaderParser(const uint8* rtp_data,
38 size_t rtp_data_length)
39 : rtp_data_begin_(rtp_data),
40 length_(rtp_data_length) {}
41
42 RtpHeaderParser::~RtpHeaderParser() {}
43
44 bool RtpHeaderParser::Parse(RtpCastTestHeader* parsed_packet) const {
45 if (length_ < kRtpCommonHeaderLength + kRtpCastHeaderLength)
46 return false;
47 if (!ParseCommon(parsed_packet)) return false;
48 return ParseCast(parsed_packet);
49 }
50
51 bool RtpHeaderParser::ParseCommon(RtpCastTestHeader* parsed_packet) const {
52 const uint8 version = rtp_data_begin_[0] >> 6;
53 if (version != 2) {
54 return false;
55 }
56
57 const uint8 num_csrcs = rtp_data_begin_[0] & 0x0f;
58 const bool marker = ((rtp_data_begin_[1] & 0x80) == 0) ? false : true;
59 const uint8 payload_type = rtp_data_begin_[1] & 0x7f;
60 const uint16 sequence_number = (rtp_data_begin_[2] << 8) +
61 rtp_data_begin_[3];
62
63 const uint8* ptr = &rtp_data_begin_[4];
64
65 net::BigEndianReader big_endian_reader(ptr, 8);
66 uint32 rtp_timestamp, ssrc;
67 big_endian_reader.ReadU32(&rtp_timestamp);
68 big_endian_reader.ReadU32(&ssrc);
69
70 const uint8 csrc_octs = num_csrcs * 4;
71
72 parsed_packet->marker = marker;
73 parsed_packet->payload_type = payload_type;
74 parsed_packet->sequence_number = sequence_number;
75 parsed_packet->rtp_timestamp = rtp_timestamp;
76 parsed_packet->ssrc = ssrc;
77 parsed_packet->num_csrcs = num_csrcs;
78
79 parsed_packet->audio_num_energy = parsed_packet->num_csrcs;
80
81 parsed_packet->header_length = 12 + csrc_octs;
82 return true;
83 }
84
85 bool RtpHeaderParser::ParseCast(RtpCastTestHeader* parsed_packet) const {
86 const uint8* data = rtp_data_begin_ + kRtpCommonHeaderLength;
87 parsed_packet->is_key_frame = (data[0] & kCastKeyFrameBitMask);
88 parsed_packet->is_reference = (data[0] & kCastReferenceFrameIdBitMask);
89 parsed_packet->frame_id = frame_id_wrap_helper_.MapTo32bitsFrameId(data[1]);
90
91 net::BigEndianReader big_endian_reader(data + 2, 8);
92 big_endian_reader.ReadU16(&parsed_packet->packet_id);
93 big_endian_reader.ReadU16(&parsed_packet->max_packet_id);
94
95 if (parsed_packet->is_reference) {
96 parsed_packet->reference_frame_id =
97 reference_frame_id_wrap_helper_.MapTo32bitsFrameId(data[6]);
98 }
99 return true;
100 }
101
102 } // namespace cast
103 } // namespace media
OLDNEW
« no previous file with comments | « media/cast/net/rtp_sender/rtp_packetizer/test/rtp_header_parser.h ('k') | media/cast/net/rtp_sender/rtp_sender.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698