Index: channels/chan_sip.c =================================================================== --- channels/chan_sip.c (revision 150550) +++ channels/chan_sip.c (working copy) @@ -21238,9 +21238,17 @@ if (srvlookup && peer->dnsmgr == NULL) { char transport[MAXHOSTNAMELEN]; + char _srvlookup[MAXHOSTNAMELEN]; + char *params; + + ast_copy_string(_srvlookup, srvlookup, sizeof(_srvlookup)); + if (params = strchr(_srvlookup, ';')) { + *params++ = '\0'; + } + snprintf(transport, sizeof(transport), "_sip._%s", get_transport(peer->socket.type)); - if (ast_dnsmgr_lookup(srvlookup, &peer->addr, &peer->dnsmgr, global_srvlookup ? transport : NULL)) { + if (ast_dnsmgr_lookup(_srvlookup, &peer->addr, &peer->dnsmgr, global_srvlookup ? transport : NULL)) { unref_peer(peer, "getting rid of a peer pointer"); return NULL; }