FS-3545 --resolve no, that was not the intention, I missed a few more spots to hack in the exception for iLBC, (thanks for marring my code iLBC ppl) it should work as expected now even with the m_per_ptime on

This commit is contained in:
Anthony Minessale 2011-09-08 09:48:21 -05:00
parent aea22cd4b7
commit 83a78fbfa0
1 changed files with 19 additions and 9 deletions

View File

@ -201,6 +201,11 @@ static void generate_m(private_object_t *tech_pvt, char *buf, size_t buflen,
for (i = 0; i < tech_pvt->num_codecs; i++) { for (i = 0; i < tech_pvt->num_codecs; i++) {
const switch_codec_implementation_t *imp = tech_pvt->codecs[i]; const switch_codec_implementation_t *imp = tech_pvt->codecs[i];
int this_ptime = (imp->microseconds_per_packet / 1000);
if (!strcasecmp(imp->iananame, "ilbc")) {
this_ptime = 20;
}
if (imp->codec_type != SWITCH_CODEC_TYPE_AUDIO) { if (imp->codec_type != SWITCH_CODEC_TYPE_AUDIO) {
continue; continue;
@ -210,12 +215,12 @@ static void generate_m(private_object_t *tech_pvt, char *buf, size_t buflen,
if (!cur_ptime) { if (!cur_ptime) {
#if 0 #if 0
if (ptime) { if (ptime) {
if (ptime != imp->microseconds_per_packet / 1000) { if (ptime != this_ptime) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_WARNING, switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_WARNING,
"Codec %s payload %d added to sdp wanting ptime %d but it's already %d (%s:%d:%d), disabling ptime.\n", "Codec %s payload %d added to sdp wanting ptime %d but it's already %d (%s:%d:%d), disabling ptime.\n",
imp->iananame, imp->iananame,
tech_pvt->ianacodes[i], tech_pvt->ianacodes[i],
imp->microseconds_per_packet / 1000, this_ptime,
ptime, ptime,
tech_pvt->codecs[0]->iananame, tech_pvt->codecs[0]->iananame,
tech_pvt->codecs[0]->ianacode, tech_pvt->codecs[0]->ianacode,
@ -224,15 +229,15 @@ static void generate_m(private_object_t *tech_pvt, char *buf, size_t buflen,
noptime = 1; noptime = 1;
} }
} else { } else {
ptime = imp->microseconds_per_packet / 1000; ptime = this_ptime;
} }
#else #else
if (!ptime) { if (!ptime) {
ptime = imp->microseconds_per_packet / 1000; ptime = this_ptime;
} }
#endif #endif
} else { } else {
if ((imp->microseconds_per_packet / 1000) != cur_ptime) { if (this_ptime != cur_ptime) {
continue; continue;
} }
} }
@ -266,18 +271,23 @@ static void generate_m(private_object_t *tech_pvt, char *buf, size_t buflen,
for (i = 0; i < tech_pvt->num_codecs; i++) { for (i = 0; i < tech_pvt->num_codecs; i++) {
const switch_codec_implementation_t *imp = tech_pvt->codecs[i]; const switch_codec_implementation_t *imp = tech_pvt->codecs[i];
char *fmtp = imp->fmtp; char *fmtp = imp->fmtp;
int this_ptime = imp->microseconds_per_packet / 1000;
if (imp->codec_type != SWITCH_CODEC_TYPE_AUDIO) { if (imp->codec_type != SWITCH_CODEC_TYPE_AUDIO) {
continue; continue;
} }
if (!strcasecmp(imp->iananame, "ilbc")) {
this_ptime = 20;
}
if (!noptime) { if (!noptime) {
if (!cur_ptime) { if (!cur_ptime) {
if (!ptime) { if (!ptime) {
ptime = imp->microseconds_per_packet / 1000; ptime = this_ptime;
} }
} else { } else {
if ((imp->microseconds_per_packet / 1000) != cur_ptime) { if (this_ptime != cur_ptime) {
continue; continue;
} }
} }