diff --git a/patches/pa.diff b/patches/pa.diff new file mode 100644 index 0000000000..466208e52b --- /dev/null +++ b/patches/pa.diff @@ -0,0 +1,254 @@ +Index: src/mod/endpoints/mod_portaudio/mod_portaudio.c +=================================================================== +--- src/mod/endpoints/mod_portaudio/mod_portaudio.c (revision 12655) ++++ src/mod/endpoints/mod_portaudio/mod_portaudio.c (working copy) +@@ -124,7 +124,8 @@ + private_t *call_list; + int ring_interval; + GFLAGS flags; +- switch_timer_t timer; ++ switch_timer_t read_timer; ++ switch_timer_t write_timer; + switch_timer_t hold_timer; + int dual_streams; + time_t deactivate_timer; +@@ -249,7 +250,7 @@ + } + + while (switch_channel_get_state(channel) == CS_INIT && !switch_test_flag(tech_pvt, TFLAG_ANSWER)) { +- switch_size_t olen = globals.timer.samples; ++ switch_size_t olen = globals.read_timer.samples; + + if (switch_micro_time_now() - last >= waitsec) { + char buf[512]; +@@ -268,7 +269,7 @@ + } + + if (ring_file) { +- if (switch_core_timer_next(&globals.timer) != SWITCH_STATUS_SUCCESS) { ++ if (switch_core_timer_next(&globals.read_timer) != SWITCH_STATUS_SUCCESS) { + switch_core_file_close(&fh); + break; + } +@@ -279,7 +280,7 @@ + } + + if (globals.ring_stream) { +- WriteAudioStream(globals.ring_stream, abuf, (long) olen, &globals.timer); ++ WriteAudioStream(globals.ring_stream, abuf, (long) olen, &globals.write_timer); + } + } else { + switch_yield(10000); +@@ -355,10 +356,14 @@ + switch_core_codec_destroy(&globals.write_codec); + } + +- if (globals.timer.timer_interface) { +- switch_core_timer_destroy(&globals.timer); ++ if (globals.read_timer.timer_interface) { ++ switch_core_timer_destroy(&globals.read_timer); + } + ++ if (globals.write_timer.timer_interface) { ++ switch_core_timer_destroy(&globals.write_timer); ++ } ++ + if (globals.hold_timer.timer_interface) { + switch_core_timer_destroy(&globals.hold_timer); + } +@@ -597,14 +602,13 @@ + + switch_mutex_lock(globals.device_lock); + samples = ReadAudioStream(globals.audio_stream, globals.read_frame.data, +- globals.read_codec.implementation->samples_per_packet, &globals.timer); ++ globals.read_codec.implementation->samples_per_packet, &globals.read_timer); + switch_mutex_unlock(globals.device_lock); + + if (samples) { + globals.read_frame.datalen = samples * 2; + globals.read_frame.samples = samples; + +- //switch_core_timer_check(&globals.timer, SWITCH_TRUE); + *frame = &globals.read_frame; + + if (!switch_test_flag((&globals), GFLAG_MOUTH)) { +@@ -649,7 +653,7 @@ + + if (globals.audio_stream) { + if (switch_test_flag((&globals), GFLAG_EAR)) { +- WriteAudioStream(globals.audio_stream, (short *) frame->data, (int) (frame->datalen / sizeof(SAMPLE)), &globals.timer); ++ WriteAudioStream(globals.audio_stream, (short *) frame->data, (int) (frame->datalen / sizeof(SAMPLE)), &globals.write_timer); + } + status = SWITCH_STATUS_SUCCESS; + } +@@ -1278,10 +1282,14 @@ + destroy_codecs(); + } + +- if (globals.timer.timer_interface) { +- switch_core_timer_sync(&globals.timer); ++ if (globals.read_timer.timer_interface) { ++ switch_core_timer_sync(&globals.read_timer); + } + ++ if (globals.write_timer.timer_interface) { ++ switch_core_timer_sync(&globals.write_timer); ++ } ++ + if (globals.audio_stream) { + return SWITCH_STATUS_SUCCESS; + } +@@ -1310,8 +1318,8 @@ + } + } + +- if (!globals.timer.timer_interface) { +- if (switch_core_timer_init(&globals.timer, ++ if (!globals.read_timer.timer_interface) { ++ if (switch_core_timer_init(&globals.read_timer, + globals.timer_name, codec_ms, globals.read_codec.implementation->samples_per_packet, + module_pool) != SWITCH_STATUS_SUCCESS) { + switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "setup timer failed!\n"); +@@ -1321,6 +1329,19 @@ + } + } + ++ ++ if (!globals.write_timer.timer_interface) { ++ if (switch_core_timer_init(&globals.write_timer, ++ globals.timer_name, codec_ms, globals.read_codec.implementation->samples_per_packet, ++ module_pool) != SWITCH_STATUS_SUCCESS) { ++ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "setup timer failed!\n"); ++ switch_core_codec_destroy(&globals.read_codec); ++ switch_core_codec_destroy(&globals.write_codec); ++ switch_core_timer_destroy(&globals.read_timer); ++ return SWITCH_STATUS_FALSE; ++ } ++ } ++ + if (!globals.hold_timer.timer_interface) { + if (switch_core_timer_init(&globals.hold_timer, + globals.timer_name, codec_ms, globals.read_codec.implementation->samples_per_packet, +@@ -1328,7 +1349,8 @@ + switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "setup hold timer failed!\n"); + switch_core_codec_destroy(&globals.read_codec); + switch_core_codec_destroy(&globals.write_codec); +- switch_core_timer_destroy(&globals.timer); ++ switch_core_timer_destroy(&globals.read_timer); ++ switch_core_timer_destroy(&globals.write_timer); + return SWITCH_STATUS_FALSE; + } + } +@@ -1366,7 +1388,8 @@ + switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Can't open audio device\n"); + switch_core_codec_destroy(&globals.read_codec); + switch_core_codec_destroy(&globals.write_codec); +- switch_core_timer_destroy(&globals.timer); ++ switch_core_timer_destroy(&globals.read_timer); ++ switch_core_timer_destroy(&globals.write_timer); + switch_core_timer_destroy(&globals.hold_timer); + return SWITCH_STATUS_FALSE; + } +@@ -1963,8 +1986,8 @@ + playfile, seconds, samples, globals.read_codec.implementation->actual_samples_per_second); + + while (switch_core_file_read(&fh, abuf, &olen) == SWITCH_STATUS_SUCCESS) { +- WriteAudioStream(globals.audio_stream, abuf, (long) olen, &globals.timer); +- switch_core_timer_next(&globals.timer); ++ WriteAudioStream(globals.audio_stream, abuf, (long) olen, &globals.read_timer); ++ switch_core_timer_next(&globals.read_timer); + samples -= (int) olen; + if (samples <= 0) { + break; +@@ -1993,8 +2016,8 @@ + int i; + for(i = 0; i < 400; i++) { + if ((samples = ReadAudioStream(globals.audio_stream, globals.read_frame.data, +- globals.read_codec.implementation->samples_per_packet, &globals.timer))) { +- WriteAudioStream(globals.audio_stream, globals.read_frame.data, (long) samples, &globals.timer); ++ globals.read_codec.implementation->samples_per_packet, &globals.read_timer))) { ++ WriteAudioStream(globals.audio_stream, globals.read_frame.data, (long) samples, &globals.write_timer); + success = 1; + } + switch_yield(10000); +Index: src/mod/endpoints/mod_portaudio/pablio.c +=================================================================== +--- src/mod/endpoints/mod_portaudio/pablio.c (revision 12655) ++++ src/mod/endpoints/mod_portaudio/pablio.c (working copy) +@@ -146,17 +146,15 @@ + char *p = (char *) data; + long numBytes = aStream->bytesPerFrame * numFrames; + +- while (numBytes > 0) { +- bytesWritten = PaUtil_WriteRingBuffer(&aStream->outFIFO, p, numBytes); +- numBytes -= bytesWritten; +- p += bytesWritten; +- if (numBytes > 0) { +- if (switch_core_timer_check(timer, SWITCH_TRUE) == SWITCH_STATUS_SUCCESS) { +- PaUtil_FlushRingBuffer(&aStream->outFIFO); +- return 0; +- } +- switch_cond_next(); +- } ++ switch_core_timer_next(timer); ++ ++ bytesWritten = PaUtil_WriteRingBuffer(&aStream->outFIFO, p, numBytes); ++ numBytes -= bytesWritten; ++ p += bytesWritten; ++ ++ if (numBytes > 0) { ++ PaUtil_FlushRingBuffer(&aStream->outFIFO); ++ return 0; + } + return numFrames; + } +@@ -171,32 +169,28 @@ + char *p = (char *) data; + long avail, totalBytes = 0, neededBytes = aStream->bytesPerFrame * numFrames; + +- for (;;) { +- avail = PaUtil_GetRingBufferReadAvailable(&aStream->inFIFO); ++ switch_core_timer_next(timer); ++ ++ avail = PaUtil_GetRingBufferReadAvailable(&aStream->inFIFO); + +- if (switch_core_timer_check(timer, SWITCH_TRUE) == SWITCH_STATUS_SUCCESS) { +- break; +- } ++ if (avail >= neededBytes * 6) { ++ PaUtil_FlushRingBuffer(&aStream->inFIFO); ++ avail = 0; ++ } + +- if (avail >= neededBytes * 6) { +- PaUtil_FlushRingBuffer(&aStream->inFIFO); +- avail = 0; +- } ++ bytesRead = 0; + +- bytesRead = 0; +- +- if (totalBytes < neededBytes && avail >= neededBytes) { +- bytesRead = PaUtil_ReadRingBuffer(&aStream->inFIFO, p, neededBytes); +- totalBytes += bytesRead; +- } +- +- if (bytesRead) { +- p += bytesRead; +- } else { +- switch_cond_next(); +- } ++ if (totalBytes < neededBytes && avail >= neededBytes) { ++ bytesRead = PaUtil_ReadRingBuffer(&aStream->inFIFO, p, neededBytes); ++ totalBytes += bytesRead; + } + ++ if (bytesRead) { ++ p += bytesRead; ++ } else { ++ switch_cond_next(); ++ } ++ + return totalBytes / aStream->bytesPerFrame; + } +