[Freeswitch-svn] [commit] r5987 - in freeswitch/trunk/src: . include mod/applications/mod_conference mod/codecs/mod_amr mod/codecs/mod_g711 mod/codecs/mod_g722 mod/codecs/mod_g723_1 mod/codecs/mod_g726 mod/codecs/mod_g729 mod/codecs/mod_gsm mod/codecs/mod_h26x mod/codecs/mod_ilbc mod/codecs/mod_l16 mod/codecs/mod_lpc10 mod/codecs/mod_speex mod/endpoints/mod_sofia

Freeswitch SVN anthm at freeswitch.org
Thu Oct 18 23:21:38 EDT 2007


Author: anthm
Date: Thu Oct 18 23:21:37 2007
New Revision: 5987

Modified:
   freeswitch/trunk/src/include/switch_module_interfaces.h
   freeswitch/trunk/src/mod/applications/mod_conference/mod_conference.c
   freeswitch/trunk/src/mod/codecs/mod_amr/mod_amr.c
   freeswitch/trunk/src/mod/codecs/mod_g711/mod_g711.c
   freeswitch/trunk/src/mod/codecs/mod_g722/mod_g722.c
   freeswitch/trunk/src/mod/codecs/mod_g723_1/mod_g723_1.c
   freeswitch/trunk/src/mod/codecs/mod_g726/mod_g726.c
   freeswitch/trunk/src/mod/codecs/mod_g729/mod_g729.c
   freeswitch/trunk/src/mod/codecs/mod_gsm/mod_gsm.c
   freeswitch/trunk/src/mod/codecs/mod_h26x/mod_h26x.c
   freeswitch/trunk/src/mod/codecs/mod_ilbc/mod_ilbc.c
   freeswitch/trunk/src/mod/codecs/mod_l16/mod_l16.c
   freeswitch/trunk/src/mod/codecs/mod_lpc10/mod_lpc10.c
   freeswitch/trunk/src/mod/codecs/mod_speex/mod_speex.c
   freeswitch/trunk/src/mod/endpoints/mod_sofia/sofia_glue.c
   freeswitch/trunk/src/switch_core_io.c
   freeswitch/trunk/src/switch_rtp.c

Log:
more g722 fun

Modified: freeswitch/trunk/src/include/switch_module_interfaces.h
==============================================================================
--- freeswitch/trunk/src/include/switch_module_interfaces.h	(original)
+++ freeswitch/trunk/src/include/switch_module_interfaces.h	Thu Oct 18 23:21:37 2007
@@ -502,6 +502,8 @@
 	char *fmtp;
 	/*! samples transferred per second */
 	uint32_t samples_per_second;
+	/*! actual samples transferred per second for those who are not moron g722 RFC writers*/
+	uint32_t actual_samples_per_second;
 	/*! bits transferred per second */
 	int bits_per_second;
 	/*! number of microseconds that denote one frame */

Modified: freeswitch/trunk/src/mod/applications/mod_conference/mod_conference.c
==============================================================================
--- freeswitch/trunk/src/mod/applications/mod_conference/mod_conference.c	(original)
+++ freeswitch/trunk/src/mod/applications/mod_conference/mod_conference.c	Thu Oct 18 23:21:37 2007
@@ -4218,13 +4218,13 @@
 		goto done;
 	}
 
-	if (read_codec->implementation->samples_per_second != conference->rate) {
+	if (read_codec->implementation->actual_samples_per_second != conference->rate) {
 		switch_audio_resampler_t **resampler = read_codec->implementation->samples_per_second > conference->rate ?
 			&member.read_resampler : &member.mux_resampler;
 
 		if (switch_resample_create(resampler,
-								   read_codec->implementation->samples_per_second,
-								   read_codec->implementation->samples_per_second * 20,
+								   read_codec->implementation->actual_samples_per_second,
+								   read_codec->implementation->actual_samples_per_second * 20,
 								   conference->rate,
 								   conference->rate * 20,
 								   member.pool) != SWITCH_STATUS_SUCCESS) {

Modified: freeswitch/trunk/src/mod/codecs/mod_amr/mod_amr.c
==============================================================================
--- freeswitch/trunk/src/mod/codecs/mod_amr/mod_amr.c	(original)
+++ freeswitch/trunk/src/mod/codecs/mod_amr/mod_amr.c	Thu Oct 18 23:21:37 2007
@@ -296,6 +296,7 @@
 	/*.iananame */ "AMR",
 	/*.fmtp */ "octet-align=0",
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 0,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,

Modified: freeswitch/trunk/src/mod/codecs/mod_g711/mod_g711.c
==============================================================================
--- freeswitch/trunk/src/mod/codecs/mod_g711/mod_g711.c	(original)
+++ freeswitch/trunk/src/mod/codecs/mod_g711/mod_g711.c	Thu Oct 18 23:21:37 2007
@@ -188,6 +188,7 @@
 	/*.iananame */ "PCMU",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 64000,
 	/*.microseconds_per_frame */ 120000,
 	/*.samples_per_frame */ 960,
@@ -208,6 +209,7 @@
 	/*.iananame */ "PCMU",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 19200,
 	/*.microseconds_per_frame */ 60000,
 	/*.samples_per_frame */ 480,
@@ -229,6 +231,7 @@
 	/*.iananame */ "PCMU",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 96000,
 	/*.microseconds_per_frame */ 30000,
 	/*.samples_per_frame */ 240,
@@ -250,6 +253,7 @@
 	/*.iananame */ "PCMU",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 64000,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,
@@ -271,6 +275,7 @@
 	/*.iananame */ "PCMU",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 64000,
 	/*.microseconds_per_frame */ 10000,
 	/*.samples_per_frame */ 80,
@@ -294,6 +299,7 @@
 	/*.iananame */ "PCMA",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 64000,
 	/*.microseconds_per_frame */ 120000,
 	/*.samples_per_frame */ 960,
@@ -314,6 +320,7 @@
 	/*.iananame */ "PCMA",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 19200,
 	/*.microseconds_per_frame */ 60000,
 	/*.samples_per_frame */ 480,
@@ -335,6 +342,7 @@
 	/*.iananame */ "PCMA",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 96000,
 	/*.microseconds_per_frame */ 30000,
 	/*.samples_per_frame */ 240,
@@ -356,6 +364,7 @@
 	/*.iananame */ "PCMA",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 64000,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,
@@ -377,6 +386,7 @@
 	/*.iananame */ "PCMA",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 64000,
 	/*.microseconds_per_frame */ 10000,
 	/*.samples_per_frame */ 80,

Modified: freeswitch/trunk/src/mod/codecs/mod_g722/mod_g722.c
==============================================================================
--- freeswitch/trunk/src/mod/codecs/mod_g722/mod_g722.c	(original)
+++ freeswitch/trunk/src/mod/codecs/mod_g722/mod_g722.c	Thu Oct 18 23:21:37 2007
@@ -54,14 +54,14 @@
 		return SWITCH_STATUS_FALSE;
 	} else {
 		if (encoding) {
-			if (codec->implementation->samples_per_second == 16000) {
+			if (codec->implementation->actual_samples_per_second == 16000) {
 				g722_encode_init(&context->encoder_object, 64000, G722_PACKED);
 			} else {
 				g722_encode_init(&context->encoder_object, 64000, G722_SAMPLE_RATE_8000);
 			}
 		}
 		if (decoding) {
-			if (codec->implementation->samples_per_second == 16000) {
+			if (codec->implementation->actual_samples_per_second == 16000) {
 				g722_decode_init(&context->decoder_object, 64000, G722_PACKED);
 			} else {
 				g722_decode_init(&context->decoder_object, 64000, G722_SAMPLE_RATE_8000);
@@ -124,6 +124,7 @@
 	/*.iananame */ "G722_8",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 64000,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,
@@ -143,7 +144,8 @@
 	/*.ianacode */ 9,
 	/*.iananame */ "G722",
 	/*.fmtp */ NULL,
-	/*.samples_per_second */ 16000,
+	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 16000,
 	/*.bits_per_second */ 64000,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,
@@ -156,7 +158,7 @@
 	/*.encode */ switch_g722_encode,
 	/*.decode */ switch_g722_decode,
 	/*.destroy */ switch_g722_destroy,
-	/*.next */ &g722_8k_implementation
+	/*.next */ 
 };
 
 SWITCH_MODULE_LOAD_FUNCTION(mod_g722_load)
@@ -164,7 +166,8 @@
 	switch_codec_interface_t *codec_interface;
 	/* connect my internal structure to the blank pointer passed to me */
 	*module_interface = switch_loadable_module_create_module_interface(pool, modname);
-	SWITCH_ADD_CODEC(codec_interface, "g722", &g722_16k_implementation);
+	SWITCH_ADD_CODEC(codec_interface, "G722", &g722_16k_implementation);
+	SWITCH_ADD_CODEC(codec_interface, "G722_8", &g722_8k_implementation);
 
 	/* indicate that the module should continue to be loaded */
 	return SWITCH_STATUS_SUCCESS;

Modified: freeswitch/trunk/src/mod/codecs/mod_g723_1/mod_g723_1.c
==============================================================================
--- freeswitch/trunk/src/mod/codecs/mod_g723_1/mod_g723_1.c	(original)
+++ freeswitch/trunk/src/mod/codecs/mod_g723_1/mod_g723_1.c	Thu Oct 18 23:21:37 2007
@@ -175,6 +175,7 @@
 	/*.iananame */ "G723",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 6300,
 	/*.microseconds_per_frame */ 30000,
 	/*.samples_per_frame */ 240,

Modified: freeswitch/trunk/src/mod/codecs/mod_g726/mod_g726.c
==============================================================================
--- freeswitch/trunk/src/mod/codecs/mod_g726/mod_g726.c	(original)
+++ freeswitch/trunk/src/mod/codecs/mod_g726/mod_g726.c	Thu Oct 18 23:21:37 2007
@@ -94,7 +94,7 @@
 
 		g726_init_state(&handle->context);
 		codec->private_info = handle;
-		handle->bits_per_frame = (switch_byte_t) (codec->implementation->bits_per_second / (codec->implementation->samples_per_second));
+		handle->bits_per_frame = (switch_byte_t) (codec->implementation->bits_per_second / (codec->implementation->actual_samples_per_second));
 		handle->mode = (flags & SWITCH_CODEC_FLAG_AAL2 || strstr(codec->implementation->iananame, "AAL2"))
 			? SWITCH_BITPACK_MODE_AAL2 : SWITCH_BITPACK_MODE_RFC3551;
 		return SWITCH_STATUS_SUCCESS;
@@ -210,6 +210,7 @@
 	/*.iananame */ "G726-16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 16000,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,
@@ -231,6 +232,7 @@
 	/*.iananame */ "G726-24",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 24000,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,
@@ -251,6 +253,7 @@
 	/*.iananame */ "G726-32",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 32000,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,
@@ -271,6 +274,7 @@
 	/*.iananame */ "G726-40",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 40000,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,
@@ -293,6 +297,7 @@
 	/*.iananame */ "AAL2-G726-16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 16000,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,
@@ -314,6 +319,7 @@
 	/*.iananame */ "AAL2-G726-24",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 24000,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,
@@ -334,6 +340,7 @@
 	/*.iananame */ "AAL2-G726-32",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 32000,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,
@@ -354,6 +361,7 @@
 	/*.iananame */ "AAL2-G726-40",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 40000,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,

Modified: freeswitch/trunk/src/mod/codecs/mod_g729/mod_g729.c
==============================================================================
--- freeswitch/trunk/src/mod/codecs/mod_g729/mod_g729.c	(original)
+++ freeswitch/trunk/src/mod/codecs/mod_g729/mod_g729.c	Thu Oct 18 23:21:37 2007
@@ -218,6 +218,7 @@
 	/*.iananame */ "G729",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 128000,
 	/*.microseconds_per_frame */ 40000,
 	/*.samples_per_frame */ 320,
@@ -238,6 +239,7 @@
 	/*.iananame */ "G729",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 96000,
 	/*.microseconds_per_frame */ 30000,
 	/*.samples_per_frame */ 240,
@@ -259,6 +261,7 @@
 	/*.iananame */ "G729",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 32000,
 	/*.microseconds_per_frame */ 10000,
 	/*.samples_per_frame */ 80,
@@ -280,6 +283,7 @@
 	/*.iananame */ "G729",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 64000,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,

Modified: freeswitch/trunk/src/mod/codecs/mod_gsm/mod_gsm.c
==============================================================================
--- freeswitch/trunk/src/mod/codecs/mod_gsm/mod_gsm.c	(original)
+++ freeswitch/trunk/src/mod/codecs/mod_gsm/mod_gsm.c	Thu Oct 18 23:21:37 2007
@@ -140,6 +140,7 @@
 	/*.iananame */ "GSM",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 13200,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,

Modified: freeswitch/trunk/src/mod/codecs/mod_h26x/mod_h26x.c
==============================================================================
--- freeswitch/trunk/src/mod/codecs/mod_h26x/mod_h26x.c	(original)
+++ freeswitch/trunk/src/mod/codecs/mod_h26x/mod_h26x.c	Thu Oct 18 23:21:37 2007
@@ -81,6 +81,7 @@
 	/*.iananame */ "H264",
 	/*.fmtp */ NULL,
 	/*.samples_per_second = */ 90000,
+	/*.actual_samples_per_second = */ 90000,
 	/*.bits_per_second = */ 0,
 	/*.microseconds_per_frame = */ 0,
 	/*.samples_per_frame = */ 0,
@@ -102,6 +103,7 @@
 	/*.iananame */ "H263",
 	/*.fmtp */ NULL,
 	/*.samples_per_second = */ 90000,
+	/*.actual_samples_per_second = */ 90000,
 	/*.bits_per_second = */ 0,
 	/*.microseconds_per_frame = */ 0,
 	/*.samples_per_frame = */ 0,
@@ -123,6 +125,7 @@
 	/*.iananame */ "H261",
 	/*.fmtp */ NULL,
 	/*.samples_per_second = */ 90000,
+	/*.actual_samples_per_second = */ 90000,
 	/*.bits_per_second = */ 0,
 	/*.microseconds_per_frame = */ 0,
 	/*.samples_per_frame = */ 0,

Modified: freeswitch/trunk/src/mod/codecs/mod_ilbc/mod_ilbc.c
==============================================================================
--- freeswitch/trunk/src/mod/codecs/mod_ilbc/mod_ilbc.c	(original)
+++ freeswitch/trunk/src/mod/codecs/mod_ilbc/mod_ilbc.c	Thu Oct 18 23:21:37 2007
@@ -188,6 +188,7 @@
 	/*.iananame */ "iLBC",
 	/*.fmtp */ "mode=30",
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ NO_OF_BYTES_30MS * 8 * 8000 / BLOCKL_30MS,
 	/*.microseconds_per_frame */ 30000,
 	/*.samples_per_frame */ 240,
@@ -208,6 +209,7 @@
 	/*.iananame */ "iLBC",
 	/*.fmtp */ "mode=20",
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ NO_OF_BYTES_20MS * 8 * 8000 / BLOCKL_20MS,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,
@@ -231,6 +233,7 @@
 	/*.iananame */ "iLBC",
 	/*.fmtp */ "mode=30",
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ NO_OF_BYTES_30MS * 8 * 8000 / BLOCKL_30MS,
 	/*.microseconds_per_frame */ 30000,
 	/*.samples_per_frame */ 240,
@@ -251,6 +254,7 @@
 	/*.iananame */ "iLBC102",
 	/*.fmtp */ "mode=20",
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ NO_OF_BYTES_20MS * 8 * 8000 / BLOCKL_20MS,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,
@@ -273,6 +277,7 @@
 	/*.iananame */ "iLBC20ms",
 	/*.fmtp */ "mode=20",
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ NO_OF_BYTES_20MS * 8 * 8000 / BLOCKL_20MS,
 	/*.microseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,

Modified: freeswitch/trunk/src/mod/codecs/mod_l16/mod_l16.c
==============================================================================
--- freeswitch/trunk/src/mod/codecs/mod_l16/mod_l16.c	(original)
+++ freeswitch/trunk/src/mod/codecs/mod_l16/mod_l16.c	Thu Oct 18 23:21:37 2007
@@ -57,7 +57,7 @@
 {
 
 	/* NOOP indicates that the audio in is already the same as the audio out, so no conversion was necessary. */
-	if (codec && other_codec && codec->implementation && other_codec->implementation && codec->implementation->samples_per_second != other_codec->implementation->samples_per_second) {
+	if (codec && other_codec && codec->implementation && other_codec->implementation && codec->implementation->actual_samples_per_second != other_codec->implementation->actual_samples_per_second) {
 		memcpy(encoded_data, decoded_data, decoded_data_len);
 		*encoded_data_len = decoded_data_len;
 		return SWITCH_STATUS_RESAMPLE;
@@ -72,7 +72,7 @@
 										 uint32_t encoded_rate, void *decoded_data, uint32_t * decoded_data_len, uint32_t * decoded_rate,
 										 unsigned int *flag)
 {
-	if (codec && other_codec && codec->implementation && other_codec->implementation && codec->implementation->samples_per_second != other_codec->implementation->samples_per_second) {
+	if (codec && other_codec && codec->implementation && other_codec->implementation && codec->implementation->actual_samples_per_second != other_codec->implementation->actual_samples_per_second) {
 		memcpy(decoded_data, encoded_data, encoded_data_len);
 		*decoded_data_len = encoded_data_len;
 		return SWITCH_STATUS_RESAMPLE;
@@ -93,6 +93,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second = */ 32000,
+	/*.actual_samples_per_second = */ 32000,
 	/*.bits_per_second = */ 512000,
 	/*.microseconds_per_frame = */ 60000,
 	/*.samples_per_frame = */ 1920,
@@ -114,6 +115,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second = */ 32000,
+	/*.actual_samples_per_second = */ 32000,
 	/*.bits_per_second = */ 512000,
 	/*.microseconds_per_frame = */ 30000,
 	/*.samples_per_frame = */ 960,
@@ -135,6 +137,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second = */ 32000,
+	/*.actual_samples_per_second = */ 32000,
 	/*.bits_per_second = */ 512000,
 	/*.microseconds_per_frame = */ 20000,
 	/*.samples_per_frame = */ 640,
@@ -156,6 +159,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second = */ 32000,
+	/*.actual_samples_per_second = */ 32000,
 	/*.bits_per_second = */ 512000,
 	/*.microseconds_per_frame = */ 10000,
 	/*.samples_per_frame = */ 320,
@@ -177,6 +181,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second = */ 22050,
+	/*.actual_samples_per_second = */ 22050,
 	/*.bits_per_second = */ 352800,
 	/*.microseconds_per_frame = */ 20000,
 	/*.samples_per_frame = */ 441,
@@ -198,6 +203,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 16000,
+	/*.actual_samples_per_second */ 16000,
 	/*.bits_per_second */ 256000,
 	/*.microseconds_per_frame */ 120000,
 	/*.samples_per_frame */ 1920,
@@ -219,6 +225,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 16000,
+	/*.actual_samples_per_second */ 16000,
 	/*.bits_per_second */ 256000,
 	/*.microseconds_per_frame */ 60000,
 	/*.samples_per_frame */ 960,
@@ -240,6 +247,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 16000,
+	/*.actual_samples_per_second */ 16000,
 	/*.bits_per_second */ 256000,
 	/*.microseconds_per_frame */ 30000,
 	/*.samples_per_frame */ 480,
@@ -261,6 +269,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second = */ 16000,
+	/*.actual_samples_per_second = */ 16000,
 	/*.bits_per_second = */ 256000,
 	/*.microseconds_per_frame = */ 20000,
 	/*.samples_per_frame = */ 320,
@@ -282,6 +291,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second = */ 16000,
+	/*.actual_samples_per_second = */ 16000,
 	/*.bits_per_second = */ 256000,
 	/*.microseconds_per_frame = */ 10000,
 	/*.samples_per_frame = */ 160,
@@ -306,6 +316,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 512000,
 	/*.microseconds_per_frame */ 120000,
 	/*.samples_per_frame */ 960,
@@ -328,6 +339,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 256000,
 	/*.microseconds_per_frame */ 60000,
 	/*.samples_per_frame */ 480,
@@ -349,6 +361,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 128000,
 	/*.microseconds_per_frame */ 30000,
 	/*.samples_per_frame */ 240,
@@ -369,6 +382,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second = */ 8000,
+	/*.actual_samples_per_second = */ 8000,
 	/*.bits_per_second = */ 128000,
 	/*.microseconds_per_frame = */ 20000,
 	/*.samples_per_frame = */ 160,
@@ -392,6 +406,7 @@
 	/*.iananame */ "L16",
 	/*.fmtp */ NULL,
 	/*.samples_per_second = */ 8000,
+	/*.actual_samples_per_second = */ 8000,
 	/*.bits_per_second = */ 128000,
 	/*.microseconds_per_frame = */ 10000,
 	/*.samples_per_frame = */ 80,

Modified: freeswitch/trunk/src/mod/codecs/mod_lpc10/mod_lpc10.c
==============================================================================
--- freeswitch/trunk/src/mod/codecs/mod_lpc10/mod_lpc10.c	(original)
+++ freeswitch/trunk/src/mod/codecs/mod_lpc10/mod_lpc10.c	Thu Oct 18 23:21:37 2007
@@ -162,6 +162,7 @@
 	/*.iananame */ "LPC",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 240,
 	/*.microseconds_per_frame */ 22500,
 	/*.samples_per_frame */ 180,

Modified: freeswitch/trunk/src/mod/codecs/mod_speex/mod_speex.c
==============================================================================
--- freeswitch/trunk/src/mod/codecs/mod_speex/mod_speex.c	(original)
+++ freeswitch/trunk/src/mod/codecs/mod_speex/mod_speex.c	Thu Oct 18 23:21:37 2007
@@ -268,6 +268,7 @@
 	/*.iananame */ "speex",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 32000,
+	/*.actual_samples_per_second */ 32000,
 	/*.bits_per_second */ 256000,
 	/*.nanoseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 640,
@@ -288,6 +289,7 @@
 	/*.iananame */ "speex",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 16000,
+	/*.actual_samples_per_second */ 16000,
 	/*.bits_per_second */ 22000,
 	/*.nanoseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 320,
@@ -310,6 +312,7 @@
 	/*.iananame */ "speex",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 3300,
 	/*.nanoseconds_per_frame */ 60000,
 	/*.samples_per_frame */ 480,
@@ -331,6 +334,7 @@
 	/*.iananame */ "speex",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 22000,
 	/*.nanoseconds_per_frame */ 40000,
 	/*.samples_per_frame */ 240,
@@ -354,6 +358,7 @@
 	/*.iananame */ "speex",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 1650,
 	/*.nanoseconds_per_frame */ 30000,
 	/*.samples_per_frame */ 240,
@@ -375,6 +380,7 @@
 	/*.iananame */ "speex",
 	/*.fmtp */ NULL,
 	/*.samples_per_second */ 8000,
+	/*.actual_samples_per_second */ 8000,
 	/*.bits_per_second */ 11000,
 	/*.nanoseconds_per_frame */ 20000,
 	/*.samples_per_frame */ 160,

Modified: freeswitch/trunk/src/mod/endpoints/mod_sofia/sofia_glue.c
==============================================================================
--- freeswitch/trunk/src/mod/endpoints/mod_sofia/sofia_glue.c	(original)
+++ freeswitch/trunk/src/mod/endpoints/mod_sofia/sofia_glue.c	Thu Oct 18 23:21:37 2007
@@ -122,9 +122,6 @@
 
 	if (tech_pvt->rm_encoding) {
 		rate = tech_pvt->rm_rate;
-		if (tech_pvt->pt == 9) {
-			rate = 8000;
-		}
 		snprintf(buf + strlen(buf), sizeof(buf) - strlen(buf), "a=rtpmap:%d %s/%d\n", tech_pvt->pt, tech_pvt->rm_encoding, rate);
 		if (tech_pvt->fmtp_out) {
 			snprintf(buf + strlen(buf), sizeof(buf) - strlen(buf), "a=fmtp:%d %s\n", tech_pvt->pt, tech_pvt->fmtp_out);
@@ -156,9 +153,6 @@
 			if (ptime && ptime != imp->microseconds_per_frame / 1000) {
 				switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_WARNING, "ptime %u != advertised ptime %u\n", imp->microseconds_per_frame / 1000, ptime);
 			}
-			if (imp->ianacode == 9) {
-				rate = 8000;
-			}
 			snprintf(buf + strlen(buf), sizeof(buf) - strlen(buf), "a=rtpmap:%d %s/%d\n", imp->ianacode, imp->iananame, rate);
 			if (imp->fmtp) {
 				snprintf(buf + strlen(buf), sizeof(buf) - strlen(buf), "a=fmtp:%d %s\n", imp->ianacode, imp->fmtp);
@@ -1251,10 +1245,6 @@
 						continue;
 					}
 
-					if (imp->ianacode == 9) {
-						codec_rate = 8000;
-					}
-
 					switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Audio Codec Compare [%s:%d:%u]/[%s:%d:%u]\n",
 									  rm_encoding, map->rm_pt, (int)map->rm_rate, imp->iananame, imp->ianacode, codec_rate);
 					if (map->rm_pt < 96) {
@@ -1307,11 +1297,7 @@
 					if ((tech_pvt->rm_encoding = switch_core_session_strdup(session, (char *) rm_encoding))) {
 						char tmp[50];
 						tech_pvt->pt = (switch_payload_t) map->rm_pt;
-						if (map->rm_pt == 9) {
-							tech_pvt->rm_rate = 16000; /* *stab* *stab* *stab* */
-						} else {
-							tech_pvt->rm_rate = map->rm_rate;
-						}
+						tech_pvt->rm_rate = map->rm_rate;
 						tech_pvt->codec_ms = mimp->microseconds_per_frame / 1000;
 						tech_pvt->remote_sdp_audio_ip = switch_core_session_strdup(session, (char *) connection->c_address);
 						tech_pvt->rm_fmtp = switch_core_session_strdup(session, (char *) map->rm_fmtp);

Modified: freeswitch/trunk/src/switch_core_io.c
==============================================================================
--- freeswitch/trunk/src/switch_core_io.c	(original)
+++ freeswitch/trunk/src/switch_core_io.c	Thu Oct 18 23:21:37 2007
@@ -178,9 +178,9 @@
 			case SWITCH_STATUS_RESAMPLE:
 				if (!session->read_resampler) {
 					if (switch_resample_create(&session->read_resampler,
-											   read_frame->codec->implementation->samples_per_second,
+											   read_frame->codec->implementation->actual_samples_per_second,
 											   read_frame->codec->implementation->bytes_per_frame * 20,
-											   session->read_codec->implementation->samples_per_second,
+											   session->read_codec->implementation->actual_samples_per_second,
 											   session->read_codec->implementation->bytes_per_frame * 20, session->pool) != SWITCH_STATUS_SUCCESS) {
 						switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Unable to allocate resampler\n");
 						status = SWITCH_STATUS_FALSE;
@@ -458,9 +458,9 @@
 				write_frame = &session->raw_write_frame;
 				if (!session->write_resampler) {
 					status = switch_resample_create(&session->write_resampler,
-													frame->codec->implementation->samples_per_second,
+													frame->codec->implementation->actual_samples_per_second,
 													frame->codec->implementation->bytes_per_frame * 20,
-													session->write_codec->implementation->samples_per_second,
+													session->write_codec->implementation->actual_samples_per_second,
 													session->write_codec->implementation->bytes_per_frame * 20, session->pool);
 					if (status != SWITCH_STATUS_SUCCESS) {
 						goto done;
@@ -680,10 +680,9 @@
 								write_frame = &session->enc_write_frame;
 								if (!session->read_resampler) {
 									status = switch_resample_create(&session->read_resampler,
-																	frame->codec->implementation->samples_per_second,
+																	frame->codec->implementation->actual_samples_per_second,
 																	frame->codec->implementation->bytes_per_frame * 20,
-																	session->write_codec->implementation->
-																	samples_per_second,
+																	session->write_codec->implementation->actual_samples_per_second,
 																	session->write_codec->implementation->bytes_per_frame * 20, session->pool);
 									if (status != SWITCH_STATUS_SUCCESS) {
 										goto done;

Modified: freeswitch/trunk/src/switch_rtp.c
==============================================================================
--- freeswitch/trunk/src/switch_rtp.c	(original)
+++ freeswitch/trunk/src/switch_rtp.c	Thu Oct 18 23:21:37 2007
@@ -846,13 +846,7 @@
 		if (!switch_test_flag(rtp_session, SWITCH_RTP_FLAG_IO)) {
 			return -1;
 		}
-#if 1
-		if (rtp_session->recv_msg.header.pt == 9 /* && G722 RFC != LAME */) {
-			uint32_t rfc_sucks = ntohl(rtp_session->recv_msg.header.ts);
-			rfc_sucks *= 2;
-			rtp_session->recv_msg.header.ts = htonl(rfc_sucks);
-		}
-#endif
+
 		if (rtp_session->jb && bytes && rtp_session->recv_msg.header.pt == rtp_session->payload) {
 			if (rtp_session->recv_msg.header.m) {
 				stfu_n_reset(rtp_session->jb);
@@ -1623,11 +1617,6 @@
 	}
 
 	send_msg = rtp_session->send_msg;
-#if 1
-	if (payload == 9 /* && G722 RFC != LAME */) {
-		ts /= 2;
-	}
-#endif
 	send_msg.header.seq = htons(mseq);
 	send_msg.header.ts = htonl(ts);
 	send_msg.header.ssrc = htonl(ssrc);



More information about the Freeswitch-svn mailing list