diff options
author | Pavel Emelyanov <xemul@parallels.com> | 2010-11-02 01:54:01 +0000 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-11-03 18:50:07 -0700 |
commit | 8200a59f24aeca379660f80658a8c0c343ca5c31 (patch) | |
tree | fc21336c6dd33ee96d7cf9f07f20132d4a46994e /net/rds | |
parent | 58c490babd4b425310363cbd1f406d7e508f77a5 (diff) | |
download | op-kernel-dev-8200a59f24aeca379660f80658a8c0c343ca5c31.zip op-kernel-dev-8200a59f24aeca379660f80658a8c0c343ca5c31.tar.gz |
rds: Remove kfreed tcp conn from list
All the rds_tcp_connection objects are stored list, but when
being freed it should be removed from there.
Signed-off-by: Pavel Emelyanov <xemul@openvz.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/rds')
-rw-r--r-- | net/rds/tcp.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/net/rds/tcp.c b/net/rds/tcp.c index 08a8c6c..8e0a320 100644 --- a/net/rds/tcp.c +++ b/net/rds/tcp.c @@ -221,7 +221,13 @@ static int rds_tcp_conn_alloc(struct rds_connection *conn, gfp_t gfp) static void rds_tcp_conn_free(void *arg) { struct rds_tcp_connection *tc = arg; + unsigned long flags; rdsdebug("freeing tc %p\n", tc); + + spin_lock_irqsave(&rds_tcp_conn_lock, flags); + list_del(&tc->t_tcp_node); + spin_unlock_irqrestore(&rds_tcp_conn_lock, flags); + kmem_cache_free(rds_tcp_conn_slab, tc); } |