From 213dd7a30aef5a0e8e099773a099705e213149e9 Mon Sep 17 00:00:00 2001 From: Anthony Minessale Date: Tue, 12 Aug 2008 19:12:38 +0000 Subject: [PATCH] byte swap on l16 read codec git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@9285 d0543943-73ff-0310-b7d9-9358b9ac24b2 --- src/switch_ivr_play_say.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/src/switch_ivr_play_say.c b/src/switch_ivr_play_say.c index 196b4b84fd..84bae11a44 100644 --- a/src/switch_ivr_play_say.c +++ b/src/switch_ivr_play_say.c @@ -731,6 +731,7 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_play_file(switch_core_session_t *sess const char *alt = NULL; int eof = 0; switch_size_t bread = 0; + int l16 = 0; switch_channel_pre_answer(channel); @@ -739,6 +740,10 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_play_file(switch_core_session_t *sess read_codec = switch_core_session_get_read_codec(session); + if (!strcasecmp(read_codec->implementation->iananame, "l16")) { + l16++; + } + if (switch_strlen_zero(file) || !read_codec) { status = SWITCH_STATUS_FALSE; goto end; @@ -1143,12 +1148,11 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_play_file(switch_core_session_t *sess write_frame.timestamp = timer.samplecount; } #ifndef WIN32 -#if 0 // don't seem to need it, maybe only on mac? -//#if SWITCH_BYTE_ORDER == __BIG_ENDIAN - if (!asis) { + //#if SWITCH_BYTE_ORDER == __BIG_ENDIAN + if (!asis && l16) { switch_swap_linear(write_frame.data, (int) write_frame.datalen / 2); } -#endif + //#endif #endif if (fh->vol) { switch_change_sln_volume(write_frame.data, write_frame.datalen / 2, fh->vol);