diff options
author | Herbert Xu <herbert@gondor.apana.org.au> | 2010-02-15 19:24:30 +0000 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-02-16 14:53:24 -0800 |
commit | 10e7454ed7a2da39f1f6255f63d7df27ab4bb67f (patch) | |
tree | 467bf2ee42e91914ac679ad871a87ea2ecb3925f /net/ipv4/ipcomp.c | |
parent | 1cab819b5e244e1b853c7b440981e6a960da3bfb (diff) | |
download | lwn-10e7454ed7a2da39f1f6255f63d7df27ab4bb67f.tar.gz lwn-10e7454ed7a2da39f1f6255f63d7df27ab4bb67f.zip |
ipcomp: Avoid duplicate calls to ipcomp_destroy
When ipcomp_tunnel_attach fails we will call ipcomp_destroy twice.
This may lead to double-frees on certain structures.
As there is no reason to explicitly call ipcomp_destroy, this patch
removes it from ipcomp*.c and lets the standard xfrm_state destruction
take place.
This is based on the discovery and patch by Alexey Dobriyan.
Tested-by: Alexey Dobriyan <adobriyan@gmail.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4/ipcomp.c')
-rw-r--r-- | net/ipv4/ipcomp.c | 6 |
1 files changed, 1 insertions, 5 deletions
diff --git a/net/ipv4/ipcomp.c b/net/ipv4/ipcomp.c index 38fbf04150ae..544ce0876f12 100644 --- a/net/ipv4/ipcomp.c +++ b/net/ipv4/ipcomp.c @@ -124,16 +124,12 @@ static int ipcomp4_init_state(struct xfrm_state *x) if (x->props.mode == XFRM_MODE_TUNNEL) { err = ipcomp_tunnel_attach(x); if (err) - goto error_tunnel; + goto out; } err = 0; out: return err; - -error_tunnel: - ipcomp_destroy(x); - goto out; } static const struct xfrm_type ipcomp_type = { |