]> git.ipfire.org Git - thirdparty/freeswitch.git/commitdiff
FS-7499: don't send fir or pli till stun is established
authorAnthony Minessale <anthm@freeswitch.org>
Thu, 11 Dec 2014 03:08:16 +0000 (21:08 -0600)
committerMichael Jerris <mike@jerris.com>
Thu, 28 May 2015 17:46:51 +0000 (12:46 -0500)
src/switch_rtp.c

index 86809ddb05b3fb6c3fdc7cb451aeb478a8aebcf6..e1e2a55f68b5109250f5596fb1ffd24ed505bfab 100644 (file)
@@ -3973,6 +3973,11 @@ SWITCH_DECLARE(void) switch_rtp_flush(switch_rtp_t *rtp_session)
 
 SWITCH_DECLARE(void) switch_rtp_video_refresh(switch_rtp_t *rtp_session)
 {
+
+       if (!rtp_write_ready(rtp_session, 0, __LINE__)) {
+               return;
+       }
+
        if (rtp_session->flags[SWITCH_RTP_FLAG_VIDEO] && 
                (rtp_session->ice.ice_user || rtp_session->flags[SWITCH_RTP_FLAG_FIR])) {
                rtp_session->fir_count++;
@@ -3982,6 +3987,10 @@ SWITCH_DECLARE(void) switch_rtp_video_refresh(switch_rtp_t *rtp_session)
 
 SWITCH_DECLARE(void) switch_rtp_video_loss(switch_rtp_t *rtp_session)
 {
+       if (!rtp_write_ready(rtp_session, 0, __LINE__)) {
+               return;
+       }
+
        if (rtp_session->flags[SWITCH_RTP_FLAG_VIDEO] && 
                (rtp_session->ice.ice_user || rtp_session->flags[SWITCH_RTP_FLAG_PLI])) {
                rtp_session->pli_count++;
@@ -6361,6 +6370,8 @@ SWITCH_DECLARE(switch_status_t) switch_rtp_zerocopy_read(switch_rtp_t *rtp_sessi
 
 static int rtp_write_ready(switch_rtp_t *rtp_session, uint32_t bytes, int line)
 {
+       if (!rtp_session) return 0;
+       
        if (rtp_session->ice.ice_user && !(rtp_session->ice.rready && rtp_session->ice.ready)) {
                switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG1, "Skip sending %s packet %ld bytes (ice not ready @ line %d!)\n", 
                                                  rtp_type(rtp_session), (long)bytes, line);