[Core] RFC 3264 says once we assign a payload number to a dynamic codec, we are stuck with it.
8.3.1 Modifying Address, Port or Transport The port number for a stream MAY be changed. To do this, the offerer creates a new media description, with the port number in the m line different from the corresponding stream in the previous SDP. If only the port number is to be changed, the rest of the media stream description SHOULD remain unchanged. The offerer MUST be prepared to receive media on both the old and new ports as soon as the offer is sent. The offerer SHOULD NOT cease listening for media on the old port until the answer is received and media arrives on the new port. Doing so could result in loss of media during the transition. Co-authored-by: Anthony Minessale <anthm@signalwire.com>
This commit is contained in:
parent
862a19e103
commit
6c87ed4915
|
@ -9907,6 +9907,7 @@ static void generate_m(switch_core_session_t *session, char *buf, size_t buflen,
|
||||||
for (i = 0; i < smh->mparams->num_codecs; i++) {
|
for (i = 0; i < smh->mparams->num_codecs; i++) {
|
||||||
const switch_codec_implementation_t *imp = smh->codecs[i];
|
const switch_codec_implementation_t *imp = smh->codecs[i];
|
||||||
int this_ptime = (imp->microseconds_per_packet / 1000);
|
int this_ptime = (imp->microseconds_per_packet / 1000);
|
||||||
|
payload_map_t *pmap;
|
||||||
|
|
||||||
if (!strcasecmp(imp->iananame, "ilbc") || !strcasecmp(imp->iananame, "isac") ) {
|
if (!strcasecmp(imp->iananame, "ilbc") || !strcasecmp(imp->iananame, "isac") ) {
|
||||||
this_ptime = 20;
|
this_ptime = 20;
|
||||||
|
@ -9932,7 +9933,18 @@ static void generate_m(switch_core_session_t *session, char *buf, size_t buflen,
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
switch_mutex_lock(smh->sdp_mutex);
|
||||||
|
for (pmap = a_engine->cur_payload_map; pmap && pmap->allocated; pmap = pmap->next) {
|
||||||
|
if (pmap->negotiated && !strcasecmp(imp->iananame, pmap->iananame)) {
|
||||||
|
smh->ianacodes[i] = pmap->pt;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
switch_mutex_unlock(smh->sdp_mutex);
|
||||||
|
|
||||||
already_did[smh->ianacodes[i]] = 1;
|
already_did[smh->ianacodes[i]] = 1;
|
||||||
|
|
||||||
switch_snprintf(buf + strlen(buf), buflen - strlen(buf), " %d", smh->ianacodes[i]);
|
switch_snprintf(buf + strlen(buf), buflen - strlen(buf), " %d", smh->ianacodes[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11114,13 +11126,21 @@ SWITCH_DECLARE(void) switch_core_media_gen_local_sdp(switch_core_session_t *sess
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (smh->ianacodes[i] < 128) {
|
if (smh->ianacodes[i] >= 128 || already_did[smh->ianacodes[i]]) {
|
||||||
if (already_did[smh->ianacodes[i]]) {
|
continue;
|
||||||
continue;
|
|
||||||
}
|
|
||||||
already_did[smh->ianacodes[i]] = 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
switch_mutex_lock(smh->sdp_mutex);
|
||||||
|
for (pmap = v_engine->cur_payload_map; pmap && pmap->allocated; pmap = pmap->next) {
|
||||||
|
if (pmap->negotiated && !strcasecmp(imp->iananame, pmap->iananame)) {
|
||||||
|
smh->ianacodes[i] = pmap->pt;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
switch_mutex_unlock(smh->sdp_mutex);
|
||||||
|
|
||||||
|
already_did[smh->ianacodes[i]] = 1;
|
||||||
|
|
||||||
switch_snprintf(buf + strlen(buf), SDPBUFLEN - strlen(buf), " %d", smh->ianacodes[i]);
|
switch_snprintf(buf + strlen(buf), SDPBUFLEN - strlen(buf), " %d", smh->ianacodes[i]);
|
||||||
|
|
||||||
if (!ptime) {
|
if (!ptime) {
|
||||||
|
|
Loading…
Reference in New Issue