From: Ondřej Surý Date: Wed, 5 Apr 2023 13:28:32 +0000 (+0200) Subject: Honour the source-port when retrying in dns_dispatch X-Git-Tag: v9.19.13~24^2~1 X-Git-Url: http://git.ipfire.org/gitweb/index.cgi?a=commitdiff_plain;h=c8e8ccd0262283bede1340451be71a353dafd693;p=thirdparty%2Fbind9.git Honour the source-port when retrying in dns_dispatch When retrying in the DNS dispatch, the local port would be forgotten on ISC_R_ADDRINUSE, keep the configured source-port even when retrying. Additionally, treat ISC_R_NOPERM same as ISC_R_ADDRINUSE. Closes: #3986 --- diff --git a/lib/dns/dispatch.c b/lib/dns/dispatch.c index 9e98e10afa5..c3006b6501c 100644 --- a/lib/dns/dispatch.c +++ b/lib/dns/dispatch.c @@ -1440,7 +1440,7 @@ dns_dispatch_add(dns_dispatch_t *disp, unsigned int options, dns_dispentry_t **respp) { dns_dispentry_t *resp = NULL; dns_qid_t *qid = NULL; - in_port_t dispport, localport = 0; + in_port_t localport; dns_messageid_t id; unsigned int bucket; bool ok = false; @@ -1465,10 +1465,7 @@ dns_dispatch_add(dns_dispatch_t *disp, unsigned int options, qid = disp->mgr->qid; - dispport = isc_sockaddr_getport(&disp->local); - if (dispport != 0) { - localport = dispport; - } + localport = isc_sockaddr_getport(&disp->local); resp = isc_mem_get(disp->mgr->mctx, sizeof(*resp)); *resp = (dns_dispentry_t){ @@ -1943,8 +1940,9 @@ udp_connected(isc_nmhandle_t *handle, isc_result_t eresult, void *arg) { resp->state = DNS_DISPATCHSTATE_CONNECTED; udp_startrecv(handle, resp); break; + case ISC_R_NOPERM: case ISC_R_ADDRINUSE: { - in_port_t localport = 0; + in_port_t localport = isc_sockaddr_getport(&disp->local); isc_result_t result; /* probably a port collision; try a different one */