blob: 75cffc14ab6e8e0ff4ef83ba5dd72a567effe3c4 [file] [log] [blame]
YOSHIFUJI Hideaki8e87d142007-02-09 23:24:33 +09001/*
Linus Torvalds1da177e2005-04-16 15:20:36 -07002 BlueZ - Bluetooth protocol stack for Linux
3 Copyright (C) 2000-2001 Qualcomm Incorporated
4
5 Written 2000,2001 by Maxim Krasnyansky <maxk@qualcomm.com>
6
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License version 2 as
9 published by the Free Software Foundation;
10
11 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
12 OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
13 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS.
14 IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) AND AUTHOR(S) BE LIABLE FOR ANY
YOSHIFUJI Hideaki8e87d142007-02-09 23:24:33 +090015 CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES
16 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
17 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
Linus Torvalds1da177e2005-04-16 15:20:36 -070018 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
19
YOSHIFUJI Hideaki8e87d142007-02-09 23:24:33 +090020 ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS,
21 COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS, RELATING TO USE OF THIS
Linus Torvalds1da177e2005-04-16 15:20:36 -070022 SOFTWARE IS DISCLAIMED.
23*/
24
25/* Bluetooth SCO sockets. */
26
Linus Torvalds1da177e2005-04-16 15:20:36 -070027#include <linux/module.h>
Marcel Holtmannaef7d972010-03-21 05:27:45 +010028#include <linux/debugfs.h>
29#include <linux/seq_file.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070030
31#include <net/bluetooth/bluetooth.h>
32#include <net/bluetooth/hci_core.h>
33#include <net/bluetooth/sco.h>
34
Rusty Russelleb939922011-12-19 14:08:01 +000035static bool disable_esco;
Linus Torvalds1da177e2005-04-16 15:20:36 -070036
Eric Dumazet90ddc4f2005-12-22 12:49:22 -080037static const struct proto_ops sco_sock_ops;
Linus Torvalds1da177e2005-04-16 15:20:36 -070038
39static struct bt_sock_list sco_sk_list = {
Robert P. J. Dayd5fb2962008-03-28 16:17:38 -070040 .lock = __RW_LOCK_UNLOCKED(sco_sk_list.lock)
Linus Torvalds1da177e2005-04-16 15:20:36 -070041};
42
Marcel Holtmannfc8f5252014-07-11 06:19:42 +020043/* ---- SCO connections ---- */
44struct sco_conn {
45 struct hci_conn *hcon;
46
47 spinlock_t lock;
48 struct sock *sk;
49
50 unsigned int mtu;
51};
52
53#define sco_conn_lock(c) spin_lock(&c->lock);
54#define sco_conn_unlock(c) spin_unlock(&c->lock);
55
Linus Torvalds1da177e2005-04-16 15:20:36 -070056static void sco_chan_del(struct sock *sk, int err);
57
Linus Torvalds1da177e2005-04-16 15:20:36 -070058static void sco_sock_close(struct sock *sk);
59static void sco_sock_kill(struct sock *sk);
60
Marcel Holtmann2a0dccb2014-07-11 06:19:41 +020061/* ----- SCO socket info ----- */
62#define sco_pi(sk) ((struct sco_pinfo *) sk)
63
64struct sco_pinfo {
65 struct bt_sock bt;
66 bdaddr_t src;
67 bdaddr_t dst;
68 __u32 flags;
69 __u16 setting;
70 struct sco_conn *conn;
71};
72
Linus Torvalds1da177e2005-04-16 15:20:36 -070073/* ---- SCO timers ---- */
Marcel Holtmann068d69e2014-07-11 06:19:44 +020074#define SCO_CONN_TIMEOUT (HZ * 40)
75#define SCO_DISCONN_TIMEOUT (HZ * 2)
76
Linus Torvalds1da177e2005-04-16 15:20:36 -070077static void sco_sock_timeout(unsigned long arg)
78{
79 struct sock *sk = (struct sock *) arg;
80
81 BT_DBG("sock %p state %d", sk, sk->sk_state);
82
83 bh_lock_sock(sk);
84 sk->sk_err = ETIMEDOUT;
85 sk->sk_state_change(sk);
86 bh_unlock_sock(sk);
87
88 sco_sock_kill(sk);
89 sock_put(sk);
90}
91
92static void sco_sock_set_timer(struct sock *sk, long timeout)
93{
94 BT_DBG("sock %p state %d timeout %ld", sk, sk->sk_state, timeout);
95 sk_reset_timer(sk, &sk->sk_timer, jiffies + timeout);
96}
97
98static void sco_sock_clear_timer(struct sock *sk)
99{
100 BT_DBG("sock %p state %d", sk, sk->sk_state);
101 sk_stop_timer(sk, &sk->sk_timer);
102}
103
Linus Torvalds1da177e2005-04-16 15:20:36 -0700104/* ---- SCO connections ---- */
Lukasz Rymanowski519e42b2012-04-19 16:12:28 +0200105static struct sco_conn *sco_conn_add(struct hci_conn *hcon)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700106{
107 struct hci_dev *hdev = hcon->hdev;
Marcel Holtmann25ea6db2006-07-06 15:40:09 +0200108 struct sco_conn *conn = hcon->sco_data;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700109
Lukasz Rymanowski519e42b2012-04-19 16:12:28 +0200110 if (conn)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700111 return conn;
112
Claudio Takahasic10cc5a2013-04-11 11:35:45 -0300113 conn = kzalloc(sizeof(struct sco_conn), GFP_KERNEL);
Marcel Holtmann25ea6db2006-07-06 15:40:09 +0200114 if (!conn)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700115 return NULL;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700116
117 spin_lock_init(&conn->lock);
118
119 hcon->sco_data = conn;
120 conn->hcon = hcon;
121
Linus Torvalds1da177e2005-04-16 15:20:36 -0700122 if (hdev->sco_mtu > 0)
123 conn->mtu = hdev->sco_mtu;
124 else
125 conn->mtu = 60;
126
127 BT_DBG("hcon %p conn %p", hcon, conn);
Marcel Holtmann25ea6db2006-07-06 15:40:09 +0200128
Linus Torvalds1da177e2005-04-16 15:20:36 -0700129 return conn;
130}
131
Gustavo Padovan6039aa732012-05-23 04:04:18 -0300132static struct sock *sco_chan_get(struct sco_conn *conn)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700133{
134 struct sock *sk = NULL;
135 sco_conn_lock(conn);
136 sk = conn->sk;
137 sco_conn_unlock(conn);
138 return sk;
139}
140
141static int sco_conn_del(struct hci_conn *hcon, int err)
142{
Andrei Emeltchenko735cbc42010-12-01 16:58:22 +0200143 struct sco_conn *conn = hcon->sco_data;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700144 struct sock *sk;
145
Andrei Emeltchenko735cbc42010-12-01 16:58:22 +0200146 if (!conn)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700147 return 0;
148
149 BT_DBG("hcon %p conn %p, err %d", hcon, conn, err);
150
151 /* Kill socket */
Andrei Emeltchenko735cbc42010-12-01 16:58:22 +0200152 sk = sco_chan_get(conn);
153 if (sk) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700154 bh_lock_sock(sk);
155 sco_sock_clear_timer(sk);
156 sco_chan_del(sk, err);
157 bh_unlock_sock(sk);
158 sco_sock_kill(sk);
159 }
160
161 hcon->sco_data = NULL;
162 kfree(conn);
163 return 0;
164}
165
Marcel Holtmann015b01c2014-07-13 19:54:48 +0200166static void __sco_chan_add(struct sco_conn *conn, struct sock *sk, struct sock *parent)
167{
168 BT_DBG("conn %p", conn);
169
170 sco_pi(sk)->conn = conn;
171 conn->sk = sk;
172
173 if (parent)
174 bt_accept_enqueue(parent, sk);
175}
176
Gustavo Padovan6039aa732012-05-23 04:04:18 -0300177static int sco_chan_add(struct sco_conn *conn, struct sock *sk,
178 struct sock *parent)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700179{
180 int err = 0;
181
182 sco_conn_lock(conn);
Gustavo F. Padovanb9dbdbc2010-05-01 16:15:35 -0300183 if (conn->sk)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700184 err = -EBUSY;
Gustavo F. Padovanb9dbdbc2010-05-01 16:15:35 -0300185 else
Linus Torvalds1da177e2005-04-16 15:20:36 -0700186 __sco_chan_add(conn, sk, parent);
Gustavo F. Padovanb9dbdbc2010-05-01 16:15:35 -0300187
Linus Torvalds1da177e2005-04-16 15:20:36 -0700188 sco_conn_unlock(conn);
189 return err;
190}
191
192static int sco_connect(struct sock *sk)
193{
Linus Torvalds1da177e2005-04-16 15:20:36 -0700194 struct sco_conn *conn;
195 struct hci_conn *hcon;
196 struct hci_dev *hdev;
Marcel Holtmannb6a0dc82007-10-20 14:55:10 +0200197 int err, type;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700198
Marcel Holtmanneea96362013-10-13 10:34:01 -0700199 BT_DBG("%pMR -> %pMR", &sco_pi(sk)->src, &sco_pi(sk)->dst);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700200
Marcel Holtmanneea96362013-10-13 10:34:01 -0700201 hdev = hci_get_route(&sco_pi(sk)->dst, &sco_pi(sk)->src);
Andrei Emeltchenko735cbc42010-12-01 16:58:22 +0200202 if (!hdev)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700203 return -EHOSTUNREACH;
204
Gustavo F. Padovan09fd0de2011-06-17 13:03:21 -0300205 hci_dev_lock(hdev);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700206
Marcel Holtmann7cb127d2008-07-14 20:13:53 +0200207 if (lmp_esco_capable(hdev) && !disable_esco)
208 type = ESCO_LINK;
209 else
210 type = SCO_LINK;
Marcel Holtmannb6a0dc82007-10-20 14:55:10 +0200211
Frédéric Dalleau79dc0082013-08-19 14:24:01 +0200212 if (sco_pi(sk)->setting == BT_VOICE_TRANSPARENT &&
213 (!lmp_transp_capable(hdev) || !lmp_esco_capable(hdev))) {
214 err = -EOPNOTSUPP;
215 goto done;
216 }
217
Marcel Holtmanneea96362013-10-13 10:34:01 -0700218 hcon = hci_connect_sco(hdev, type, &sco_pi(sk)->dst,
Marcel Holtmann041987c2013-10-13 10:15:22 -0700219 sco_pi(sk)->setting);
Ville Tervo30e76272011-02-22 16:10:53 -0300220 if (IS_ERR(hcon)) {
221 err = PTR_ERR(hcon);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700222 goto done;
Ville Tervo30e76272011-02-22 16:10:53 -0300223 }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700224
Lukasz Rymanowski519e42b2012-04-19 16:12:28 +0200225 conn = sco_conn_add(hcon);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700226 if (!conn) {
David Herrmann76a68ba2013-04-06 20:28:37 +0200227 hci_conn_drop(hcon);
Ville Tervo30e76272011-02-22 16:10:53 -0300228 err = -ENOMEM;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700229 goto done;
230 }
231
232 /* Update source addr of the socket */
Marcel Holtmanneea96362013-10-13 10:34:01 -0700233 bacpy(&sco_pi(sk)->src, &hcon->src);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700234
235 err = sco_chan_add(conn, sk, NULL);
236 if (err)
237 goto done;
238
239 if (hcon->state == BT_CONNECTED) {
240 sco_sock_clear_timer(sk);
241 sk->sk_state = BT_CONNECTED;
242 } else {
243 sk->sk_state = BT_CONNECT;
244 sco_sock_set_timer(sk, sk->sk_sndtimeo);
245 }
Marcel Holtmannb6a0dc82007-10-20 14:55:10 +0200246
Linus Torvalds1da177e2005-04-16 15:20:36 -0700247done:
Gustavo F. Padovan09fd0de2011-06-17 13:03:21 -0300248 hci_dev_unlock(hdev);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700249 hci_dev_put(hdev);
250 return err;
251}
252
Gustavo Padovan6039aa732012-05-23 04:04:18 -0300253static int sco_send_frame(struct sock *sk, struct msghdr *msg, int len)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700254{
255 struct sco_conn *conn = sco_pi(sk)->conn;
256 struct sk_buff *skb;
Mikel Astiz088ce082012-04-11 08:48:48 +0200257 int err;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700258
259 /* Check outgoing MTU */
260 if (len > conn->mtu)
261 return -EINVAL;
262
263 BT_DBG("sk %p len %d", sk, len);
264
Mikel Astiz088ce082012-04-11 08:48:48 +0200265 skb = bt_skb_send_alloc(sk, len, msg->msg_flags & MSG_DONTWAIT, &err);
Gustavo F. Padovanb9dbdbc2010-05-01 16:15:35 -0300266 if (!skb)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700267 return err;
268
Mikel Astiz088ce082012-04-11 08:48:48 +0200269 if (memcpy_fromiovec(skb_put(skb, len), msg->msg_iov, len)) {
Gustavo F. Padovanb9dbdbc2010-05-01 16:15:35 -0300270 kfree_skb(skb);
271 return -EFAULT;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700272 }
273
Gustavo F. Padovan0d861d82010-05-01 16:15:35 -0300274 hci_send_sco(conn->hcon, skb);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700275
Mikel Astiz088ce082012-04-11 08:48:48 +0200276 return len;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700277}
278
Gustavo Padovan6039aa732012-05-23 04:04:18 -0300279static void sco_recv_frame(struct sco_conn *conn, struct sk_buff *skb)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700280{
281 struct sock *sk = sco_chan_get(conn);
282
283 if (!sk)
284 goto drop;
285
286 BT_DBG("sk %p len %d", sk, skb->len);
287
288 if (sk->sk_state != BT_CONNECTED)
289 goto drop;
290
291 if (!sock_queue_rcv_skb(sk, skb))
292 return;
293
294drop:
295 kfree_skb(skb);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700296}
297
298/* -------- Socket interface ---------- */
Marcel Holtmannfb334052012-04-19 14:37:58 +0200299static struct sock *__sco_get_sock_listen_by_addr(bdaddr_t *ba)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700300{
Marcel Holtmannfb334052012-04-19 14:37:58 +0200301 struct sock *sk;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700302
Sasha Levinb67bfe02013-02-27 17:06:00 -0800303 sk_for_each(sk, &sco_sk_list.head) {
Marcel Holtmannfb334052012-04-19 14:37:58 +0200304 if (sk->sk_state != BT_LISTEN)
305 continue;
306
Marcel Holtmanneea96362013-10-13 10:34:01 -0700307 if (!bacmp(&sco_pi(sk)->src, ba))
Marcel Holtmannfb334052012-04-19 14:37:58 +0200308 return sk;
309 }
310
311 return NULL;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700312}
313
314/* Find socket listening on source bdaddr.
315 * Returns closest match.
316 */
317static struct sock *sco_get_sock_listen(bdaddr_t *src)
318{
319 struct sock *sk = NULL, *sk1 = NULL;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700320
321 read_lock(&sco_sk_list.lock);
322
Sasha Levinb67bfe02013-02-27 17:06:00 -0800323 sk_for_each(sk, &sco_sk_list.head) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700324 if (sk->sk_state != BT_LISTEN)
325 continue;
326
327 /* Exact match. */
Marcel Holtmanneea96362013-10-13 10:34:01 -0700328 if (!bacmp(&sco_pi(sk)->src, src))
Linus Torvalds1da177e2005-04-16 15:20:36 -0700329 break;
330
331 /* Closest match */
Marcel Holtmanneea96362013-10-13 10:34:01 -0700332 if (!bacmp(&sco_pi(sk)->src, BDADDR_ANY))
Linus Torvalds1da177e2005-04-16 15:20:36 -0700333 sk1 = sk;
334 }
335
336 read_unlock(&sco_sk_list.lock);
337
Sasha Levinb67bfe02013-02-27 17:06:00 -0800338 return sk ? sk : sk1;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700339}
340
341static void sco_sock_destruct(struct sock *sk)
342{
343 BT_DBG("sk %p", sk);
344
345 skb_queue_purge(&sk->sk_receive_queue);
346 skb_queue_purge(&sk->sk_write_queue);
347}
348
349static void sco_sock_cleanup_listen(struct sock *parent)
350{
351 struct sock *sk;
352
353 BT_DBG("parent %p", parent);
354
355 /* Close not yet accepted channels */
356 while ((sk = bt_accept_dequeue(parent, NULL))) {
357 sco_sock_close(sk);
358 sco_sock_kill(sk);
359 }
360
361 parent->sk_state = BT_CLOSED;
362 sock_set_flag(parent, SOCK_ZAPPED);
363}
364
365/* Kill socket (only if zapped and orphan)
366 * Must be called on unlocked socket.
367 */
368static void sco_sock_kill(struct sock *sk)
369{
370 if (!sock_flag(sk, SOCK_ZAPPED) || sk->sk_socket)
371 return;
372
373 BT_DBG("sk %p state %d", sk, sk->sk_state);
374
375 /* Kill poor orphan */
376 bt_sock_unlink(&sco_sk_list, sk);
377 sock_set_flag(sk, SOCK_DEAD);
378 sock_put(sk);
379}
380
Marcel Holtmannfd0b3ff2009-06-16 00:01:49 +0200381static void __sco_sock_close(struct sock *sk)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700382{
Marcel Holtmannfd0b3ff2009-06-16 00:01:49 +0200383 BT_DBG("sk %p state %d socket %p", sk, sk->sk_state, sk->sk_socket);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700384
385 switch (sk->sk_state) {
386 case BT_LISTEN:
387 sco_sock_cleanup_listen(sk);
388 break;
389
390 case BT_CONNECTED:
391 case BT_CONFIG:
Gustavo Padovanb7e98b52013-01-03 19:59:28 -0200392 if (sco_pi(sk)->conn->hcon) {
Luiz Augusto von Dentz4a777082011-05-12 11:13:15 +0300393 sk->sk_state = BT_DISCONN;
394 sco_sock_set_timer(sk, SCO_DISCONN_TIMEOUT);
David Herrmann76a68ba2013-04-06 20:28:37 +0200395 hci_conn_drop(sco_pi(sk)->conn->hcon);
Luiz Augusto von Dentz4a777082011-05-12 11:13:15 +0300396 sco_pi(sk)->conn->hcon = NULL;
397 } else
398 sco_chan_del(sk, ECONNRESET);
399 break;
400
Vinicius Costa Gomeseb20ff92013-03-13 19:46:20 -0300401 case BT_CONNECT2:
Linus Torvalds1da177e2005-04-16 15:20:36 -0700402 case BT_CONNECT:
403 case BT_DISCONN:
404 sco_chan_del(sk, ECONNRESET);
405 break;
406
407 default:
408 sock_set_flag(sk, SOCK_ZAPPED);
409 break;
Stephen Hemminger3ff50b72007-04-20 17:09:22 -0700410 }
Marcel Holtmannfd0b3ff2009-06-16 00:01:49 +0200411}
Linus Torvalds1da177e2005-04-16 15:20:36 -0700412
Marcel Holtmannfd0b3ff2009-06-16 00:01:49 +0200413/* Must be called on unlocked socket. */
414static void sco_sock_close(struct sock *sk)
415{
416 sco_sock_clear_timer(sk);
417 lock_sock(sk);
418 __sco_sock_close(sk);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700419 release_sock(sk);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700420 sco_sock_kill(sk);
421}
422
423static void sco_sock_init(struct sock *sk, struct sock *parent)
424{
425 BT_DBG("sk %p", sk);
426
Paul Moore6230c9b2011-10-07 09:40:59 +0000427 if (parent) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700428 sk->sk_type = parent->sk_type;
Frédéric Dalleau20714bf2012-11-21 10:51:12 +0100429 bt_sk(sk)->flags = bt_sk(parent)->flags;
Paul Moore6230c9b2011-10-07 09:40:59 +0000430 security_sk_clone(parent, sk);
431 }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700432}
433
434static struct proto sco_proto = {
435 .name = "SCO",
436 .owner = THIS_MODULE,
437 .obj_size = sizeof(struct sco_pinfo)
438};
439
Eric W. Biederman1b8d7ae2007-10-08 23:24:22 -0700440static struct sock *sco_sock_alloc(struct net *net, struct socket *sock, int proto, gfp_t prio)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700441{
442 struct sock *sk;
443
Pavel Emelyanov6257ff22007-11-01 00:39:31 -0700444 sk = sk_alloc(net, PF_BLUETOOTH, prio, &sco_proto);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700445 if (!sk)
446 return NULL;
447
448 sock_init_data(sock, sk);
449 INIT_LIST_HEAD(&bt_sk(sk)->accept_q);
450
451 sk->sk_destruct = sco_sock_destruct;
452 sk->sk_sndtimeo = SCO_CONN_TIMEOUT;
453
454 sock_reset_flag(sk, SOCK_ZAPPED);
455
456 sk->sk_protocol = proto;
457 sk->sk_state = BT_OPEN;
458
Frédéric Dalleauad10b1a2013-08-19 14:23:56 +0200459 sco_pi(sk)->setting = BT_VOICE_CVSD_16BIT;
460
Pavel Emelyanovb24b8a22008-01-23 21:20:07 -0800461 setup_timer(&sk->sk_timer, sco_sock_timeout, (unsigned long)sk);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700462
463 bt_sock_link(&sco_sk_list, sk);
464 return sk;
465}
466
Eric Paris3f378b62009-11-05 22:18:14 -0800467static int sco_sock_create(struct net *net, struct socket *sock, int protocol,
468 int kern)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700469{
470 struct sock *sk;
471
472 BT_DBG("sock %p", sock);
473
474 sock->state = SS_UNCONNECTED;
475
476 if (sock->type != SOCK_SEQPACKET)
477 return -ESOCKTNOSUPPORT;
478
479 sock->ops = &sco_sock_ops;
480
Eric W. Biederman1b8d7ae2007-10-08 23:24:22 -0700481 sk = sco_sock_alloc(net, sock, protocol, GFP_ATOMIC);
Marcel Holtmann74da6262006-10-15 17:31:14 +0200482 if (!sk)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700483 return -ENOMEM;
484
485 sco_sock_init(sk, NULL);
486 return 0;
487}
488
489static int sco_sock_bind(struct socket *sock, struct sockaddr *addr, int addr_len)
490{
491 struct sockaddr_sco *sa = (struct sockaddr_sco *) addr;
492 struct sock *sk = sock->sk;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700493 int err = 0;
494
Andrei Emeltchenko6ed93dc2012-09-25 12:49:43 +0300495 BT_DBG("sk %p %pMR", sk, &sa->sco_bdaddr);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700496
497 if (!addr || addr->sa_family != AF_BLUETOOTH)
498 return -EINVAL;
499
500 lock_sock(sk);
501
502 if (sk->sk_state != BT_OPEN) {
503 err = -EBADFD;
504 goto done;
505 }
506
Marcel Holtmann8ed21f72012-04-19 13:43:53 +0200507 if (sk->sk_type != SOCK_SEQPACKET) {
508 err = -EINVAL;
509 goto done;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700510 }
511
Marcel Holtmanneea96362013-10-13 10:34:01 -0700512 bacpy(&sco_pi(sk)->src, &sa->sco_bdaddr);
Marcel Holtmann8ed21f72012-04-19 13:43:53 +0200513
514 sk->sk_state = BT_BOUND;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700515
516done:
517 release_sock(sk);
518 return err;
519}
520
521static int sco_sock_connect(struct socket *sock, struct sockaddr *addr, int alen, int flags)
522{
523 struct sockaddr_sco *sa = (struct sockaddr_sco *) addr;
524 struct sock *sk = sock->sk;
Claudio Takahasi92f185c2013-04-11 11:35:46 -0300525 int err;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700526
527 BT_DBG("sk %p", sk);
528
Changli Gao6503d962010-03-31 22:58:26 +0000529 if (alen < sizeof(struct sockaddr_sco) ||
530 addr->sa_family != AF_BLUETOOTH)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700531 return -EINVAL;
532
533 if (sk->sk_state != BT_OPEN && sk->sk_state != BT_BOUND)
534 return -EBADFD;
535
536 if (sk->sk_type != SOCK_SEQPACKET)
537 return -EINVAL;
538
539 lock_sock(sk);
540
541 /* Set destination address and psm */
Marcel Holtmanneea96362013-10-13 10:34:01 -0700542 bacpy(&sco_pi(sk)->dst, &sa->sco_bdaddr);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700543
Andrei Emeltchenko735cbc42010-12-01 16:58:22 +0200544 err = sco_connect(sk);
545 if (err)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700546 goto done;
547
YOSHIFUJI Hideaki8e87d142007-02-09 23:24:33 +0900548 err = bt_sock_wait_state(sk, BT_CONNECTED,
Gustavo Padovanbe7c2b92012-05-17 00:36:21 -0300549 sock_sndtimeo(sk, flags & O_NONBLOCK));
Linus Torvalds1da177e2005-04-16 15:20:36 -0700550
551done:
552 release_sock(sk);
553 return err;
554}
555
556static int sco_sock_listen(struct socket *sock, int backlog)
557{
558 struct sock *sk = sock->sk;
Marcel Holtmanneea96362013-10-13 10:34:01 -0700559 bdaddr_t *src = &sco_pi(sk)->src;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700560 int err = 0;
561
562 BT_DBG("sk %p backlog %d", sk, backlog);
563
564 lock_sock(sk);
565
Marcel Holtmann7d5d7752012-04-19 13:43:52 +0200566 if (sk->sk_state != BT_BOUND) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700567 err = -EBADFD;
568 goto done;
569 }
570
Marcel Holtmann7d5d7752012-04-19 13:43:52 +0200571 if (sk->sk_type != SOCK_SEQPACKET) {
572 err = -EINVAL;
573 goto done;
574 }
575
Marcel Holtmannfb334052012-04-19 14:37:58 +0200576 write_lock(&sco_sk_list.lock);
577
578 if (__sco_get_sock_listen_by_addr(src)) {
579 err = -EADDRINUSE;
580 goto unlock;
581 }
582
Linus Torvalds1da177e2005-04-16 15:20:36 -0700583 sk->sk_max_ack_backlog = backlog;
584 sk->sk_ack_backlog = 0;
Marcel Holtmannfb334052012-04-19 14:37:58 +0200585
Linus Torvalds1da177e2005-04-16 15:20:36 -0700586 sk->sk_state = BT_LISTEN;
587
Marcel Holtmannfb334052012-04-19 14:37:58 +0200588unlock:
589 write_unlock(&sco_sk_list.lock);
590
Linus Torvalds1da177e2005-04-16 15:20:36 -0700591done:
592 release_sock(sk);
593 return err;
594}
595
596static int sco_sock_accept(struct socket *sock, struct socket *newsock, int flags)
597{
598 DECLARE_WAITQUEUE(wait, current);
599 struct sock *sk = sock->sk, *ch;
600 long timeo;
601 int err = 0;
602
603 lock_sock(sk);
604
Linus Torvalds1da177e2005-04-16 15:20:36 -0700605 timeo = sock_rcvtimeo(sk, flags & O_NONBLOCK);
606
607 BT_DBG("sk %p timeo %ld", sk, timeo);
608
609 /* Wait for an incoming connection. (wake-one). */
Eric Dumazetaa395142010-04-20 13:03:51 +0000610 add_wait_queue_exclusive(sk_sleep(sk), &wait);
Peter Hurley552b0d32011-07-24 00:11:01 -0400611 while (1) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700612 set_current_state(TASK_INTERRUPTIBLE);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700613
614 if (sk->sk_state != BT_LISTEN) {
615 err = -EBADFD;
616 break;
617 }
618
Peter Hurley552b0d32011-07-24 00:11:01 -0400619 ch = bt_accept_dequeue(sk, newsock);
620 if (ch)
621 break;
622
623 if (!timeo) {
624 err = -EAGAIN;
625 break;
626 }
627
Linus Torvalds1da177e2005-04-16 15:20:36 -0700628 if (signal_pending(current)) {
629 err = sock_intr_errno(timeo);
630 break;
631 }
Peter Hurley552b0d32011-07-24 00:11:01 -0400632
633 release_sock(sk);
634 timeo = schedule_timeout(timeo);
635 lock_sock(sk);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700636 }
Peter Hurley552b0d32011-07-24 00:11:01 -0400637 __set_current_state(TASK_RUNNING);
Eric Dumazetaa395142010-04-20 13:03:51 +0000638 remove_wait_queue(sk_sleep(sk), &wait);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700639
640 if (err)
641 goto done;
642
643 newsock->state = SS_CONNECTED;
644
645 BT_DBG("new socket %p", ch);
646
647done:
648 release_sock(sk);
649 return err;
650}
651
652static int sco_sock_getname(struct socket *sock, struct sockaddr *addr, int *len, int peer)
653{
654 struct sockaddr_sco *sa = (struct sockaddr_sco *) addr;
655 struct sock *sk = sock->sk;
656
657 BT_DBG("sock %p, sk %p", sock, sk);
658
659 addr->sa_family = AF_BLUETOOTH;
660 *len = sizeof(struct sockaddr_sco);
661
662 if (peer)
Marcel Holtmanneea96362013-10-13 10:34:01 -0700663 bacpy(&sa->sco_bdaddr, &sco_pi(sk)->dst);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700664 else
Marcel Holtmanneea96362013-10-13 10:34:01 -0700665 bacpy(&sa->sco_bdaddr, &sco_pi(sk)->src);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700666
667 return 0;
668}
669
YOSHIFUJI Hideaki8e87d142007-02-09 23:24:33 +0900670static int sco_sock_sendmsg(struct kiocb *iocb, struct socket *sock,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700671 struct msghdr *msg, size_t len)
672{
673 struct sock *sk = sock->sk;
Gustavo F. Padovanb9dbdbc2010-05-01 16:15:35 -0300674 int err;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700675
676 BT_DBG("sock %p, sk %p", sock, sk);
677
Benjamin LaHaisec1cbe4b2005-12-13 23:22:19 -0800678 err = sock_error(sk);
679 if (err)
680 return err;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700681
682 if (msg->msg_flags & MSG_OOB)
683 return -EOPNOTSUPP;
684
685 lock_sock(sk);
686
687 if (sk->sk_state == BT_CONNECTED)
688 err = sco_send_frame(sk, msg, len);
689 else
690 err = -ENOTCONN;
691
692 release_sock(sk);
693 return err;
694}
695
Frédéric Dalleau2f69a822013-08-19 14:23:58 +0200696static void sco_conn_defer_accept(struct hci_conn *conn, u16 setting)
Frédéric Dalleaufa5513b2013-04-16 17:28:58 +0200697{
698 struct hci_dev *hdev = conn->hdev;
699
700 BT_DBG("conn %p", conn);
701
702 conn->state = BT_CONFIG;
703
704 if (!lmp_esco_capable(hdev)) {
705 struct hci_cp_accept_conn_req cp;
706
707 bacpy(&cp.bdaddr, &conn->dst);
Frédéric Dalleau33f24042013-08-19 14:23:55 +0200708 cp.role = 0x00; /* Ignored */
Frédéric Dalleaufa5513b2013-04-16 17:28:58 +0200709
710 hci_send_cmd(hdev, HCI_OP_ACCEPT_CONN_REQ, sizeof(cp), &cp);
711 } else {
712 struct hci_cp_accept_sync_conn_req cp;
713
714 bacpy(&cp.bdaddr, &conn->dst);
715 cp.pkt_type = cpu_to_le16(conn->pkt_type);
716
Joe Perchesdcf4adb2014-03-12 10:52:35 -0700717 cp.tx_bandwidth = cpu_to_le32(0x00001f40);
718 cp.rx_bandwidth = cpu_to_le32(0x00001f40);
Frédéric Dalleau2f69a822013-08-19 14:23:58 +0200719 cp.content_format = cpu_to_le16(setting);
720
721 switch (setting & SCO_AIRMODE_MASK) {
722 case SCO_AIRMODE_TRANSP:
723 if (conn->pkt_type & ESCO_2EV3)
Joe Perchesdcf4adb2014-03-12 10:52:35 -0700724 cp.max_latency = cpu_to_le16(0x0008);
Frédéric Dalleau2f69a822013-08-19 14:23:58 +0200725 else
Joe Perchesdcf4adb2014-03-12 10:52:35 -0700726 cp.max_latency = cpu_to_le16(0x000D);
Frédéric Dalleau2f69a822013-08-19 14:23:58 +0200727 cp.retrans_effort = 0x02;
728 break;
729 case SCO_AIRMODE_CVSD:
Joe Perchesdcf4adb2014-03-12 10:52:35 -0700730 cp.max_latency = cpu_to_le16(0xffff);
Frédéric Dalleau2f69a822013-08-19 14:23:58 +0200731 cp.retrans_effort = 0xff;
732 break;
733 }
Frédéric Dalleaufa5513b2013-04-16 17:28:58 +0200734
735 hci_send_cmd(hdev, HCI_OP_ACCEPT_SYNC_CONN_REQ,
736 sizeof(cp), &cp);
737 }
738}
739
Frédéric Dalleau20714bf2012-11-21 10:51:12 +0100740static int sco_sock_recvmsg(struct kiocb *iocb, struct socket *sock,
741 struct msghdr *msg, size_t len, int flags)
742{
743 struct sock *sk = sock->sk;
744 struct sco_pinfo *pi = sco_pi(sk);
745
746 lock_sock(sk);
747
748 if (sk->sk_state == BT_CONNECT2 &&
749 test_bit(BT_SK_DEFER_SETUP, &bt_sk(sk)->flags)) {
Frédéric Dalleau2f69a822013-08-19 14:23:58 +0200750 sco_conn_defer_accept(pi->conn->hcon, pi->setting);
Frédéric Dalleau20714bf2012-11-21 10:51:12 +0100751 sk->sk_state = BT_CONFIG;
752
753 release_sock(sk);
754 return 0;
755 }
756
757 release_sock(sk);
758
759 return bt_sock_recvmsg(iocb, sock, msg, len, flags);
760}
761
David S. Millerb7058842009-09-30 16:12:20 -0700762static int sco_sock_setsockopt(struct socket *sock, int level, int optname, char __user *optval, unsigned int optlen)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700763{
764 struct sock *sk = sock->sk;
Frédéric Dalleauad10b1a2013-08-19 14:23:56 +0200765 int len, err = 0;
766 struct bt_voice voice;
Frédéric Dalleaub96e9c62012-11-21 10:51:11 +0100767 u32 opt;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700768
769 BT_DBG("sk %p", sk);
770
771 lock_sock(sk);
772
773 switch (optname) {
Frédéric Dalleaub96e9c62012-11-21 10:51:11 +0100774
775 case BT_DEFER_SETUP:
776 if (sk->sk_state != BT_BOUND && sk->sk_state != BT_LISTEN) {
777 err = -EINVAL;
778 break;
779 }
780
781 if (get_user(opt, (u32 __user *) optval)) {
782 err = -EFAULT;
783 break;
784 }
785
786 if (opt)
787 set_bit(BT_SK_DEFER_SETUP, &bt_sk(sk)->flags);
788 else
789 clear_bit(BT_SK_DEFER_SETUP, &bt_sk(sk)->flags);
790 break;
791
Frédéric Dalleauad10b1a2013-08-19 14:23:56 +0200792 case BT_VOICE:
793 if (sk->sk_state != BT_OPEN && sk->sk_state != BT_BOUND &&
794 sk->sk_state != BT_CONNECT2) {
795 err = -EINVAL;
796 break;
797 }
798
799 voice.setting = sco_pi(sk)->setting;
800
801 len = min_t(unsigned int, sizeof(voice), optlen);
802 if (copy_from_user((char *) &voice, optval, len)) {
803 err = -EFAULT;
804 break;
805 }
806
807 /* Explicitly check for these values */
808 if (voice.setting != BT_VOICE_TRANSPARENT &&
809 voice.setting != BT_VOICE_CVSD_16BIT) {
810 err = -EINVAL;
811 break;
812 }
813
814 sco_pi(sk)->setting = voice.setting;
815 break;
816
Linus Torvalds1da177e2005-04-16 15:20:36 -0700817 default:
818 err = -ENOPROTOOPT;
819 break;
820 }
821
822 release_sock(sk);
823 return err;
824}
825
Marcel Holtmannd58daf42009-01-15 21:52:14 +0100826static int sco_sock_getsockopt_old(struct socket *sock, int optname, char __user *optval, int __user *optlen)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700827{
828 struct sock *sk = sock->sk;
829 struct sco_options opts;
830 struct sco_conninfo cinfo;
YOSHIFUJI Hideaki8e87d142007-02-09 23:24:33 +0900831 int len, err = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700832
833 BT_DBG("sk %p", sk);
834
835 if (get_user(len, optlen))
836 return -EFAULT;
837
838 lock_sock(sk);
839
840 switch (optname) {
841 case SCO_OPTIONS:
Johan Hedberg9d225d22013-08-08 14:53:56 +0300842 if (sk->sk_state != BT_CONNECTED &&
843 !(sk->sk_state == BT_CONNECT2 &&
844 test_bit(BT_SK_DEFER_SETUP, &bt_sk(sk)->flags))) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700845 err = -ENOTCONN;
846 break;
847 }
848
849 opts.mtu = sco_pi(sk)->conn->mtu;
850
851 BT_DBG("mtu %d", opts.mtu);
852
853 len = min_t(unsigned int, len, sizeof(opts));
854 if (copy_to_user(optval, (char *)&opts, len))
855 err = -EFAULT;
856
857 break;
858
859 case SCO_CONNINFO:
Johan Hedberg9d225d22013-08-08 14:53:56 +0300860 if (sk->sk_state != BT_CONNECTED &&
861 !(sk->sk_state == BT_CONNECT2 &&
862 test_bit(BT_SK_DEFER_SETUP, &bt_sk(sk)->flags))) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700863 err = -ENOTCONN;
864 break;
865 }
866
Vasiliy Kulikovc4c896e2011-02-14 13:54:26 +0300867 memset(&cinfo, 0, sizeof(cinfo));
Linus Torvalds1da177e2005-04-16 15:20:36 -0700868 cinfo.hci_handle = sco_pi(sk)->conn->hcon->handle;
869 memcpy(cinfo.dev_class, sco_pi(sk)->conn->hcon->dev_class, 3);
870
871 len = min_t(unsigned int, len, sizeof(cinfo));
872 if (copy_to_user(optval, (char *)&cinfo, len))
873 err = -EFAULT;
874
875 break;
876
877 default:
878 err = -ENOPROTOOPT;
879 break;
880 }
881
882 release_sock(sk);
883 return err;
884}
885
Marcel Holtmannd58daf42009-01-15 21:52:14 +0100886static int sco_sock_getsockopt(struct socket *sock, int level, int optname, char __user *optval, int __user *optlen)
887{
888 struct sock *sk = sock->sk;
889 int len, err = 0;
Frédéric Dalleauad10b1a2013-08-19 14:23:56 +0200890 struct bt_voice voice;
Marcel Holtmannd58daf42009-01-15 21:52:14 +0100891
892 BT_DBG("sk %p", sk);
893
894 if (level == SOL_SCO)
895 return sco_sock_getsockopt_old(sock, optname, optval, optlen);
896
897 if (get_user(len, optlen))
898 return -EFAULT;
899
900 lock_sock(sk);
901
902 switch (optname) {
Frédéric Dalleaub96e9c62012-11-21 10:51:11 +0100903
904 case BT_DEFER_SETUP:
905 if (sk->sk_state != BT_BOUND && sk->sk_state != BT_LISTEN) {
906 err = -EINVAL;
907 break;
908 }
909
910 if (put_user(test_bit(BT_SK_DEFER_SETUP, &bt_sk(sk)->flags),
911 (u32 __user *) optval))
912 err = -EFAULT;
913
914 break;
915
Frédéric Dalleauad10b1a2013-08-19 14:23:56 +0200916 case BT_VOICE:
917 voice.setting = sco_pi(sk)->setting;
918
919 len = min_t(unsigned int, len, sizeof(voice));
920 if (copy_to_user(optval, (char *)&voice, len))
921 err = -EFAULT;
922
923 break;
924
Marcel Holtmannd58daf42009-01-15 21:52:14 +0100925 default:
926 err = -ENOPROTOOPT;
927 break;
928 }
929
930 release_sock(sk);
931 return err;
932}
933
Marcel Holtmannfd0b3ff2009-06-16 00:01:49 +0200934static int sco_sock_shutdown(struct socket *sock, int how)
935{
936 struct sock *sk = sock->sk;
937 int err = 0;
938
939 BT_DBG("sock %p, sk %p", sock, sk);
940
941 if (!sk)
942 return 0;
943
944 lock_sock(sk);
945 if (!sk->sk_shutdown) {
946 sk->sk_shutdown = SHUTDOWN_MASK;
947 sco_sock_clear_timer(sk);
948 __sco_sock_close(sk);
949
950 if (sock_flag(sk, SOCK_LINGER) && sk->sk_lingertime)
951 err = bt_sock_wait_state(sk, BT_CLOSED,
Gustavo Padovanbe7c2b92012-05-17 00:36:21 -0300952 sk->sk_lingertime);
Marcel Holtmannfd0b3ff2009-06-16 00:01:49 +0200953 }
954 release_sock(sk);
955 return err;
956}
957
Linus Torvalds1da177e2005-04-16 15:20:36 -0700958static int sco_sock_release(struct socket *sock)
959{
960 struct sock *sk = sock->sk;
961 int err = 0;
962
963 BT_DBG("sock %p, sk %p", sock, sk);
964
965 if (!sk)
966 return 0;
967
968 sco_sock_close(sk);
969
970 if (sock_flag(sk, SOCK_LINGER) && sk->sk_lingertime) {
971 lock_sock(sk);
972 err = bt_sock_wait_state(sk, BT_CLOSED, sk->sk_lingertime);
973 release_sock(sk);
974 }
975
976 sock_orphan(sk);
977 sco_sock_kill(sk);
978 return err;
979}
980
YOSHIFUJI Hideaki8e87d142007-02-09 23:24:33 +0900981/* Delete channel.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700982 * Must be called on the locked socket. */
983static 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
Gustavo Padovan0b27a4b2012-12-03 15:36:51 -0200991 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)
David Herrmann76a68ba2013-04-06 20:28:37 +0200998 hci_conn_drop(conn->hcon);
Gustavo Padovan0b27a4b2012-12-03 15:36:51 -0200999 }
1000
Linus Torvalds1da177e2005-04-16 15:20:36 -07001001 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
1008static void sco_conn_ready(struct sco_conn *conn)
1009{
Andrei Emeltchenko735cbc42010-12-01 16:58:22 +02001010 struct sock *parent;
1011 struct sock *sk = conn->sk;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001012
1013 BT_DBG("conn %p", conn);
1014
Andrei Emeltchenko735cbc42010-12-01 16:58:22 +02001015 if (sk) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001016 sco_sock_clear_timer(sk);
1017 bh_lock_sock(sk);
1018 sk->sk_state = BT_CONNECTED;
1019 sk->sk_state_change(sk);
1020 bh_unlock_sock(sk);
1021 } else {
Andre Guedes40528082013-01-29 19:59:56 -03001022 sco_conn_lock(conn);
1023
Marcel Holtmann041987c2013-10-13 10:15:22 -07001024 parent = sco_get_sock_listen(&conn->hcon->src);
Andre Guedes40528082013-01-29 19:59:56 -03001025 if (!parent) {
1026 sco_conn_unlock(conn);
1027 return;
1028 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001029
1030 bh_lock_sock(parent);
1031
Gustavo F. Padovanb9dbdbc2010-05-01 16:15:35 -03001032 sk = sco_sock_alloc(sock_net(parent), NULL,
Gustavo Padovanbe7c2b92012-05-17 00:36:21 -03001033 BTPROTO_SCO, GFP_ATOMIC);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001034 if (!sk) {
1035 bh_unlock_sock(parent);
Andre Guedes40528082013-01-29 19:59:56 -03001036 sco_conn_unlock(conn);
1037 return;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001038 }
1039
1040 sco_sock_init(sk, parent);
1041
Marcel Holtmanneea96362013-10-13 10:34:01 -07001042 bacpy(&sco_pi(sk)->src, &conn->hcon->src);
1043 bacpy(&sco_pi(sk)->dst, &conn->hcon->dst);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001044
1045 hci_conn_hold(conn->hcon);
1046 __sco_chan_add(conn, sk, parent);
1047
Frédéric Dalleau20714bf2012-11-21 10:51:12 +01001048 if (test_bit(BT_SK_DEFER_SETUP, &bt_sk(parent)->flags))
1049 sk->sk_state = BT_CONNECT2;
1050 else
1051 sk->sk_state = BT_CONNECTED;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001052
1053 /* Wake up parent */
David S. Miller676d2362014-04-11 16:15:36 -04001054 parent->sk_data_ready(parent);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001055
1056 bh_unlock_sock(parent);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001057
Andre Guedes40528082013-01-29 19:59:56 -03001058 sco_conn_unlock(conn);
1059 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001060}
1061
1062/* ----- SCO interface with lower layer (HCI) ----- */
Frédéric Dalleau20714bf2012-11-21 10:51:12 +01001063int sco_connect_ind(struct hci_dev *hdev, bdaddr_t *bdaddr, __u8 *flags)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001064{
Gustavo Padovanfc5fef62012-05-23 04:04:19 -03001065 struct sock *sk;
Marcel Holtmann71aeeaa2009-01-15 21:57:02 +01001066 int lm = 0;
1067
Andrei Emeltchenko6ed93dc2012-09-25 12:49:43 +03001068 BT_DBG("hdev %s, bdaddr %pMR", hdev->name, bdaddr);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001069
Marcel Holtmann71aeeaa2009-01-15 21:57:02 +01001070 /* Find listening sockets */
1071 read_lock(&sco_sk_list.lock);
Sasha Levinb67bfe02013-02-27 17:06:00 -08001072 sk_for_each(sk, &sco_sk_list.head) {
Marcel Holtmann71aeeaa2009-01-15 21:57:02 +01001073 if (sk->sk_state != BT_LISTEN)
1074 continue;
1075
Marcel Holtmanneea96362013-10-13 10:34:01 -07001076 if (!bacmp(&sco_pi(sk)->src, &hdev->bdaddr) ||
1077 !bacmp(&sco_pi(sk)->src, BDADDR_ANY)) {
Marcel Holtmann71aeeaa2009-01-15 21:57:02 +01001078 lm |= HCI_LM_ACCEPT;
Frédéric Dalleau20714bf2012-11-21 10:51:12 +01001079
1080 if (test_bit(BT_SK_DEFER_SETUP, &bt_sk(sk)->flags))
1081 *flags |= HCI_PROTO_DEFER;
Marcel Holtmann71aeeaa2009-01-15 21:57:02 +01001082 break;
1083 }
1084 }
1085 read_unlock(&sco_sk_list.lock);
1086
1087 return lm;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001088}
1089
Andrei Emeltchenko9e664632012-07-24 16:06:15 +03001090void sco_connect_cfm(struct hci_conn *hcon, __u8 status)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001091{
Andrei Emeltchenko6ed93dc2012-09-25 12:49:43 +03001092 BT_DBG("hcon %p bdaddr %pMR status %d", hcon, &hcon->dst, status);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001093 if (!status) {
1094 struct sco_conn *conn;
1095
Lukasz Rymanowski519e42b2012-04-19 16:12:28 +02001096 conn = sco_conn_add(hcon);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001097 if (conn)
1098 sco_conn_ready(conn);
YOSHIFUJI Hideaki8e87d142007-02-09 23:24:33 +09001099 } else
Joe Perchese1750722011-06-29 18:18:29 -07001100 sco_conn_del(hcon, bt_to_errno(status));
Linus Torvalds1da177e2005-04-16 15:20:36 -07001101}
1102
Andrei Emeltchenko9e664632012-07-24 16:06:15 +03001103void sco_disconn_cfm(struct hci_conn *hcon, __u8 reason)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001104{
1105 BT_DBG("hcon %p reason %d", hcon, reason);
1106
Joe Perchese1750722011-06-29 18:18:29 -07001107 sco_conn_del(hcon, bt_to_errno(reason));
Linus Torvalds1da177e2005-04-16 15:20:36 -07001108}
1109
Ulisses Furquim686ebf22011-12-21 10:11:33 -02001110int sco_recv_scodata(struct hci_conn *hcon, struct sk_buff *skb)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001111{
1112 struct sco_conn *conn = hcon->sco_data;
1113
1114 if (!conn)
1115 goto drop;
1116
1117 BT_DBG("conn %p len %d", conn, skb->len);
1118
1119 if (skb->len) {
1120 sco_recv_frame(conn, skb);
1121 return 0;
1122 }
1123
1124drop:
YOSHIFUJI Hideaki8e87d142007-02-09 23:24:33 +09001125 kfree_skb(skb);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001126 return 0;
1127}
1128
Marcel Holtmannaef7d972010-03-21 05:27:45 +01001129static int sco_debugfs_show(struct seq_file *f, void *p)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001130{
1131 struct sock *sk;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001132
Gustavo F. Padovanee65d192011-12-27 15:28:46 -02001133 read_lock(&sco_sk_list.lock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001134
Sasha Levinb67bfe02013-02-27 17:06:00 -08001135 sk_for_each(sk, &sco_sk_list.head) {
Marcel Holtmanneea96362013-10-13 10:34:01 -07001136 seq_printf(f, "%pMR %pMR %d\n", &sco_pi(sk)->src,
1137 &sco_pi(sk)->dst, sk->sk_state);
Marcel Holtmannbe9d1222005-11-08 09:57:38 -08001138 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001139
Gustavo F. Padovanee65d192011-12-27 15:28:46 -02001140 read_unlock(&sco_sk_list.lock);
Marcel Holtmannbe9d1222005-11-08 09:57:38 -08001141
Marcel Holtmannaef7d972010-03-21 05:27:45 +01001142 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001143}
1144
Marcel Holtmannaef7d972010-03-21 05:27:45 +01001145static int sco_debugfs_open(struct inode *inode, struct file *file)
1146{
1147 return single_open(file, sco_debugfs_show, inode->i_private);
1148}
1149
1150static const struct file_operations sco_debugfs_fops = {
1151 .open = sco_debugfs_open,
1152 .read = seq_read,
1153 .llseek = seq_lseek,
1154 .release = single_release,
1155};
1156
1157static struct dentry *sco_debugfs;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001158
Eric Dumazet90ddc4f2005-12-22 12:49:22 -08001159static const struct proto_ops sco_sock_ops = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001160 .family = PF_BLUETOOTH,
1161 .owner = THIS_MODULE,
1162 .release = sco_sock_release,
1163 .bind = sco_sock_bind,
1164 .connect = sco_sock_connect,
1165 .listen = sco_sock_listen,
1166 .accept = sco_sock_accept,
1167 .getname = sco_sock_getname,
1168 .sendmsg = sco_sock_sendmsg,
Frédéric Dalleau20714bf2012-11-21 10:51:12 +01001169 .recvmsg = sco_sock_recvmsg,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001170 .poll = bt_sock_poll,
Marcel Holtmann3241ad82008-07-14 20:13:50 +02001171 .ioctl = bt_sock_ioctl,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001172 .mmap = sock_no_mmap,
1173 .socketpair = sock_no_socketpair,
Marcel Holtmannfd0b3ff2009-06-16 00:01:49 +02001174 .shutdown = sco_sock_shutdown,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001175 .setsockopt = sco_sock_setsockopt,
1176 .getsockopt = sco_sock_getsockopt
1177};
1178
Stephen Hemmingerec1b4cf2009-10-05 05:58:39 +00001179static const struct net_proto_family sco_sock_family_ops = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001180 .family = PF_BLUETOOTH,
1181 .owner = THIS_MODULE,
1182 .create = sco_sock_create,
1183};
1184
Gustavo F. Padovan64274512011-02-07 20:08:52 -02001185int __init sco_init(void)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001186{
1187 int err;
1188
1189 err = proto_register(&sco_proto, 0);
1190 if (err < 0)
1191 return err;
1192
1193 err = bt_sock_register(BTPROTO_SCO, &sco_sock_family_ops);
1194 if (err < 0) {
1195 BT_ERR("SCO socket registration failed");
1196 goto error;
1197 }
1198
Al Virob0316612013-04-04 19:14:33 -04001199 err = bt_procfs_init(&init_net, "sco", &sco_sk_list, NULL);
Masatake YAMATOde9b9212012-07-26 01:30:12 +09001200 if (err < 0) {
1201 BT_ERR("Failed to create SCO proc file");
1202 bt_sock_unregister(BTPROTO_SCO);
1203 goto error;
1204 }
1205
Linus Torvalds1da177e2005-04-16 15:20:36 -07001206 BT_INFO("SCO socket layer initialized");
1207
Marcel Holtmann1120e4b2013-10-17 17:24:16 -07001208 if (IS_ERR_OR_NULL(bt_debugfs))
1209 return 0;
1210
1211 sco_debugfs = debugfs_create_file("sco", 0444, bt_debugfs,
1212 NULL, &sco_debugfs_fops);
1213
Linus Torvalds1da177e2005-04-16 15:20:36 -07001214 return 0;
1215
1216error:
1217 proto_unregister(&sco_proto);
1218 return err;
1219}
1220
Gustavo F. Padovan64274512011-02-07 20:08:52 -02001221void __exit sco_exit(void)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001222{
Masatake YAMATOde9b9212012-07-26 01:30:12 +09001223 bt_procfs_cleanup(&init_net, "sco");
1224
Marcel Holtmannaef7d972010-03-21 05:27:45 +01001225 debugfs_remove(sco_debugfs);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001226
David Herrmann5e9d7f82013-02-24 19:36:51 +01001227 bt_sock_unregister(BTPROTO_SCO);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001228
Linus Torvalds1da177e2005-04-16 15:20:36 -07001229 proto_unregister(&sco_proto);
1230}
1231
Marcel Holtmann7cb127d2008-07-14 20:13:53 +02001232module_param(disable_esco, bool, 0644);
1233MODULE_PARM_DESC(disable_esco, "Disable eSCO connection creation");