/* * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #include #include #include "modules/remote_bitrate_estimator/tools/bwe_rtp.h" #include "modules/rtp_rtcp/include/rtp_header_extension_map.h" #include "modules/rtp_rtcp/source/rtp_header_extensions.h" #include "modules/rtp_rtcp/source/rtp_packet.h" #include "rtc_base/strings/string_builder.h" #include "test/rtp_file_reader.h" int main(int argc, char* argv[]) { std::unique_ptr reader; webrtc::RtpHeaderExtensionMap rtp_header_extensions; if (!ParseArgsAndSetupRtpReader(argc, argv, reader, rtp_header_extensions)) { return -1; } bool arrival_time_only = (argc >= 5 && strncmp(argv[4], "-t", 2) == 0); fprintf(stdout, "seqnum timestamp ts_offset abs_sendtime recvtime " "markerbit ssrc size original_size\n"); int packet_counter = 0; int non_zero_abs_send_time = 0; int non_zero_ts_offsets = 0; webrtc::test::RtpPacket packet; while (reader->NextPacket(&packet)) { webrtc::RtpPacket header(&rtp_header_extensions); header.Parse(packet.data, packet.length); uint32_t abs_send_time = 0; if (header.GetExtension(&abs_send_time) && abs_send_time != 0) ++non_zero_abs_send_time; int32_t toffset = 0; if (header.GetExtension(&toffset) && toffset != 0) ++non_zero_ts_offsets; if (arrival_time_only) { rtc::StringBuilder ss; ss << static_cast(packet.time_ms) * 1000000; fprintf(stdout, "%s\n", ss.str().c_str()); } else { fprintf(stdout, "%u %u %d %u %u %d %u %zu %zu\n", header.SequenceNumber(), header.Timestamp(), toffset, abs_send_time, packet.time_ms, header.Marker(), header.Ssrc(), packet.length, packet.original_length); } ++packet_counter; } fprintf(stderr, "Parsed %d packets\n", packet_counter); fprintf(stderr, "Packets with non-zero absolute send time: %d\n", non_zero_abs_send_time); fprintf(stderr, "Packets with non-zero timestamp offset: %d\n", non_zero_ts_offsets); return 0; }