diff options
author | Herbert Xu <herbert@gondor.apana.org.au> | 2005-10-18 04:03:28 +0200 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@mandriva.com> | 2005-10-20 18:49:59 +0200 |
commit | 49c5bfaffe8ae6e6440dc4bf78b03800960d93f5 (patch) | |
tree | dbd4565b42697a7fdeee8d088f017eb7df8bc594 /net/dccp/output.c | |
parent | [DCCP]: Make dccp_write_xmit always free the packet (diff) | |
download | linux-49c5bfaffe8ae6e6440dc4bf78b03800960d93f5.tar.xz linux-49c5bfaffe8ae6e6440dc4bf78b03800960d93f5.zip |
[DCCP]: Clear the IPCB area
Turns out the problem has nothing to do with use-after-free or double-free.
It's just that we're not clearing the CB area and DCCP unlike TCP uses a CB
format that's incompatible with IP.
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: Ian McDonald <imcdnzl@gmail.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@mandriva.com>
Diffstat (limited to '')
-rw-r--r-- | net/dccp/output.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/net/dccp/output.c b/net/dccp/output.c index 7006549f7050..29250749f16f 100644 --- a/net/dccp/output.c +++ b/net/dccp/output.c @@ -100,6 +100,7 @@ int dccp_transmit_skb(struct sock *sk, struct sk_buff *skb) DCCP_INC_STATS(DCCP_MIB_OUTSEGS); + memset(&(IPCB(skb)->opt), 0, sizeof(IPCB(skb)->opt)); err = ip_queue_xmit(skb, 0); if (err <= 0) return err; |