FreeCalypso > hg > rtp-debug-utils
annotate pcap-study/rtp-stream-dump.c @ 13:d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sat, 27 Jul 2024 23:39:50 +0000 |
parents | e686bc92c7d8 |
children | e7f43262efa1 |
rev | line source |
---|---|
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
1 /* |
6
709aa9ad72d1
new program rtp-stream-dump
Mychaela Falconia <falcon@freecalypso.org>
parents:
5
diff
changeset
|
2 * This program is an aid for analyzing arbitrary RTP streams: |
709aa9ad72d1
new program rtp-stream-dump
Mychaela Falconia <falcon@freecalypso.org>
parents:
5
diff
changeset
|
3 * it reads a pcap file, extracts packets belonging to a particular |
709aa9ad72d1
new program rtp-stream-dump
Mychaela Falconia <falcon@freecalypso.org>
parents:
5
diff
changeset
|
4 * RTP stream as identified by a source or destination IP:port, |
709aa9ad72d1
new program rtp-stream-dump
Mychaela Falconia <falcon@freecalypso.org>
parents:
5
diff
changeset
|
5 * and displays a one-line summary of every RTP packet. |
709aa9ad72d1
new program rtp-stream-dump
Mychaela Falconia <falcon@freecalypso.org>
parents:
5
diff
changeset
|
6 * Discontinuities are treated as non-fatal errors: an error message |
709aa9ad72d1
new program rtp-stream-dump
Mychaela Falconia <falcon@freecalypso.org>
parents:
5
diff
changeset
|
7 * is printed, but analysis continues. |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
8 */ |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
9 |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
10 #include <sys/types.h> |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
11 #include <sys/socket.h> |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
12 #include <netinet/in.h> |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
13 #include <arpa/inet.h> |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
14 #include <stdio.h> |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
15 #include <stdlib.h> |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
16 #include <string.h> |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
17 #include <strings.h> |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
18 #include <pcap/pcap.h> |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
19 |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
20 static pcap_t *pcap; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
21 static in_addr_t match_ip_addr; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
22 static u_short match_udp_port; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
23 static unsigned iphdr_addr_offset, udphdr_port_offset; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
24 static unsigned link_hdr_len, ethertype_offset; |
13
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
25 static int stream_init_flag, toad_init_flag; |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
26 static unsigned last_seq, last_tstamp, stream_ssrc; |
13
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
27 static struct timeval last_pkt_time; |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
28 |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
29 static void |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
30 check_dl_type() |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
31 { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
32 int dltype; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
33 |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
34 dltype = pcap_datalink(pcap); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
35 switch (dltype) { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
36 case DLT_EN10MB: |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
37 link_hdr_len = 14; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
38 ethertype_offset = 12; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
39 break; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
40 case DLT_RAW: |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
41 link_hdr_len = 0; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
42 break; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
43 case DLT_LINUX_SLL: |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
44 link_hdr_len = 16; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
45 ethertype_offset = 14; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
46 break; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
47 default: |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
48 fprintf(stderr, "error: unsupported data link type %d\n", |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
49 dltype); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
50 exit(1); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
51 } |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
52 } |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
53 |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
54 static void |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
55 rtp_stream_logic(rtp_hdr, pkt_idx) |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
56 u_char *rtp_hdr; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
57 unsigned pkt_idx; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
58 { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
59 unsigned cur_seq, cur_tstamp, cur_ssrc; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
60 |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
61 cur_seq = (rtp_hdr[2] << 8) | rtp_hdr[3]; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
62 cur_tstamp = (rtp_hdr[4] << 24) | (rtp_hdr[5] << 16) | |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
63 (rtp_hdr[6] << 8) | rtp_hdr[7]; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
64 cur_ssrc = (rtp_hdr[8] << 24) | (rtp_hdr[9] << 16) | |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
65 (rtp_hdr[10] << 8) | rtp_hdr[11]; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
66 if (stream_init_flag) { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
67 if (cur_ssrc != stream_ssrc) { |
5
7c85a7a913f7
rtp-gsmfr-dump: treat stream discontinuities as non-fatal
Mychaela Falconia <falcon@freecalypso.org>
parents:
3
diff
changeset
|
68 printf( |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
69 "error in packet #%u: SSRC change from 0x%08X to 0x%08X\n", |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
70 pkt_idx, stream_ssrc, cur_ssrc); |
5
7c85a7a913f7
rtp-gsmfr-dump: treat stream discontinuities as non-fatal
Mychaela Falconia <falcon@freecalypso.org>
parents:
3
diff
changeset
|
71 } else if (cur_seq != last_seq + 1 && |
7c85a7a913f7
rtp-gsmfr-dump: treat stream discontinuities as non-fatal
Mychaela Falconia <falcon@freecalypso.org>
parents:
3
diff
changeset
|
72 (cur_seq != 0 || last_seq != 0xFFFF)) { |
7c85a7a913f7
rtp-gsmfr-dump: treat stream discontinuities as non-fatal
Mychaela Falconia <falcon@freecalypso.org>
parents:
3
diff
changeset
|
73 printf( |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
74 "error in packet #%u: seq break from 0x%04X to 0x%04X\n", |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
75 pkt_idx, last_seq, cur_seq); |
5
7c85a7a913f7
rtp-gsmfr-dump: treat stream discontinuities as non-fatal
Mychaela Falconia <falcon@freecalypso.org>
parents:
3
diff
changeset
|
76 } else if (cur_tstamp != last_tstamp + 160) { |
7c85a7a913f7
rtp-gsmfr-dump: treat stream discontinuities as non-fatal
Mychaela Falconia <falcon@freecalypso.org>
parents:
3
diff
changeset
|
77 printf( |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
78 "error in packet #%u: timestamp break from 0x%08X to 0x%08X\n", |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
79 pkt_idx, last_tstamp, cur_tstamp); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
80 } |
5
7c85a7a913f7
rtp-gsmfr-dump: treat stream discontinuities as non-fatal
Mychaela Falconia <falcon@freecalypso.org>
parents:
3
diff
changeset
|
81 } else |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
82 stream_init_flag = 1; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
83 last_seq = cur_seq; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
84 last_tstamp = cur_tstamp; |
5
7c85a7a913f7
rtp-gsmfr-dump: treat stream discontinuities as non-fatal
Mychaela Falconia <falcon@freecalypso.org>
parents:
3
diff
changeset
|
85 stream_ssrc = cur_ssrc; |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
86 } |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
87 |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
88 static void |
13
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
89 process_packet(pkt, caplen, pkt_idx, pkt_time) |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
90 u_char *pkt; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
91 unsigned caplen, pkt_idx; |
13
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
92 struct timeval *pkt_time; |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
93 { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
94 unsigned udplen, payload_len; |
13
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
95 struct timeval toad; |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
96 unsigned toad_ms, toad_us; |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
97 |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
98 if (caplen < link_hdr_len + 28) |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
99 return; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
100 if (link_hdr_len) { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
101 if (pkt[ethertype_offset] != 0x08) |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
102 return; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
103 if (pkt[ethertype_offset+1] != 0x00) |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
104 return; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
105 pkt += link_hdr_len; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
106 caplen -= link_hdr_len; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
107 } |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
108 /* check IP header */ |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
109 if (pkt[0] != 0x45) |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
110 return; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
111 if (pkt[9] != 17) /* UDP */ |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
112 return; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
113 if (bcmp(pkt + iphdr_addr_offset, &match_ip_addr, 4)) |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
114 return; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
115 /* check UDP header */ |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
116 if (bcmp(pkt + 20 + udphdr_port_offset, &match_udp_port, 2)) |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
117 return; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
118 /* it is our target - now scrutinize it */ |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
119 udplen = (pkt[24] << 8) | pkt[25]; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
120 if (caplen < udplen + 20) { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
121 fprintf(stderr, |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
122 "error: packet #%u is truncated in the capture\n", |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
123 pkt_idx); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
124 exit(1); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
125 } |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
126 if (udplen < 20) { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
127 fprintf(stderr, |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
128 "error in packet #%u: UDP length is too short for RTP header\n", |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
129 pkt_idx); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
130 exit(1); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
131 } |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
132 if (pkt[28] != 0x80) { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
133 fprintf(stderr, |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
134 "error in packet #%u: unsupported RTP header structure\n", |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
135 pkt_idx); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
136 exit(1); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
137 } |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
138 rtp_stream_logic(pkt + 28, pkt_idx); |
13
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
139 printf("pkt #%u seq 0x%04X ts 0x%08X: pt=%u M=%u len=%u", pkt_idx, |
6
709aa9ad72d1
new program rtp-stream-dump
Mychaela Falconia <falcon@freecalypso.org>
parents:
5
diff
changeset
|
140 last_seq, last_tstamp, pkt[29] & 0x7F, pkt[29] >> 7, |
709aa9ad72d1
new program rtp-stream-dump
Mychaela Falconia <falcon@freecalypso.org>
parents:
5
diff
changeset
|
141 udplen - 20); |
13
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
142 if (toad_init_flag && timercmp(pkt_time, &last_pkt_time, >=)) { |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
143 timersub(pkt_time, &last_pkt_time, &toad); |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
144 if (toad.tv_sec) |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
145 printf(", toad %u.%06u s", (unsigned) toad.tv_sec, |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
146 (unsigned) toad.tv_usec); |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
147 else { |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
148 toad_ms = toad.tv_usec / 1000; |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
149 toad_us = toad.tv_usec % 1000; |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
150 printf(", toad %u.%03u ms", toad_ms, toad_us); |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
151 } |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
152 } |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
153 putchar('\n'); |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
154 bcopy(pkt_time, &last_pkt_time, sizeof(struct timeval)); |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
155 toad_init_flag = 1; |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
156 } |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
157 |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
158 main(argc, argv) |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
159 char **argv; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
160 { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
161 char errbuf[PCAP_ERRBUF_SIZE]; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
162 u_char *pkt; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
163 struct pcap_pkthdr pkthdr; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
164 unsigned pkt_idx; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
165 |
3
50aa973a91ef
new program rtp-gsmfr-dump
Mychaela Falconia <falcon@freecalypso.org>
parents:
2
diff
changeset
|
166 if (argc != 5) { |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
167 fprintf(stderr, |
3
50aa973a91ef
new program rtp-gsmfr-dump
Mychaela Falconia <falcon@freecalypso.org>
parents:
2
diff
changeset
|
168 "usage: %s pcap-file src|dest ip-addr udp-port\n", |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
169 argv[0]); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
170 exit(1); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
171 } |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
172 pcap = pcap_open_offline(argv[1], errbuf); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
173 if (!pcap) { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
174 fprintf(stderr, "%s: %s\n", argv[1], errbuf); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
175 exit(1); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
176 } |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
177 check_dl_type(); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
178 if (!strcmp(argv[2], "src")) { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
179 iphdr_addr_offset = 12; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
180 udphdr_port_offset = 0; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
181 } else if (!strcmp(argv[2], "dest")) { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
182 iphdr_addr_offset = 16; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
183 udphdr_port_offset = 2; |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
184 } else { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
185 fprintf(stderr, |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
186 "error: direction argument must be \"src\" or \"dest\"\n"); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
187 exit(1); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
188 } |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
189 match_ip_addr = inet_addr(argv[3]); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
190 if (match_ip_addr == INADDR_NONE) { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
191 fprintf(stderr, "error: IP address argument is invalid\n"); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
192 exit(1); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
193 } |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
194 match_udp_port = htons(strtoul(argv[4], 0, 0)); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
195 for (pkt_idx = 0; ; pkt_idx++) { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
196 pkt = pcap_next(pcap, &pkthdr); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
197 if (!pkt) |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
198 break; |
13
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
199 process_packet(pkt, (unsigned) pkthdr.caplen, pkt_idx, |
d59dbdfe1778
rtp-stream-dump: compute and print time-of-arrival delta (toad)
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
200 &pkthdr.ts); |
0
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
201 } |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
202 if (!stream_init_flag) { |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
203 fprintf(stderr, "error: specified RTP stream not found\n"); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
204 exit(1); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
205 } |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
206 exit(0); |
05ff0f7ac977
initial commit: split from gsm-codec-lib
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
207 } |