diff options
Diffstat (limited to 'net/bluetooth/sco.c')
-rw-r--r-- | net/bluetooth/sco.c | 56 |
1 files changed, 27 insertions, 29 deletions
diff --git a/net/bluetooth/sco.c b/net/bluetooth/sco.c index 75cffc14ab6e..4d67b0354d23 100644 --- a/net/bluetooth/sco.c +++ b/net/bluetooth/sco.c | |||
@@ -53,8 +53,6 @@ struct sco_conn { | |||
53 | #define sco_conn_lock(c) spin_lock(&c->lock); | 53 | #define sco_conn_lock(c) spin_lock(&c->lock); |
54 | #define sco_conn_unlock(c) spin_unlock(&c->lock); | 54 | #define sco_conn_unlock(c) spin_unlock(&c->lock); |
55 | 55 | ||
56 | static void sco_chan_del(struct sock *sk, int err); | ||
57 | |||
58 | static void sco_sock_close(struct sock *sk); | 56 | static void sco_sock_close(struct sock *sk); |
59 | static void sco_sock_kill(struct sock *sk); | 57 | static void sco_sock_kill(struct sock *sk); |
60 | 58 | ||
@@ -138,6 +136,33 @@ static struct sock *sco_chan_get(struct sco_conn *conn) | |||
138 | return sk; | 136 | return sk; |
139 | } | 137 | } |
140 | 138 | ||
139 | /* Delete channel. | ||
140 | * Must be called on the locked socket. */ | ||
141 | static void sco_chan_del(struct sock *sk, int err) | ||
142 | { | ||
143 | struct sco_conn *conn; | ||
144 | |||
145 | conn = sco_pi(sk)->conn; | ||
146 | |||
147 | BT_DBG("sk %p, conn %p, err %d", sk, conn, err); | ||
148 | |||
149 | if (conn) { | ||
150 | sco_conn_lock(conn); | ||
151 | conn->sk = NULL; | ||
152 | sco_pi(sk)->conn = NULL; | ||
153 | sco_conn_unlock(conn); | ||
154 | |||
155 | if (conn->hcon) | ||
156 | hci_conn_drop(conn->hcon); | ||
157 | } | ||
158 | |||
159 | sk->sk_state = BT_CLOSED; | ||
160 | sk->sk_err = err; | ||
161 | sk->sk_state_change(sk); | ||
162 | |||
163 | sock_set_flag(sk, SOCK_ZAPPED); | ||
164 | } | ||
165 | |||
141 | static int sco_conn_del(struct hci_conn *hcon, int err) | 166 | static int sco_conn_del(struct hci_conn *hcon, int err) |
142 | { | 167 | { |
143 | struct sco_conn *conn = hcon->sco_data; | 168 | struct sco_conn *conn = hcon->sco_data; |
@@ -978,33 +1003,6 @@ static int sco_sock_release(struct socket *sock) | |||
978 | return err; | 1003 | return err; |
979 | } | 1004 | } |
980 | 1005 | ||
981 | /* Delete channel. | ||
982 | * Must be called on the locked socket. */ | ||
983 | static void sco_chan_del(struct sock *sk, int err) | ||
984 | { | ||
985 | struct sco_conn *conn; | ||
986 | |||
987 | conn = sco_pi(sk)->conn; | ||
988 | |||
989 | BT_DBG("sk %p, conn %p, err %d", sk, conn, err); | ||
990 | |||
991 | if (conn) { | ||
992 | sco_conn_lock(conn); | ||
993 | conn->sk = NULL; | ||
994 | sco_pi(sk)->conn = NULL; | ||
995 | sco_conn_unlock(conn); | ||
996 | |||
997 | if (conn->hcon) | ||
998 | hci_conn_drop(conn->hcon); | ||
999 | } | ||
1000 | |||
1001 | sk->sk_state = BT_CLOSED; | ||
1002 | sk->sk_err = err; | ||
1003 | sk->sk_state_change(sk); | ||
1004 | |||
1005 | sock_set_flag(sk, SOCK_ZAPPED); | ||
1006 | } | ||
1007 | |||
1008 | static void sco_conn_ready(struct sco_conn *conn) | 1006 | static void sco_conn_ready(struct sco_conn *conn) |
1009 | { | 1007 | { |
1010 | struct sock *parent; | 1008 | struct sock *parent; |