]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
res_rtp_asterisk: Count a roll-over of the sequence number even on lost packets. 23/3223/1
authorAlexander Traud <pabstraud@compuserve.com>
Mon, 18 Jul 2016 10:13:25 +0000 (12:13 +0200)
committerAlexander Traud <pabstraud@compuserve.com>
Mon, 18 Jul 2016 10:47:20 +0000 (05:47 -0500)
With this change, the initial RTP sequence number is randomly chosen not between
0 and 65535 (0xffff) but 0 and 32767 (0x7fff). This assures, the roll-over
counter (ROC) synchronization is not lost for sRTP, when the very first RTP
packets get lost; see http://srtp.sourceforge.net/faq.html#Q6

ASTERISK-26207 #close

Change-Id: I9a527e3aa3ce8f3becc5131d7ba32b57b5845464

res/res_rtp_asterisk.c

index 8055e877f2865aeb727ffad120e5021184229351..9db5aefe73e535a36552fc0e89d65c19a265c745 100644 (file)
@@ -2592,7 +2592,7 @@ static int ast_rtp_new(struct ast_rtp_instance *instance,
 
        /* Set default parameters on the newly created RTP structure */
        rtp->ssrc = ast_random();
-       rtp->seqno = ast_random() & 0xffff;
+       rtp->seqno = ast_random() & 0x7fff;
        rtp->strict_rtp_state = (strictrtp ? STRICT_RTP_LEARN : STRICT_RTP_OPEN);
        if (strictrtp) {
                rtp_learning_seq_init(&rtp->rtp_source_learn, (uint16_t)rtp->seqno);