net: sk_free() should be allowed right after sk_alloc()
authorJarek Poplawski <jarkao2@gmail.com>
Sun, 30 Aug 2009 23:15:36 +0000 (23:15 +0000)
committerDavid S. Miller <davem@davemloft.net>
Wed, 2 Sep 2009 00:49:00 +0000 (17:49 -0700)
commitd66ee0587c3927aea5178a822976c7c853d815fe
tree3367ebb2757501223ae658b23a96f352aa6ebba8
parent38bddf04bcfe661fbdab94888c3b72c32f6873b3
net: sk_free() should be allowed right after sk_alloc()

After commit 2b85a34e911bf483c27cfdd124aeb1605145dc80
(net: No more expensive sock_hold()/sock_put() on each tx)
sk_free() frees socks conditionally and depends
on sk_wmem_alloc being set e.g. in sock_init_data(). But in some
cases sk_free() is called earlier, usually after other alloc errors.

Fix is to move sk_wmem_alloc initialization from sock_init_data()
to sk_alloc() itself.

Signed-off-by: Jarek Poplawski <jarkao2@gmail.com>
Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/core/sock.c