blob: 728cb63f50691dcfd18f500603c868a67ac71646 [file] [log] [blame]
asapersson@webrtc.org0f2809a2014-02-21 08:14:45 +00001/*
2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved.
3 *
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
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Henrik Kjellandera80c16a2017-07-01 16:48:15 +020011#include "webrtc/base/checks.h"
12#include "webrtc/base/logging.h"
asapersson@webrtc.org0f2809a2014-02-21 08:14:45 +000013#include "webrtc/test/rtcp_packet_parser.h"
14
15namespace webrtc {
16namespace test {
17
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020018RtcpPacketParser::RtcpPacketParser() = default;
19RtcpPacketParser::~RtcpPacketParser() = default;
Erik Språng242e22b2015-05-11 10:17:43 +020020
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020021bool RtcpPacketParser::Parse(const void* data, size_t length) {
22 const uint8_t* const buffer = static_cast<const uint8_t*>(data);
23 const uint8_t* const buffer_end = buffer + length;
24 rtcp::CommonHeader header;
25 for (const uint8_t* next_packet = buffer; next_packet != buffer_end;
26 next_packet = header.NextPacket()) {
27 RTC_DCHECK_GT(buffer_end - next_packet, 0);
28 if (!header.Parse(next_packet, buffer_end - next_packet)) {
29 LOG(LS_WARNING)
30 << "Invalid rtcp header or unaligned rtcp packet at position "
31 << (next_packet - buffer);
32 return false;
33 }
34 switch (header.type()) {
35 case rtcp::App::kPacketType:
36 app_.Parse(header);
asapersson@webrtc.orga8260062014-05-20 09:53:51 +000037 break;
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020038 case rtcp::Bye::kPacketType:
danilchap3dc929e2016-11-02 08:21:59 -070039 bye_.Parse(header, &sender_ssrc_);
asapersson@webrtc.orga8260062014-05-20 09:53:51 +000040 break;
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020041 case rtcp::ExtendedReports::kPacketType:
danilchap3dc929e2016-11-02 08:21:59 -070042 xr_.Parse(header, &sender_ssrc_);
asapersson@webrtc.orga8260062014-05-20 09:53:51 +000043 break;
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020044 case rtcp::ExtendedJitterReport::kPacketType:
45 ij_.Parse(header);
asapersson@webrtc.org4b12d402014-06-16 14:09:28 +000046 break;
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020047 case rtcp::Psfb::kPacketType:
48 switch (header.fmt()) {
49 case rtcp::Fir::kFeedbackMessageType:
danilchap3dc929e2016-11-02 08:21:59 -070050 fir_.Parse(header, &sender_ssrc_);
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020051 break;
52 case rtcp::Pli::kFeedbackMessageType:
danilchap3dc929e2016-11-02 08:21:59 -070053 pli_.Parse(header, &sender_ssrc_);
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020054 break;
55 case rtcp::Remb::kFeedbackMessageType:
danilchap3dc929e2016-11-02 08:21:59 -070056 remb_.Parse(header, &sender_ssrc_);
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020057 break;
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020058 default:
59 LOG(LS_WARNING) << "Unknown rtcp payload specific feedback type "
60 << header.fmt();
61 break;
62 }
asapersson@webrtc.org4b12d402014-06-16 14:09:28 +000063 break;
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020064 case rtcp::ReceiverReport::kPacketType:
danilchap3dc929e2016-11-02 08:21:59 -070065 receiver_report_.Parse(header, &sender_ssrc_);
asapersson@webrtc.org4b12d402014-06-16 14:09:28 +000066 break;
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020067 case rtcp::Rtpfb::kPacketType:
68 switch (header.fmt()) {
69 case rtcp::Nack::kFeedbackMessageType:
danilchap3dc929e2016-11-02 08:21:59 -070070 nack_.Parse(header, &sender_ssrc_);
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020071 break;
72 case rtcp::RapidResyncRequest::kFeedbackMessageType:
danilchap3dc929e2016-11-02 08:21:59 -070073 rrr_.Parse(header, &sender_ssrc_);
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020074 break;
75 case rtcp::Tmmbn::kFeedbackMessageType:
danilchap3dc929e2016-11-02 08:21:59 -070076 tmmbn_.Parse(header, &sender_ssrc_);
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020077 break;
78 case rtcp::Tmmbr::kFeedbackMessageType:
danilchap3dc929e2016-11-02 08:21:59 -070079 tmmbr_.Parse(header, &sender_ssrc_);
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020080 break;
81 case rtcp::TransportFeedback::kFeedbackMessageType:
danilchap3dc929e2016-11-02 08:21:59 -070082 transport_feedback_.Parse(header, &sender_ssrc_);
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020083 break;
84 default:
85 LOG(LS_WARNING) << "Unknown rtcp transport feedback type "
86 << header.fmt();
87 break;
88 }
asapersson@webrtc.org4b12d402014-06-16 14:09:28 +000089 break;
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020090 case rtcp::Sdes::kPacketType:
91 sdes_.Parse(header);
asapersson@webrtc.org4b12d402014-06-16 14:09:28 +000092 break;
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020093 case rtcp::SenderReport::kPacketType:
danilchap3dc929e2016-11-02 08:21:59 -070094 sender_report_.Parse(header, &sender_ssrc_);
asapersson@webrtc.org3b84b3a2014-06-25 12:22:17 +000095 break;
asapersson@webrtc.orga8260062014-05-20 09:53:51 +000096 default:
Danil Chapovalovba6f7be2016-09-02 18:29:10 +020097 LOG(LS_WARNING) << "Unknown rtcp packet type " << header.type();
asapersson@webrtc.orga8260062014-05-20 09:53:51 +000098 break;
asapersson@webrtc.org0f2809a2014-02-21 08:14:45 +000099 }
100 }
Danil Chapovalovba6f7be2016-09-02 18:29:10 +0200101 return true;
asapersson@webrtc.orga8260062014-05-20 09:53:51 +0000102}
103
asapersson@webrtc.org0f2809a2014-02-21 08:14:45 +0000104} // namespace test
105} // namespace webrtc