diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2022-03-20 12:36:06 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2022-03-20 12:36:06 +0000 |
commit | 920edd39c12de0e69e54aa0bcde81e6e8d814c22 (patch) | |
tree | 5dfb07730b63c34818c5c4f119773e60b5cb7bf9 /contrib/librdns | |
parent | 89960ca4a4909451f83519cb5c16047246d2ae9e (diff) | |
download | rspamd-920edd39c12de0e69e54aa0bcde81e6e8d814c22.tar.gz rspamd-920edd39c12de0e69e54aa0bcde81e6e8d814c22.zip |
[Minor] Plug memory leak when rescheduling requests over TCP
Diffstat (limited to 'contrib/librdns')
-rw-r--r-- | contrib/librdns/resolver.c | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/contrib/librdns/resolver.c b/contrib/librdns/resolver.c index c12180ec1..cb9824ed4 100644 --- a/contrib/librdns/resolver.c +++ b/contrib/librdns/resolver.c @@ -554,11 +554,12 @@ rdns_process_udp_read (int fd, struct rdns_io_channel *ioc) if (!(rep->flags & RDNS_TRUNCATED)) { req->state = RDNS_REQUEST_REPLIED; req->func(rep, req->arg); + /* This will free reply as well */ REF_RELEASE (req); } else { - rdns_debug("truncated UDP reply for %s", req->requested_names[0].name); if (req->io->srv->tcp_io_cnt > 0) { + rdns_debug("truncated UDP reply for %s; schedule over TCP", req->requested_names[0].name); /* Reschedule via TCP */ if (!rdns_reschedule_req_over_tcp (req, req->io->srv)) { /* Use truncated reply as we have no other options */ @@ -566,6 +567,18 @@ rdns_process_udp_read (int fd, struct rdns_io_channel *ioc) req->func(rep, req->arg); REF_RELEASE (req); } + else { + /* Remove and free the truncated reply, as we have rescheduled the reply */ + req->reply = NULL; + rdns_reply_free(rep); + } + } + else { + /* No TCP channels available */ + req->state = RDNS_REQUEST_REPLIED; + req->func(rep, req->arg); + /* This will free reply as well */ + REF_RELEASE (req); } } } |