]> git.ipfire.org Git - thirdparty/freeswitch.git/commitdiff
FS-3910 test this patch
authorAnthony Minessale <anthm@freeswitch.org>
Fri, 17 Feb 2012 00:15:50 +0000 (18:15 -0600)
committerAnthony Minessale <anthm@freeswitch.org>
Fri, 17 Feb 2012 00:15:50 +0000 (18:15 -0600)
src/include/private/switch_core_pvt.h
src/switch_core_io.c
src/switch_core_media_bug.c

index 13727b73900b8bddc1343af3db11a9cdb7c21b13..9473139f20c85a2d1acaebe2cfc06af03b5c5738 100644 (file)
@@ -196,8 +196,7 @@ struct switch_media_bug {
        switch_codec_implementation_t read_impl;
        switch_codec_implementation_t write_impl;
        switch_timer_t timer;
-       uint32_t last_read_ts;
-       uint32_t last_write_ts;
+       uint32_t record_frame_size;
        switch_frame_t *ping_frame;
        struct switch_media_bug *next;
 };
index 01e958b2439a871d7f258749c1985d95bc3c9294..3a1b433c468b94de5a3112cf76249f544b408504 100644 (file)
@@ -486,13 +486,8 @@ SWITCH_DECLARE(switch_status_t) switch_core_session_read_frame(switch_core_sessi
                                }
 
                                if (bp->ready && switch_test_flag(bp, SMBF_READ_STREAM)) {
-                                       audio_buffer_header_t h = { 0 };
-
                                        switch_mutex_lock(bp->read_mutex);
-                                       h.ts = bp->timer.samplecount;
-                                       h.len = read_frame->datalen;
-                                       switch_buffer_write(bp->raw_read_buffer, &h, sizeof(h));
-                                       switch_buffer_write(bp->raw_read_buffer, read_frame->data, h.len);
+                                       switch_buffer_write(bp->raw_read_buffer, read_frame->data, read_frame->datalen);
 
                                        if (bp->callback) {
                                                ok = bp->callback(bp, bp->user_data, SWITCH_ABC_TYPE_READ);
@@ -654,10 +649,6 @@ SWITCH_DECLARE(switch_status_t) switch_core_session_read_frame(switch_core_sessi
                                        continue;
                                }
 
-                               if (bp->ready && bp->timer.timer_interface) {
-                                       switch_core_timer_sync(&bp->timer);
-                               }
-
                                if (bp->ready && switch_test_flag(bp, SMBF_READ_PING)) {
                                        switch_mutex_lock(bp->read_mutex);
                                        bp->ping_frame = *frame;
@@ -982,14 +973,8 @@ SWITCH_DECLARE(switch_status_t) switch_core_session_write_frame(switch_core_sess
                        }
 
                        if (switch_test_flag(bp, SMBF_WRITE_STREAM)) {
-                               audio_buffer_header_t h = { 0 };
-                               
                                switch_mutex_lock(bp->write_mutex);
-                               h.ts = bp->timer.samplecount;
-                               h.len = write_frame->datalen;
-                               
-                               switch_buffer_write(bp->raw_write_buffer, &h, sizeof(h));
-                               switch_buffer_write(bp->raw_write_buffer, write_frame->data, h.len);
+                               switch_buffer_write(bp->raw_write_buffer, write_frame->data, write_frame->datalen);
                                switch_mutex_unlock(bp->write_mutex);
                                
                                if (bp->callback) {
index b8e84661a0428f4c2f7fb754aa0cf97fda288fcf..14eda22e16ca6b101378ebbee76bb36ca36dfc1c 100644 (file)
@@ -148,20 +148,6 @@ SWITCH_DECLARE(void) switch_core_media_bug_inuse(switch_media_bug_t *bug, switch
        }
 }
 
-static switch_size_t do_peek(switch_buffer_t *buffer, audio_buffer_header_t *h)
-{
-       const void *vp = NULL;
-       audio_buffer_header_t *hp;
-       switch_size_t r;
-
-       if ((r = switch_buffer_peek_zerocopy(buffer, &vp))) {
-               hp = (audio_buffer_header_t *) vp;
-               *h = *hp;
-       }
-
-       return r;
-}
-
 SWITCH_DECLARE(switch_status_t) switch_core_media_bug_read(switch_media_bug_t *bug, switch_frame_t *frame, switch_bool_t fill)
 {
        switch_size_t bytes = 0, datalen = 0;
@@ -172,8 +158,8 @@ SWITCH_DECLARE(switch_status_t) switch_core_media_bug_read(switch_media_bug_t *b
        uint32_t blen;
        switch_codec_implementation_t read_impl = { 0 };
        int16_t *tp;
-       audio_buffer_header_t rh = { 0 }, wh = { 0 };
-       int do_read = 0, do_write = 0, fill_read = 0, fill_write = 0;
+       switch_size_t do_read = 0, do_write = 0;
+       int fill_read = 0, fill_write = 0;
 
 
        switch_core_session_get_read_impl(bug->session, &read_impl);
@@ -197,23 +183,40 @@ SWITCH_DECLARE(switch_status_t) switch_core_media_bug_read(switch_media_bug_t *b
 
        if (switch_test_flag(bug, SMBF_READ_STREAM)) {
                switch_mutex_lock(bug->read_mutex);
-               do_read = !!do_peek(bug->raw_read_buffer, &rh);
+               do_read = switch_buffer_inuse(bug->raw_read_buffer);
                switch_mutex_unlock(bug->read_mutex);
        }
 
        if (switch_test_flag(bug, SMBF_WRITE_STREAM)) {
                switch_mutex_lock(bug->write_mutex);
-               do_write = !!do_peek(bug->raw_write_buffer, &wh);
+               do_write = switch_buffer_inuse(bug->raw_write_buffer);
                switch_mutex_unlock(bug->write_mutex);
        }
        
-       if ((do_read && rh.len > SWITCH_RECOMMENDED_BUFFER_SIZE) || (do_write && wh.len > SWITCH_RECOMMENDED_BUFFER_SIZE)) {
-               switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(switch_core_media_bug_get_session(bug)), SWITCH_LOG_ERROR, "Framing Error!\n");
-               switch_core_media_bug_flush(bug);
-               return SWITCH_STATUS_FALSE;
-       }
+       if (bug->record_frame_size) {
+               if ((do_read && do_read < bug->record_frame_size) || (do_write && do_write < bug->record_frame_size)) {
+                       return SWITCH_STATUS_FALSE;
+               }
 
+               if (do_read && do_read > bug->record_frame_size) {
+                       do_read = bug->record_frame_size;
+               }
 
+               if (do_write && do_write > bug->record_frame_size) {
+                       do_write = bug->record_frame_size;
+               }
+       } else {
+               if (do_read && do_write) {
+                       if (do_read > do_write) {
+                               do_read = do_write;
+                       } else if (do_write > do_read) {
+                               do_write = do_read;
+                       }
+
+                       bug->record_frame_size = do_read;
+               }
+       }
+       
        fill_read = !do_read;
        fill_write = !do_write;
 
@@ -223,19 +226,13 @@ SWITCH_DECLARE(switch_status_t) switch_core_media_bug_read(switch_media_bug_t *b
 
        if (do_read) {
                switch_mutex_lock(bug->read_mutex);
-               if (switch_buffer_read(bug->raw_read_buffer, &rh, sizeof(rh))) {
-                       bug->last_read_ts = rh.ts;
-                       frame->datalen = (uint32_t) switch_buffer_read(bug->raw_read_buffer, frame->data, rh.len);
-                       if (frame->datalen != rh.len) {
-                               switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(switch_core_media_bug_get_session(bug)), SWITCH_LOG_ERROR, "Framing Error Reading!\n");
-                               switch_core_media_bug_flush(bug);
-                               switch_mutex_unlock(bug->read_mutex);
-                               return SWITCH_STATUS_FALSE;
-                       }
-               } else {
-                       do_read = 0;
+               frame->datalen = (uint32_t) switch_buffer_read(bug->raw_read_buffer, frame->data, do_read);
+               if (frame->datalen != do_read) {
+                       switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(switch_core_media_bug_get_session(bug)), SWITCH_LOG_ERROR, "Framing Error Reading!\n");
+                       switch_core_media_bug_flush(bug);
+                       switch_mutex_unlock(bug->read_mutex);
+                       return SWITCH_STATUS_FALSE;
                }
-               
                switch_mutex_unlock(bug->read_mutex);
        } else if (fill_read) {
                frame->datalen = bytes;
@@ -245,17 +242,12 @@ SWITCH_DECLARE(switch_status_t) switch_core_media_bug_read(switch_media_bug_t *b
        if (do_write) {
                switch_assert(bug->raw_write_buffer);
                switch_mutex_lock(bug->write_mutex);
-               if ((switch_buffer_read(bug->raw_write_buffer, &wh, sizeof(wh)))) {
-                       bug->last_write_ts = wh.ts;
-                       datalen = (uint32_t) switch_buffer_read(bug->raw_write_buffer, bug->data, wh.len);
-                       if (datalen != wh.len) {
-                               switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(switch_core_media_bug_get_session(bug)), SWITCH_LOG_ERROR, "Framing Error Writing!\n");
-                               switch_core_media_bug_flush(bug);
-                               switch_mutex_unlock(bug->write_mutex);
-                               return SWITCH_STATUS_FALSE;
-                       }
-               } else {
-                       do_write = 0;
+               datalen = (uint32_t) switch_buffer_read(bug->raw_write_buffer, bug->data, do_write);
+               if (datalen != do_write) {
+                       switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(switch_core_media_bug_get_session(bug)), SWITCH_LOG_ERROR, "Framing Error Writing!\n");
+                       switch_core_media_bug_flush(bug);
+                       switch_mutex_unlock(bug->write_mutex);
+                       return SWITCH_STATUS_FALSE;
                }
                switch_mutex_unlock(bug->write_mutex);
        } else if (fill_write) {