summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHannes Frederic Sowa <hannes@stressinduktion.org>2017-03-13 00:01:30 +0100
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2017-03-22 12:57:02 +0100
commitf70ce6c63e02d39a4009aa68d041a8dfe7f439f9 (patch)
treed86fabc71e58f2967ee41ac2bae1b5b9bc0d75a5
parenta79fa23c82a1b7ee3726ea348336fbe874130a7c (diff)
downloadlinux-stable-f70ce6c63e02d39a4009aa68d041a8dfe7f439f9.tar.gz
linux-stable-f70ce6c63e02d39a4009aa68d041a8dfe7f439f9.tar.bz2
linux-stable-f70ce6c63e02d39a4009aa68d041a8dfe7f439f9.zip
dccp: fix memory leak during tear-down of unsuccessful connection request
[ Upstream commit 72ef9c4125c7b257e3a714d62d778ab46583d6a3 ] This patch fixes a memory leak, which happens if the connection request is not fulfilled between parsing the DCCP options and handling the SYN (because e.g. the backlog is full), because we forgot to free the list of ack vectors. Reported-by: Jianwen Ji <jiji@redhat.com> Signed-off-by: Hannes Frederic Sowa <hannes@stressinduktion.org> Signed-off-by: David S. Miller <davem@davemloft.net> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r--net/dccp/ccids/ccid2.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/net/dccp/ccids/ccid2.c b/net/dccp/ccids/ccid2.c
index f053198e730c..5e3a7302f774 100644
--- a/net/dccp/ccids/ccid2.c
+++ b/net/dccp/ccids/ccid2.c
@@ -749,6 +749,7 @@ static void ccid2_hc_tx_exit(struct sock *sk)
for (i = 0; i < hc->tx_seqbufc; i++)
kfree(hc->tx_seqbuf[i]);
hc->tx_seqbufc = 0;
+ dccp_ackvec_parsed_cleanup(&hc->tx_av_chunks);
}
static void ccid2_hc_rx_packet_recv(struct sock *sk, struct sk_buff *skb)