ipv4: dst_entry leak in ip_send_unicast_reply()
authorVasily Averin <vvs@parallels.com>
Wed, 15 Oct 2014 12:24:02 +0000 (16:24 +0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 14 Nov 2014 16:59:44 +0000 (08:59 -0800)
commit7584945280883f5e414b1038c2af0e8daf51c986
treea985e6b118fd654d9bbd87db39fe76677da92fc3
parentabe640984aa492652232b65d3579361cf6d461f5
ipv4: dst_entry leak in ip_send_unicast_reply()

[ Upstream commit 4062090e3e5caaf55bed4523a69f26c3265cc1d2 ]

ip_setup_cork() called inside ip_append_data() steals dst entry from rt to cork
and in case errors in __ip_append_data() nobody frees stolen dst entry

Fixes: 2e77d89b2fa8 ("net: avoid a pair of dst_hold()/dst_release() in ip_append_data()")
Signed-off-by: Vasily Averin <vvs@parallels.com>
Acked-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
net/ipv4/ip_output.c