diff --git a/daemon/call.c b/daemon/call.c index ebec67090..2e74b1b99 100644 --- a/daemon/call.c +++ b/daemon/call.c @@ -1016,6 +1016,8 @@ static struct endpoint_map *__get_endpoint_map(struct call_media *media, unsigne port_latching = true; else if (MEDIA_ISSET(media, ICE) && (!flags || !flags->no_port_latching)) port_latching = true; + else if (!MEDIA_ISSET(media, RECV) && (!flags || !flags->no_port_latching)) + port_latching = true; struct endpoint_map *em = NULL; if (port_latching) diff --git a/t/auto-daemon-tests.pl b/t/auto-daemon-tests.pl index 150b10864..500433fa2 100755 --- a/t/auto-daemon-tests.pl +++ b/t/auto-daemon-tests.pl @@ -19253,5 +19253,225 @@ SDP +new_call; + +($port_a) = offer('re-invite sendonly port change (control)', { }, <