stefan@webrtc.org | 1dd9b4d | 2014-01-31 09:15:48 | [diff] [blame] | 1 | /* |
| 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 | |
| 11 | #include <stdio.h> |
stefan@webrtc.org | 9b5f4d8 | 2014-03-10 09:38:39 | [diff] [blame] | 12 | #include <sstream> |
stefan@webrtc.org | 1dd9b4d | 2014-01-31 09:15:48 | [diff] [blame] | 13 | |
| 14 | #include "webrtc/modules/remote_bitrate_estimator/tools/bwe_rtp.h" |
| 15 | #include "webrtc/modules/rtp_rtcp/interface/rtp_header_parser.h" |
| 16 | #include "webrtc/modules/rtp_rtcp/interface/rtp_payload_registry.h" |
stefan@webrtc.org | 1dd9b4d | 2014-01-31 09:15:48 | [diff] [blame] | 17 | #include "webrtc/system_wrappers/interface/scoped_ptr.h" |
pbos@webrtc.org | 4b5625e | 2014-08-06 16:26:56 | [diff] [blame] | 18 | #include "webrtc/test/rtp_file_reader.h" |
stefan@webrtc.org | 1dd9b4d | 2014-01-31 09:15:48 | [diff] [blame] | 19 | |
| 20 | int main(int argc, char** argv) { |
stefan@webrtc.org | f9e7c9d | 2014-03-10 09:11:21 | [diff] [blame] | 21 | if (argc < 4) { |
| 22 | fprintf(stderr, "Usage: rtp_to_text <extension type> <extension id>" |
| 23 | " <input_file.rtp> [-t]\n"); |
| 24 | fprintf(stderr, "<extension type> can either be:\n" |
stefan@webrtc.org | 1dd9b4d | 2014-01-31 09:15:48 | [diff] [blame] | 25 | " abs for absolute send time or\n" |
| 26 | " tsoffset for timestamp offset.\n" |
stefan@webrtc.org | f9e7c9d | 2014-03-10 09:11:21 | [diff] [blame] | 27 | "<extension id> is the id associated with the extension.\n" |
| 28 | " -t is an optional flag, if set only packet arrival time will be" |
| 29 | " output.\n"); |
stefan@webrtc.org | 1dd9b4d | 2014-01-31 09:15:48 | [diff] [blame] | 30 | return -1; |
| 31 | } |
pbos@webrtc.org | 4b5625e | 2014-08-06 16:26:56 | [diff] [blame] | 32 | webrtc::test::RtpFileReader* reader; |
stefan@webrtc.org | 1dd9b4d | 2014-01-31 09:15:48 | [diff] [blame] | 33 | webrtc::RtpHeaderParser* parser; |
| 34 | if (!ParseArgsAndSetupEstimator(argc, argv, NULL, NULL, &reader, &parser, |
| 35 | NULL, NULL)) { |
| 36 | return -1; |
| 37 | } |
stefan@webrtc.org | f9e7c9d | 2014-03-10 09:11:21 | [diff] [blame] | 38 | bool arrival_time_only = (argc >= 5 && strncmp(argv[4], "-t", 2) == 0); |
pbos@webrtc.org | 4b5625e | 2014-08-06 16:26:56 | [diff] [blame] | 39 | webrtc::scoped_ptr<webrtc::test::RtpFileReader> rtp_reader(reader); |
stefan@webrtc.org | 1dd9b4d | 2014-01-31 09:15:48 | [diff] [blame] | 40 | webrtc::scoped_ptr<webrtc::RtpHeaderParser> rtp_parser(parser); |
stefan@webrtc.org | f9e7c9d | 2014-03-10 09:11:21 | [diff] [blame] | 41 | fprintf(stdout, "seqnum timestamp ts_offset abs_sendtime recvtime " |
stefan@webrtc.org | 1dd9b4d | 2014-01-31 09:15:48 | [diff] [blame] | 42 | "markerbit ssrc size\n"); |
| 43 | int packet_counter = 0; |
stefan@webrtc.org | 1dd9b4d | 2014-01-31 09:15:48 | [diff] [blame] | 44 | int non_zero_abs_send_time = 0; |
| 45 | int non_zero_ts_offsets = 0; |
pbos@webrtc.org | 4b5625e | 2014-08-06 16:26:56 | [diff] [blame] | 46 | webrtc::test::RtpFileReader::Packet packet; |
| 47 | while (rtp_reader->NextPacket(&packet)) { |
solenberg@webrtc.org | b1f5010 | 2014-03-24 10:38:25 | [diff] [blame] | 48 | webrtc::RTPHeader header; |
pbos@webrtc.org | 4b5625e | 2014-08-06 16:26:56 | [diff] [blame] | 49 | parser->Parse(packet.data, packet.length, &header); |
stefan@webrtc.org | 1dd9b4d | 2014-01-31 09:15:48 | [diff] [blame] | 50 | if (header.extension.absoluteSendTime != 0) |
| 51 | ++non_zero_abs_send_time; |
| 52 | if (header.extension.transmissionTimeOffset != 0) |
| 53 | ++non_zero_ts_offsets; |
stefan@webrtc.org | f9e7c9d | 2014-03-10 09:11:21 | [diff] [blame] | 54 | if (arrival_time_only) { |
stefan@webrtc.org | 9b5f4d8 | 2014-03-10 09:38:39 | [diff] [blame] | 55 | std::stringstream ss; |
pbos@webrtc.org | 4b5625e | 2014-08-06 16:26:56 | [diff] [blame] | 56 | ss << static_cast<int64_t>(packet.time_ms) * 1000000; |
stefan@webrtc.org | 9b5f4d8 | 2014-03-10 09:38:39 | [diff] [blame] | 57 | fprintf(stdout, "%s\n", ss.str().c_str()); |
stefan@webrtc.org | f9e7c9d | 2014-03-10 09:11:21 | [diff] [blame] | 58 | } else { |
pbos@webrtc.org | 4b5625e | 2014-08-06 16:26:56 | [diff] [blame] | 59 | fprintf(stdout, |
| 60 | "%u %u %d %u %u %d %u %d\n", |
| 61 | header.sequenceNumber, |
| 62 | header.timestamp, |
| 63 | header.extension.transmissionTimeOffset, |
| 64 | header.extension.absoluteSendTime, |
| 65 | packet.time_ms, |
| 66 | header.markerBit, |
| 67 | header.ssrc, |
| 68 | static_cast<int>(packet.length)); |
stefan@webrtc.org | f9e7c9d | 2014-03-10 09:11:21 | [diff] [blame] | 69 | } |
stefan@webrtc.org | 1dd9b4d | 2014-01-31 09:15:48 | [diff] [blame] | 70 | ++packet_counter; |
| 71 | } |
stefan@webrtc.org | f9e7c9d | 2014-03-10 09:11:21 | [diff] [blame] | 72 | fprintf(stderr, "Parsed %d packets\n", packet_counter); |
| 73 | fprintf(stderr, "Packets with non-zero absolute send time: %d\n", |
stefan@webrtc.org | 1dd9b4d | 2014-01-31 09:15:48 | [diff] [blame] | 74 | non_zero_abs_send_time); |
stefan@webrtc.org | f9e7c9d | 2014-03-10 09:11:21 | [diff] [blame] | 75 | fprintf(stderr, "Packets with non-zero timestamp offset: %d\n", |
stefan@webrtc.org | 1dd9b4d | 2014-01-31 09:15:48 | [diff] [blame] | 76 | non_zero_ts_offsets); |
| 77 | return 0; |
| 78 | } |