diff options
Diffstat (limited to 'net')
-rw-r--r-- | net/bluetooth/af_bluetooth.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/net/bluetooth/af_bluetooth.c b/net/bluetooth/af_bluetooth.c index 744ed3f07ef3..7c0031ff8cfb 100644 --- a/net/bluetooth/af_bluetooth.c +++ b/net/bluetooth/af_bluetooth.c | |||
@@ -217,7 +217,8 @@ struct sock *bt_accept_dequeue(struct sock *parent, struct socket *newsock) | |||
217 | continue; | 217 | continue; |
218 | } | 218 | } |
219 | 219 | ||
220 | if (sk->sk_state == BT_CONNECTED || !newsock) { | 220 | if (sk->sk_state == BT_CONNECTED || !newsock || |
221 | bt_sk(parent)->defer_setup) { | ||
221 | bt_accept_unlink(sk); | 222 | bt_accept_unlink(sk); |
222 | if (newsock) | 223 | if (newsock) |
223 | sock_graft(sk, newsock); | 224 | sock_graft(sk, newsock); |
@@ -232,7 +233,7 @@ struct sock *bt_accept_dequeue(struct sock *parent, struct socket *newsock) | |||
232 | EXPORT_SYMBOL(bt_accept_dequeue); | 233 | EXPORT_SYMBOL(bt_accept_dequeue); |
233 | 234 | ||
234 | int bt_sock_recvmsg(struct kiocb *iocb, struct socket *sock, | 235 | int bt_sock_recvmsg(struct kiocb *iocb, struct socket *sock, |
235 | struct msghdr *msg, size_t len, int flags) | 236 | struct msghdr *msg, size_t len, int flags) |
236 | { | 237 | { |
237 | int noblock = flags & MSG_DONTWAIT; | 238 | int noblock = flags & MSG_DONTWAIT; |
238 | struct sock *sk = sock->sk; | 239 | struct sock *sk = sock->sk; |
@@ -275,6 +276,9 @@ static inline unsigned int bt_accept_poll(struct sock *parent) | |||
275 | struct list_head *p, *n; | 276 | struct list_head *p, *n; |
276 | struct sock *sk; | 277 | struct sock *sk; |
277 | 278 | ||
279 | if (bt_sk(parent)->defer_setup) | ||
280 | return POLLIN | POLLRDNORM; | ||
281 | |||
278 | list_for_each_safe(p, n, &bt_sk(parent)->accept_q) { | 282 | list_for_each_safe(p, n, &bt_sk(parent)->accept_q) { |
279 | sk = (struct sock *) list_entry(p, struct bt_sock, accept_q); | 283 | sk = (struct sock *) list_entry(p, struct bt_sock, accept_q); |
280 | if (sk->sk_state == BT_CONNECTED) | 284 | if (sk->sk_state == BT_CONNECTED) |