diff options
author | Samuel Ortiz <sameo@linux.intel.com> | 2012-03-04 19:03:51 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2012-03-06 15:16:24 -0500 |
commit | 40c75f81d6852bb4fd08491074889187f77b8d1f (patch) | |
tree | 456956512172a11d67a811e15277d5e0a56387c0 /net/nfc/llcp/llcp.c | |
parent | 47807d3dbb62e93850cbcb797db1a9ee1806f986 (diff) |
NFC: Fix LLCP sockets releasing path
The socket local pointer needs to be set to NULL when the adapter is
removed or the MAC goes down.
If the socket release code is called after such an event, the socket
reference count still needs to be decreased in order for the socket to
eventually be freed.
Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/nfc/llcp/llcp.c')
-rw-r--r-- | net/nfc/llcp/llcp.c | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/net/nfc/llcp/llcp.c b/net/nfc/llcp/llcp.c index 3ce646e35f6b..8af896dc759e 100644 --- a/net/nfc/llcp/llcp.c +++ b/net/nfc/llcp/llcp.c | |||
@@ -47,7 +47,7 @@ static void nfc_llcp_socket_release(struct nfc_llcp_local *local) | |||
47 | 47 | ||
48 | /* Release all child sockets */ | 48 | /* Release all child sockets */ |
49 | list_for_each_entry_safe(s, n, &parent->list, list) { | 49 | list_for_each_entry_safe(s, n, &parent->list, list) { |
50 | list_del(&s->list); | 50 | list_del_init(&s->list); |
51 | sk = &s->sk; | 51 | sk = &s->sk; |
52 | 52 | ||
53 | lock_sock(sk); | 53 | lock_sock(sk); |
@@ -56,9 +56,12 @@ static void nfc_llcp_socket_release(struct nfc_llcp_local *local) | |||
56 | nfc_put_device(s->dev); | 56 | nfc_put_device(s->dev); |
57 | 57 | ||
58 | sk->sk_state = LLCP_CLOSED; | 58 | sk->sk_state = LLCP_CLOSED; |
59 | sock_set_flag(sk, SOCK_DEAD); | ||
60 | 59 | ||
61 | release_sock(sk); | 60 | release_sock(sk); |
61 | |||
62 | sock_orphan(sk); | ||
63 | |||
64 | s->local = NULL; | ||
62 | } | 65 | } |
63 | 66 | ||
64 | parent_sk = &parent->sk; | 67 | parent_sk = &parent->sk; |
@@ -77,11 +80,12 @@ static void nfc_llcp_socket_release(struct nfc_llcp_local *local) | |||
77 | nfc_llcp_accept_unlink(accept_sk); | 80 | nfc_llcp_accept_unlink(accept_sk); |
78 | 81 | ||
79 | accept_sk->sk_state = LLCP_CLOSED; | 82 | accept_sk->sk_state = LLCP_CLOSED; |
80 | sock_set_flag(accept_sk, SOCK_DEAD); | ||
81 | 83 | ||
82 | release_sock(accept_sk); | 84 | release_sock(accept_sk); |
83 | 85 | ||
84 | sock_orphan(accept_sk); | 86 | sock_orphan(accept_sk); |
87 | |||
88 | lsk->local = NULL; | ||
85 | } | 89 | } |
86 | } | 90 | } |
87 | 91 | ||
@@ -89,9 +93,12 @@ static void nfc_llcp_socket_release(struct nfc_llcp_local *local) | |||
89 | nfc_put_device(parent->dev); | 93 | nfc_put_device(parent->dev); |
90 | 94 | ||
91 | parent_sk->sk_state = LLCP_CLOSED; | 95 | parent_sk->sk_state = LLCP_CLOSED; |
92 | sock_set_flag(parent_sk, SOCK_DEAD); | ||
93 | 96 | ||
94 | release_sock(parent_sk); | 97 | release_sock(parent_sk); |
98 | |||
99 | sock_orphan(parent_sk); | ||
100 | |||
101 | parent->local = NULL; | ||
95 | } | 102 | } |
96 | 103 | ||
97 | mutex_unlock(&local->socket_lock); | 104 | mutex_unlock(&local->socket_lock); |