diff options
author | John W. Linville <linville@tuxdriver.com> | 2011-06-17 12:40:36 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2011-06-17 12:40:36 -0400 |
commit | 82362ccbf259b960192019deb562bf84549e3d1d (patch) | |
tree | fee34ec77d908cd32907553eed0f10fb30061708 /net/bluetooth/sco.c | |
parent | 118133e6580a0c912cda86109b6468b5ffe73f1c (diff) | |
parent | 3373b28e5af4a0b3c6cb39372581dcc1e41322ff (diff) | |
download | linux-82362ccbf259b960192019deb562bf84549e3d1d.tar.gz linux-82362ccbf259b960192019deb562bf84549e3d1d.tar.bz2 linux-82362ccbf259b960192019deb562bf84549e3d1d.zip |
Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6 into for-davem
Diffstat (limited to 'net/bluetooth/sco.c')
-rw-r--r-- | net/bluetooth/sco.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/net/bluetooth/sco.c b/net/bluetooth/sco.c index 42fdffd1d76c..cb4fb7837e5c 100644 --- a/net/bluetooth/sco.c +++ b/net/bluetooth/sco.c @@ -369,6 +369,15 @@ static void __sco_sock_close(struct sock *sk) case BT_CONNECTED: case BT_CONFIG: + if (sco_pi(sk)->conn) { + sk->sk_state = BT_DISCONN; + sco_sock_set_timer(sk, SCO_DISCONN_TIMEOUT); + hci_conn_put(sco_pi(sk)->conn->hcon); + sco_pi(sk)->conn->hcon = NULL; + } else + sco_chan_del(sk, ECONNRESET); + break; + case BT_CONNECT: case BT_DISCONN: sco_chan_del(sk, ECONNRESET); @@ -819,7 +828,9 @@ static void sco_chan_del(struct sock *sk, int err) conn->sk = NULL; sco_pi(sk)->conn = NULL; sco_conn_unlock(conn); - hci_conn_put(conn->hcon); + + if (conn->hcon) + hci_conn_put(conn->hcon); } sk->sk_state = BT_CLOSED; |