diff --git a/net/bluetooth/sco.c b/net/bluetooth/sco.c index c736186aba26..d7054e3d7146 100644 --- a/net/bluetooth/sco.c +++ b/net/bluetooth/sco.c @@ -285,6 +285,7 @@ static int sco_connect(struct sock *sk) goto unlock; } + hci_conn_get(hcon); /* Update source addr of the socket */ bacpy(&sco_pi(sk)->src, &hcon->src); @@ -300,7 +301,8 @@ static int sco_connect(struct sock *sk) unlock: hci_dev_unlock(hdev); - hci_dev_put(hdev); + if (err) + hci_dev_put(hdev); return err; } @@ -438,12 +440,13 @@ static void __sco_sock_close(struct sock *sk) case BT_CONNECTED: case BT_CONFIG: if (sco_pi(sk)->conn->hcon) { + struct hci_conn *hcon = sco_pi(sk)->conn->hcon; sk->sk_state = BT_DISCONN; sco_sock_set_timer(sk, SCO_DISCONN_TIMEOUT); sco_conn_lock(sco_pi(sk)->conn); - hci_conn_drop(sco_pi(sk)->conn->hcon); sco_pi(sk)->conn->hcon = NULL; sco_conn_unlock(sco_pi(sk)->conn); + hci_conn_put(hcon); } else sco_chan_del(sk, ECONNRESET); break;