git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@867 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Anthony Minessale 2006-03-17 19:27:26 +00:00
parent 10ee3e4347
commit d86231404d
3 changed files with 50 additions and 38 deletions

View File

@ -57,7 +57,7 @@ static switch_status switch_g729_init(switch_codec *codec, switch_codec_flag fla
} else { } else {
if (encoding) { if (encoding) {
g729_init_coder(&context->encoder_object, 0); g729_init_coder(&context->encoder_object, 1);
} }
if (decoding) { if (decoding) {
@ -140,7 +140,8 @@ static switch_status switch_g729_decode(switch_codec *codec,
{ {
struct g729_context *context = codec->private_info; struct g729_context *context = codec->private_info;
int divisor = 10;
int plen = 10;
if (!context) { if (!context) {
@ -149,10 +150,23 @@ static switch_status switch_g729_decode(switch_codec *codec,
} }
if (encoded_data_len % 2 == 0) {
if (encoded_data_len % 10 == 0) { if (encoded_data_len % 12 == 0) {
return SWITCH_STATUS_BREAK;
//divisor = 12;
//plen = 10;
} else if (encoded_data_len % 10 != 0) {
//*decoded_data_len = (encoded_data_len / 2) * 160;
//memset(decoded_data, 255, *decoded_data_len);
return SWITCH_STATUS_BREAK;
} else {
divisor = plen = 10;
}
int loops = (int) encoded_data_len / 10; if (encoded_data_len % divisor == 0) {
int loops = (int) encoded_data_len / divisor;
char *edp = encoded_data; char *edp = encoded_data;
@ -163,15 +177,11 @@ static switch_status switch_g729_decode(switch_codec *codec,
unsigned int new_len = 0; unsigned int new_len = 0;
for (x = 0; x < loops && new_len < *decoded_data_len; x++) { for (x = 0; x < loops && new_len < *decoded_data_len; x++) {
g729_decoder(&context->decoder_object, ddp, edp, plen);
g729_decoder(&context->decoder_object, ddp, edp, 10);
ddp += 80; ddp += 80;
edp += divisor;
edp += 10;
new_len += 160; new_len += 160;
} }
if (new_len <= *decoded_data_len) { if (new_len <= *decoded_data_len) {
@ -185,7 +195,7 @@ static switch_status switch_g729_decode(switch_codec *codec,
return SWITCH_STATUS_FALSE; return SWITCH_STATUS_FALSE;
} }
}
} else { } else {
switch_console_printf(SWITCH_CHANNEL_CONSOLE, "yo this frame is an odd size [%d]\n", encoded_data_len); switch_console_printf(SWITCH_CHANNEL_CONSOLE, "yo this frame is an odd size [%d]\n", encoded_data_len);

View File

@ -712,7 +712,7 @@ static switch_status wanpipe_write_frame(switch_core_session *session, switch_fr
write(tech_pvt->fd, bp, (int) globals.mtu); write(tech_pvt->fd, bp, (int) globals.mtu);
#endif #endif
towrite = bytes >= globals.mtu ? globals.mtu : bytes; towrite = bytes >= globals.mtu ? globals.mtu : bytes;
//printf("write %d\n", towrite);
res = sangoma_sendmsg_socket(tech_pvt->socket, res = sangoma_sendmsg_socket(tech_pvt->socket,
&tech_pvt->hdrframe, sizeof(tech_pvt->hdrframe), bp, towrite, 0); &tech_pvt->hdrframe, sizeof(tech_pvt->hdrframe), bp, towrite, 0);
if (res < 0) { if (res < 0) {

View File

@ -1071,7 +1071,6 @@ SWITCH_DECLARE(switch_status) switch_core_session_write_frame(switch_core_sessio
session->write_codec->implementation->samples_per_second, session->write_codec->implementation->samples_per_second,
session->raw_write_frame.data, session->raw_write_frame.data,
&session->raw_write_frame.datalen, &session->raw_write_frame.rate, &flag); &session->raw_write_frame.datalen, &session->raw_write_frame.rate, &flag);
switch (status) { switch (status) {
case SWITCH_STATUS_RESAMPLE: case SWITCH_STATUS_RESAMPLE:
write_frame = &session->raw_write_frame; write_frame = &session->raw_write_frame;
@ -1087,6 +1086,9 @@ SWITCH_DECLARE(switch_status) switch_core_session_write_frame(switch_core_sessio
case SWITCH_STATUS_SUCCESS: case SWITCH_STATUS_SUCCESS:
write_frame = &session->raw_write_frame; write_frame = &session->raw_write_frame;
break; break;
case SWITCH_STATUS_BREAK:
return SWITCH_STATUS_SUCCESS;
break;
case SWITCH_STATUS_NOOP: case SWITCH_STATUS_NOOP:
write_frame = frame; write_frame = frame;
status = SWITCH_STATUS_SUCCESS; status = SWITCH_STATUS_SUCCESS;
@ -1119,7 +1121,7 @@ SWITCH_DECLARE(switch_status) switch_core_session_write_frame(switch_core_sessio
if (!session->raw_write_buffer) { if (!session->raw_write_buffer) {
size_t bytes = session->write_codec->implementation->bytes_per_frame * 10; size_t bytes = session->write_codec->implementation->bytes_per_frame * 10;
switch_console_printf(SWITCH_CHANNEL_CONSOLE, switch_console_printf(SWITCH_CHANNEL_CONSOLE,
"Engaging Write Buffer at %d bytes to accomidate %d->%d\n", "Engaging Write Buffer at %d bytes to accomodate %d->%d\n",
bytes, bytes,
write_frame->datalen, session->write_codec->implementation->bytes_per_frame); write_frame->datalen, session->write_codec->implementation->bytes_per_frame);
if ((status = if ((status =