7 typedef struct Hdr Hdr;
9 uchar hdr; /* RTCP header */
10 uchar pt; /* Packet type */
11 uchar len[2]; /* Report length */
12 uchar ssrc[4]; /* Synchronization source identifier */
13 uchar ntp[8]; /* NTP time stamp */
14 uchar rtp[4]; /* RTP time stamp */
15 uchar pktc[4]; /* Sender's packet count */
16 uchar octc[4]; /* Sender's octet count */
19 typedef struct Report Report;
21 uchar ssrc[4]; /* SSRC identifier */
22 uchar lost[4]; /* Fraction + cumu lost */
23 uchar seqhi[4]; /* Highest seq number received */
24 uchar jitter[4]; /* Interarrival jitter */
25 uchar lsr[4]; /* Last SR */
26 uchar dlsr[4]; /* Delay since last SR */
30 RTCPLEN = 28, /* Minimum size of an RTCP header */
42 if(m->pe - m->ps < RTCPLEN)
46 if(m->pe - m->ps < (NetS(h->len) + 1) * 4)
51 m->p = seprint(m->p, m->e, "version=%d rc=%d tp=%d ssrc=%8ux "
52 "ntp=%d.%.10ud rtp=%d pktc=%d octc=%d hlen=%d",
53 (h->hdr >> 6) & 3, rc, h->pt, NetL(h->ssrc), NetL(h->ntp),
54 (uint)NetL(&h->ntp[4]), NetL(h->rtp), NetL(h->pktc),
55 NetL(h->octc), (NetS(h->len) + 1) * 4);
57 for(i = 0; i < rc; i++){
61 frac = (int)((r->lost[0] * 100.) / 256.);
63 dlsr = NetL(r->dlsr) / 65536.;
65 m->p = seprint(m->p, m->e, "\n\trr(csrc=%8ux frac=%3d%% "
66 "cumu=%10d seqhi=%10ud jitter=%10d lsr=%8ux dlsr=%f)",
67 NetL(r->ssrc), frac, NetL(r->lost), NetL(r->seqhi),
68 NetL(r->jitter), NetL(r->lsr), dlsr);