Module: kamailio
Branch: 5.4
Commit: dccc47c4fbb306150d88be40bf2463d4926c75bd
URL:
https://github.com/kamailio/kamailio/commit/dccc47c4fbb306150d88be40bf2463d…
Author: Nacho Garcia Segovia <nacho.gs(a)zaleos.net>
Committer: Daniel-Constantin Mierla <miconda(a)gmail.com>
Date: 2021-12-06T14:30:38+01:00
msrp: fix some tcpconn where memory was never cleaned up
Thanks to Jason Shugart at INdigital. Fix consist of caring of removing references to
previously retrieved tcp connections. GH #2880
(cherry picked from commit bf371ccbfa1c89fefcd9d9322ae75189d97fc862)
(cherry picked from commit f4ebe527c25ecedb3caffa8a361b5c42a2dd6b88)
---
Modified: src/modules/msrp/msrp_netio.c
---
Diff:
https://github.com/kamailio/kamailio/commit/dccc47c4fbb306150d88be40bf2463d…
Patch:
https://github.com/kamailio/kamailio/commit/dccc47c4fbb306150d88be40bf2463d…
---
diff --git a/src/modules/msrp/msrp_netio.c b/src/modules/msrp/msrp_netio.c
index 92f7cf525b8..859432aa6d2 100644
--- a/src/modules/msrp/msrp_netio.c
+++ b/src/modules/msrp/msrp_netio.c
@@ -74,6 +74,7 @@ int msrp_relay(msrp_frame_t *mf)
char *l;
int port;
sr_event_param_t evp = {0};
+ int ret;
if(mf->buf.len>=MSRP_MAX_FRAME_SIZE-1)
return -1;
@@ -169,12 +170,17 @@ int msrp_relay(msrp_frame_t *mf)
wsev.len = p - reqbuf;
wsev.id = con->id;
evp.data = (void *)&wsev;
- return sr_event_exec(SREV_TCP_WS_FRAME_OUT, &evp);
+ ret = sr_event_exec(SREV_TCP_WS_FRAME_OUT, &evp);
+ tcpconn_put(con);
+ return ret;
}
else if (tcp_send(dst, 0, reqbuf, p - reqbuf) < 0) {
LM_ERR("forwarding frame failed\n");
+ tcpconn_put(con);
return -1;
}
+
+ tcpconn_put(con);
}
else if (tcp_send(dst, 0, reqbuf, p - reqbuf) < 0) {
LM_ERR("forwarding frame failed\n");
@@ -195,6 +201,7 @@ int msrp_reply(msrp_frame_t *mf, str *code, str *text, str *xhdrs)
char *p;
char *l;
sr_event_param_t evp = {0};
+ int ret;
/* no reply for a reply */
if(mf->fline.msgtypeid==MSRP_REPLY)
@@ -301,7 +308,9 @@ int msrp_reply(msrp_frame_t *mf, str *code, str *text, str *xhdrs)
wsev.len = p - rplbuf;
wsev.id = con->id;
evp.data = (void *)&wsev;
- return sr_event_exec(SREV_TCP_WS_FRAME_OUT, &evp);
+ ret = sr_event_exec(SREV_TCP_WS_FRAME_OUT, &evp);
+ tcpconn_put(con);
+ return ret;
}
else
if (tcp_send(&env->srcinfo, 0, rplbuf, p - rplbuf) < 0) {