l2cap.c
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:45k
源码类别:

Linux/Unix编程

开发平台:

Unix_Linux

  1. /* 
  2.    BlueZ - Bluetooth protocol stack for Linux
  3.    Copyright (C) 2000-2001 Qualcomm Incorporated
  4.    Written 2000,2001 by Maxim Krasnyansky <maxk@qualcomm.com>
  5.    This program is free software; you can redistribute it and/or modify
  6.    it under the terms of the GNU General Public License version 2 as
  7.    published by the Free Software Foundation;
  8.    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
  9.    OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  10.    FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS.
  11.    IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) AND AUTHOR(S) BE LIABLE FOR ANY
  12.    CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES 
  13.    WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 
  14.    ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 
  15.    OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  16.    ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS, 
  17.    COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS, RELATING TO USE OF THIS 
  18.    SOFTWARE IS DISCLAIMED.
  19. */
  20. /*
  21.  * BlueZ L2CAP core and sockets.
  22.  *
  23.  * $Id: l2cap.c,v 1.15 2002/09/09 01:14:52 maxk Exp $
  24.  */
  25. #define VERSION "2.1"
  26. #include <linux/config.h>
  27. #include <linux/module.h>
  28. #include <linux/types.h>
  29. #include <linux/errno.h>
  30. #include <linux/kernel.h>
  31. #include <linux/major.h>
  32. #include <linux/sched.h>
  33. #include <linux/slab.h>
  34. #include <linux/poll.h>
  35. #include <linux/fcntl.h>
  36. #include <linux/init.h>
  37. #include <linux/skbuff.h>
  38. #include <linux/interrupt.h>
  39. #include <linux/socket.h>
  40. #include <linux/skbuff.h>
  41. #include <linux/proc_fs.h>
  42. #include <linux/list.h>
  43. #include <net/sock.h>
  44. #include <asm/system.h>
  45. #include <asm/uaccess.h>
  46. #include <asm/unaligned.h>
  47. #include <net/bluetooth/bluetooth.h>
  48. #include <net/bluetooth/hci_core.h>
  49. #include <net/bluetooth/l2cap.h>
  50. #ifndef L2CAP_DEBUG
  51. #undef  BT_DBG
  52. #define BT_DBG( A... )
  53. #endif
  54. static struct proto_ops l2cap_sock_ops;
  55. struct bluez_sock_list l2cap_sk_list = {
  56. lock: RW_LOCK_UNLOCKED
  57. };
  58. static int l2cap_conn_del(struct hci_conn *conn, int err);
  59. static inline void l2cap_chan_add(struct l2cap_conn *conn, struct sock *sk, struct sock *parent);
  60. static void l2cap_chan_del(struct sock *sk, int err);
  61. static int  l2cap_chan_send(struct sock *sk, struct msghdr *msg, int len);
  62. static void __l2cap_sock_close(struct sock *sk, int reason);
  63. static void l2cap_sock_close(struct sock *sk);
  64. static void l2cap_sock_kill(struct sock *sk);
  65. static int l2cap_send_req(struct l2cap_conn *conn, __u8 code, __u16 len, void *data);
  66. static int l2cap_send_rsp(struct l2cap_conn *conn, __u8 ident, __u8 code, __u16 len, void *data);
  67. /* ----- L2CAP timers ------ */
  68. static void l2cap_sock_timeout(unsigned long arg)
  69. {
  70. struct sock *sk = (struct sock *) arg;
  71. BT_DBG("sock %p state %d", sk, sk->state);
  72. bh_lock_sock(sk);
  73. __l2cap_sock_close(sk, ETIMEDOUT);
  74. bh_unlock_sock(sk);
  75. l2cap_sock_kill(sk);
  76. sock_put(sk);
  77. }
  78. static void l2cap_sock_set_timer(struct sock *sk, long timeout)
  79. {
  80. BT_DBG("sk %p state %d timeout %ld", sk, sk->state, timeout);
  81. if (!mod_timer(&sk->timer, jiffies + timeout))
  82. sock_hold(sk);
  83. }
  84. static void l2cap_sock_clear_timer(struct sock *sk)
  85. {
  86. BT_DBG("sock %p state %d", sk, sk->state);
  87. if (timer_pending(&sk->timer) && del_timer(&sk->timer))
  88. __sock_put(sk);
  89. }
  90. static void l2cap_sock_init_timer(struct sock *sk)
  91. {
  92. init_timer(&sk->timer);
  93. sk->timer.function = l2cap_sock_timeout;
  94. sk->timer.data = (unsigned long)sk;
  95. }
  96. /* -------- L2CAP connections --------- */
  97. static struct l2cap_conn *l2cap_conn_add(struct hci_conn *hcon, __u8 status)
  98. {
  99. struct l2cap_conn *conn;
  100. if ((conn = hcon->l2cap_data))
  101. return conn;
  102. if (status)
  103. return conn;
  104. if (!(conn = kmalloc(sizeof(struct l2cap_conn), GFP_ATOMIC)))
  105. return NULL;
  106. memset(conn, 0, sizeof(struct l2cap_conn));
  107. hcon->l2cap_data = conn;
  108. conn->hcon = hcon;
  109. conn->mtu = hcon->hdev->acl_mtu;
  110. conn->src = &hcon->hdev->bdaddr;
  111. conn->dst = &hcon->dst;
  112. spin_lock_init(&conn->lock);
  113. conn->chan_list.lock = RW_LOCK_UNLOCKED;
  114. BT_DBG("hcon %p conn %p", hcon, conn);
  115. MOD_INC_USE_COUNT;
  116. return conn;
  117. }
  118. static int l2cap_conn_del(struct hci_conn *hcon, int err)
  119. {
  120. struct l2cap_conn *conn;
  121. struct sock *sk;
  122. if (!(conn = hcon->l2cap_data)) 
  123. return 0;
  124. BT_DBG("hcon %p conn %p, err %d", hcon, conn, err);
  125. if (conn->rx_skb)
  126. kfree_skb(conn->rx_skb);
  127. /* Kill channels */
  128. while ((sk = conn->chan_list.head)) {
  129. bh_lock_sock(sk);
  130. l2cap_chan_del(sk, err);
  131. bh_unlock_sock(sk);
  132. l2cap_sock_kill(sk);
  133. }
  134. hcon->l2cap_data = NULL;
  135. kfree(conn);
  136. MOD_DEC_USE_COUNT;
  137. return 0;
  138. }
  139. int l2cap_connect(struct sock *sk)
  140. {
  141. bdaddr_t *src = &bluez_pi(sk)->src;
  142. bdaddr_t *dst = &bluez_pi(sk)->dst;
  143. struct l2cap_conn *conn;
  144. struct hci_conn   *hcon;
  145. struct hci_dev    *hdev;
  146. int err = 0;
  147. BT_DBG("%s -> %s psm 0x%2.2x", batostr(src), batostr(dst), l2cap_pi(sk)->psm);
  148. if (!(hdev = hci_get_route(dst, src)))
  149. return -EHOSTUNREACH;
  150. hci_dev_lock_bh(hdev);
  151. err = -ENOMEM;
  152. hcon = hci_connect(hdev, ACL_LINK, dst);
  153. if (!hcon)
  154. goto done;
  155. conn = l2cap_conn_add(hcon, 0);
  156. if (!conn) {
  157. hci_conn_put(hcon);
  158. goto done;
  159. }
  160. err = 0;
  161. /* Update source addr of the socket */
  162. bacpy(src, conn->src);
  163. l2cap_chan_add(conn, sk, NULL);
  164. sk->state = BT_CONNECT;
  165. l2cap_sock_set_timer(sk, sk->sndtimeo);
  166. if (hcon->state == BT_CONNECTED) {
  167. if (sk->type == SOCK_SEQPACKET) {
  168. l2cap_conn_req req;
  169. req.scid = __cpu_to_le16(l2cap_pi(sk)->scid);
  170. req.psm  = l2cap_pi(sk)->psm;
  171. l2cap_send_req(conn, L2CAP_CONN_REQ, L2CAP_CONN_REQ_SIZE, &req);
  172. } else {
  173. l2cap_sock_clear_timer(sk);
  174. sk->state = BT_CONNECTED;
  175. }
  176. }
  177. done:
  178. hci_dev_unlock_bh(hdev);
  179. hci_dev_put(hdev);
  180. return err;
  181. }
  182. /* -------- Socket interface ---------- */
  183. static struct sock *__l2cap_get_sock_by_addr(__u16 psm, bdaddr_t *src)
  184. {
  185. struct sock *sk;
  186. for (sk = l2cap_sk_list.head; sk; sk = sk->next) {
  187. if (l2cap_pi(sk)->psm == psm &&
  188. !bacmp(&bluez_pi(sk)->src, src))
  189. break;
  190. }
  191. return sk;
  192. }
  193. /* Find socket with psm and source bdaddr.
  194.  * Returns closest match.
  195.  */
  196. static struct sock *__l2cap_get_sock_by_psm(int state, __u16 psm, bdaddr_t *src)
  197. {
  198. struct sock *sk, *sk1 = NULL;
  199. for (sk = l2cap_sk_list.head; sk; sk = sk->next) {
  200. if (state && sk->state != state)
  201. continue;
  202. if (l2cap_pi(sk)->psm == psm) {
  203. /* Exact match. */
  204. if (!bacmp(&bluez_pi(sk)->src, src))
  205. break;
  206. /* Closest match */
  207. if (!bacmp(&bluez_pi(sk)->src, BDADDR_ANY))
  208. sk1 = sk;
  209. }
  210. }
  211. return sk ? sk : sk1;
  212. }
  213. /* Find socket with given address (psm, src).
  214.  * Returns locked socket */
  215. static inline struct sock *l2cap_get_sock_by_psm(int state, __u16 psm, bdaddr_t *src)
  216. {
  217. struct sock *s;
  218. read_lock(&l2cap_sk_list.lock);
  219. s = __l2cap_get_sock_by_psm(state, psm, src);
  220. if (s) bh_lock_sock(s);
  221. read_unlock(&l2cap_sk_list.lock);
  222. return s;
  223. }
  224. static void l2cap_sock_destruct(struct sock *sk)
  225. {
  226. BT_DBG("sk %p", sk);
  227. skb_queue_purge(&sk->receive_queue);
  228. skb_queue_purge(&sk->write_queue);
  229. MOD_DEC_USE_COUNT;
  230. }
  231. static void l2cap_sock_cleanup_listen(struct sock *parent)
  232. {
  233. struct sock *sk;
  234. BT_DBG("parent %p", parent);
  235. /* Close not yet accepted channels */
  236. while ((sk = bluez_accept_dequeue(parent, NULL)))
  237. l2cap_sock_close(sk);
  238. parent->state  = BT_CLOSED;
  239. parent->zapped = 1;
  240. }
  241. /* Kill socket (only if zapped and orphan)
  242.  * Must be called on unlocked socket.
  243.  */
  244. static void l2cap_sock_kill(struct sock *sk)
  245. {
  246. if (!sk->zapped || sk->socket)
  247. return;
  248. BT_DBG("sk %p state %d", sk, sk->state);
  249. /* Kill poor orphan */
  250. bluez_sock_unlink(&l2cap_sk_list, sk);
  251. sk->dead = 1;
  252. sock_put(sk);
  253. }
  254. /* Close socket.
  255.  */
  256. static void __l2cap_sock_close(struct sock *sk, int reason)
  257. {
  258. BT_DBG("sk %p state %d socket %p", sk, sk->state, sk->socket);
  259. switch (sk->state) {
  260. case BT_LISTEN:
  261. l2cap_sock_cleanup_listen(sk);
  262. break;
  263. case BT_CONNECTED:
  264. case BT_CONFIG:
  265. case BT_CONNECT2:
  266. if (sk->type == SOCK_SEQPACKET) {
  267. struct l2cap_conn *conn = l2cap_pi(sk)->conn;
  268. l2cap_disconn_req req;
  269. sk->state = BT_DISCONN;
  270. l2cap_sock_set_timer(sk, HZ * 5);
  271. req.dcid = __cpu_to_le16(l2cap_pi(sk)->dcid);
  272. req.scid = __cpu_to_le16(l2cap_pi(sk)->scid);
  273. l2cap_send_req(conn, L2CAP_DISCONN_REQ, L2CAP_DISCONN_REQ_SIZE, &req);
  274. } else {
  275. l2cap_chan_del(sk, reason);
  276. }
  277. break;
  278. case BT_CONNECT:
  279. case BT_DISCONN:
  280. l2cap_chan_del(sk, reason);
  281. break;
  282. default:
  283. sk->zapped = 1;
  284. break;
  285. };
  286. }
  287. /* Must be called on unlocked socket. */
  288. static void l2cap_sock_close(struct sock *sk)
  289. {
  290. l2cap_sock_clear_timer(sk);
  291. lock_sock(sk);
  292. __l2cap_sock_close(sk, ECONNRESET);
  293. release_sock(sk);
  294. l2cap_sock_kill(sk);
  295. }
  296. static void l2cap_sock_init(struct sock *sk, struct sock *parent)
  297. {
  298. struct l2cap_pinfo *pi = l2cap_pi(sk);
  299. BT_DBG("sk %p", sk);
  300. if (parent) {
  301. sk->type = parent->type;
  302. pi->imtu = l2cap_pi(parent)->imtu;
  303. pi->omtu = l2cap_pi(parent)->omtu;
  304. pi->link_mode = l2cap_pi(parent)->link_mode;
  305. } else {
  306. pi->imtu = L2CAP_DEFAULT_MTU;
  307. pi->omtu = 0;
  308. pi->link_mode = 0;
  309. }
  310. /* Default config options */
  311. pi->conf_mtu = L2CAP_DEFAULT_MTU;
  312. pi->flush_to = L2CAP_DEFAULT_FLUSH_TO;
  313. }
  314. static struct sock *l2cap_sock_alloc(struct socket *sock, int proto, int prio)
  315. {
  316. struct sock *sk;
  317. if (!(sk = sk_alloc(PF_BLUETOOTH, prio, 1)))
  318. return NULL;
  319. bluez_sock_init(sock, sk);
  320. sk->zapped   = 0;
  321. sk->destruct = l2cap_sock_destruct;
  322. sk->sndtimeo = L2CAP_CONN_TIMEOUT;
  323. sk->protocol = proto;
  324. sk->state    = BT_OPEN;
  325. l2cap_sock_init_timer(sk);
  326. bluez_sock_link(&l2cap_sk_list, sk);
  327. MOD_INC_USE_COUNT;
  328. return sk;
  329. }
  330. static int l2cap_sock_create(struct socket *sock, int protocol)
  331. {
  332. struct sock *sk;
  333. BT_DBG("sock %p", sock);
  334. sock->state = SS_UNCONNECTED;
  335. if (sock->type != SOCK_SEQPACKET && sock->type != SOCK_DGRAM && sock->type != SOCK_RAW)
  336. return -ESOCKTNOSUPPORT;
  337. sock->ops = &l2cap_sock_ops;
  338. if (!(sk = l2cap_sock_alloc(sock, protocol, GFP_KERNEL)))
  339. return -ENOMEM;
  340. l2cap_sock_init(sk, NULL);
  341. return 0;
  342. }
  343. static int l2cap_sock_bind(struct socket *sock, struct sockaddr *addr, int addr_len)
  344. {
  345. struct sockaddr_l2 *la = (struct sockaddr_l2 *) addr;
  346. struct sock *sk = sock->sk;
  347. int err = 0;
  348. BT_DBG("sk %p, %s %d", sk, batostr(&la->l2_bdaddr), la->l2_psm);
  349. if (!addr || addr->sa_family != AF_BLUETOOTH)
  350. return -EINVAL;
  351. lock_sock(sk);
  352. if (sk->state != BT_OPEN) {
  353. err = -EBADFD;
  354. goto done;
  355. }
  356. write_lock_bh(&l2cap_sk_list.lock);
  357. if (la->l2_psm && __l2cap_get_sock_by_addr(la->l2_psm, &la->l2_bdaddr)) {
  358. err = -EADDRINUSE;
  359. } else {
  360. /* Save source address */
  361. bacpy(&bluez_pi(sk)->src, &la->l2_bdaddr);
  362. l2cap_pi(sk)->psm = la->l2_psm;
  363. sk->state = BT_BOUND;
  364. }
  365. write_unlock_bh(&l2cap_sk_list.lock);
  366. done:
  367. release_sock(sk);
  368. return err;
  369. }
  370. static int l2cap_sock_connect(struct socket *sock, struct sockaddr *addr, int alen, int flags)
  371. {
  372. struct sockaddr_l2 *la = (struct sockaddr_l2 *) addr;
  373. struct sock *sk = sock->sk;
  374. int err = 0;
  375. lock_sock(sk);
  376. BT_DBG("sk %p", sk);
  377. if (addr->sa_family != AF_BLUETOOTH || alen < sizeof(struct sockaddr_l2)) {
  378. err = -EINVAL;
  379. goto done;
  380. }
  381. if (sk->type == SOCK_SEQPACKET && !la->l2_psm) {
  382. err = -EINVAL;
  383. goto done;
  384. }
  385. switch(sk->state) {
  386. case BT_CONNECT:
  387. case BT_CONNECT2:
  388. case BT_CONFIG:
  389. /* Already connecting */
  390. goto wait;
  391. case BT_CONNECTED:
  392. /* Already connected */
  393. goto done;
  394. case BT_OPEN:
  395. case BT_BOUND:
  396. /* Can connect */
  397. break;
  398. default:
  399. err = -EBADFD;
  400. goto done;
  401. }
  402. /* Set destination address and psm */
  403. bacpy(&bluez_pi(sk)->dst, &la->l2_bdaddr);
  404. l2cap_pi(sk)->psm = la->l2_psm;
  405. if ((err = l2cap_connect(sk)))
  406. goto done;
  407. wait:
  408. err = bluez_sock_w4_connect(sk, flags);
  409. done:
  410. release_sock(sk);
  411. return err;
  412. }
  413. int l2cap_sock_listen(struct socket *sock, int backlog)
  414. {
  415. struct sock *sk = sock->sk;
  416. int err = 0;
  417. BT_DBG("sk %p backlog %d", sk, backlog);
  418. lock_sock(sk);
  419. if (sk->state != BT_BOUND || sock->type != SOCK_SEQPACKET) {
  420. err = -EBADFD;
  421. goto done;
  422. }
  423. if (!l2cap_pi(sk)->psm) {
  424. err = -EINVAL;
  425. goto done;
  426. }
  427. sk->max_ack_backlog = backlog;
  428. sk->ack_backlog = 0;
  429. sk->state = BT_LISTEN;
  430. done:
  431. release_sock(sk);
  432. return err;
  433. }
  434. int l2cap_sock_accept(struct socket *sock, struct socket *newsock, int flags)
  435. {
  436. DECLARE_WAITQUEUE(wait, current);
  437. struct sock *sk = sock->sk, *nsk;
  438. long timeo;
  439. int err = 0;
  440. lock_sock(sk);
  441. if (sk->state != BT_LISTEN) {
  442. err = -EBADFD;
  443. goto done;
  444. }
  445. timeo = sock_rcvtimeo(sk, flags & O_NONBLOCK);
  446. BT_DBG("sk %p timeo %ld", sk, timeo);
  447. /* Wait for an incoming connection. (wake-one). */
  448. add_wait_queue_exclusive(sk->sleep, &wait);
  449. while (!(nsk = bluez_accept_dequeue(sk, newsock))) {
  450. set_current_state(TASK_INTERRUPTIBLE);
  451. if (!timeo) {
  452. err = -EAGAIN;
  453. break;
  454. }
  455. release_sock(sk);
  456. timeo = schedule_timeout(timeo);
  457. lock_sock(sk);
  458. if (sk->state != BT_LISTEN) {
  459. err = -EBADFD;
  460. break;
  461. }
  462. if (signal_pending(current)) {
  463. err = sock_intr_errno(timeo);
  464. break;
  465. }
  466. }
  467. set_current_state(TASK_RUNNING);
  468. remove_wait_queue(sk->sleep, &wait);
  469. if (err)
  470. goto done;
  471. newsock->state = SS_CONNECTED;
  472. BT_DBG("new socket %p", nsk);
  473. done:
  474. release_sock(sk);
  475. return err;
  476. }
  477. static int l2cap_sock_getname(struct socket *sock, struct sockaddr *addr, int *len, int peer)
  478. {
  479. struct sockaddr_l2 *la = (struct sockaddr_l2 *) addr;
  480. struct sock *sk = sock->sk;
  481. BT_DBG("sock %p, sk %p", sock, sk);
  482. addr->sa_family = AF_BLUETOOTH;
  483. *len = sizeof(struct sockaddr_l2);
  484. if (peer)
  485. bacpy(&la->l2_bdaddr, &bluez_pi(sk)->dst);
  486. else
  487. bacpy(&la->l2_bdaddr, &bluez_pi(sk)->src);
  488. la->l2_psm = l2cap_pi(sk)->psm;
  489. return 0;
  490. }
  491. static int l2cap_sock_sendmsg(struct socket *sock, struct msghdr *msg, int len, struct scm_cookie *scm)
  492. {
  493. struct sock *sk = sock->sk;
  494. int err = 0;
  495. BT_DBG("sock %p, sk %p", sock, sk);
  496. if (sk->err)
  497. return sock_error(sk);
  498. if (msg->msg_flags & MSG_OOB)
  499. return -EOPNOTSUPP;
  500. /* Check outgoing MTU */
  501. if (len > l2cap_pi(sk)->omtu)
  502. return -EINVAL;
  503. lock_sock(sk);
  504. if (sk->state == BT_CONNECTED)
  505. err = l2cap_chan_send(sk, msg, len);
  506. else
  507. err = -ENOTCONN;
  508. release_sock(sk);
  509. return err;
  510. }
  511. static int l2cap_sock_setsockopt(struct socket *sock, int level, int optname, char *optval, int optlen)
  512. {
  513. struct sock *sk = sock->sk;
  514. struct l2cap_options opts;
  515. int err = 0, len;
  516. __u32 opt;
  517. BT_DBG("sk %p", sk);
  518. lock_sock(sk);
  519. switch (optname) {
  520. case L2CAP_OPTIONS:
  521. len = MIN(sizeof(opts), optlen);
  522. if (copy_from_user((char *)&opts, optval, len)) {
  523. err = -EFAULT;
  524. break;
  525. }
  526. l2cap_pi(sk)->imtu  = opts.imtu;
  527. l2cap_pi(sk)->omtu  = opts.omtu;
  528. break;
  529. case L2CAP_LM:
  530. if (get_user(opt, (__u32 *)optval)) {
  531. err = -EFAULT;
  532. break;
  533. }
  534. l2cap_pi(sk)->link_mode = opt;
  535. break;
  536. default:
  537. err = -ENOPROTOOPT;
  538. break;
  539. }
  540. release_sock(sk);
  541. return err;
  542. }
  543. static int l2cap_sock_getsockopt(struct socket *sock, int level, int optname, char *optval, int *optlen)
  544. {
  545. struct sock *sk = sock->sk;
  546. struct l2cap_options opts;
  547. struct l2cap_conninfo cinfo;
  548. int len, err = 0; 
  549. if (get_user(len, optlen))
  550. return -EFAULT;
  551. lock_sock(sk);
  552. switch (optname) {
  553. case L2CAP_OPTIONS:
  554. opts.imtu     = l2cap_pi(sk)->imtu;
  555. opts.omtu     = l2cap_pi(sk)->omtu;
  556. opts.flush_to = l2cap_pi(sk)->flush_to;
  557. len = MIN(len, sizeof(opts));
  558. if (copy_to_user(optval, (char *)&opts, len))
  559. err = -EFAULT;
  560. break;
  561. case L2CAP_LM:
  562. if (put_user(l2cap_pi(sk)->link_mode, (__u32 *)optval))
  563. err = -EFAULT;
  564. break;
  565. case L2CAP_CONNINFO:
  566. if (sk->state != BT_CONNECTED) {
  567. err = -ENOTCONN;
  568. break;
  569. }
  570. cinfo.hci_handle = l2cap_pi(sk)->conn->hcon->handle;
  571. len = MIN(len, sizeof(cinfo));
  572. if (copy_to_user(optval, (char *)&cinfo, len))
  573. err = -EFAULT;
  574. break;
  575. default:
  576. err = -ENOPROTOOPT;
  577. break;
  578. }
  579. release_sock(sk);
  580. return err;
  581. }
  582. static int l2cap_sock_shutdown(struct socket *sock, int how)
  583. {
  584. struct sock *sk = sock->sk;
  585. BT_DBG("sock %p, sk %p", sock, sk);
  586. if (!sk) return 0;
  587. l2cap_sock_clear_timer(sk);
  588. lock_sock(sk);
  589. sk->shutdown = SHUTDOWN_MASK;
  590. __l2cap_sock_close(sk, ECONNRESET);
  591. release_sock(sk);
  592. return 0;
  593. }
  594. static int l2cap_sock_release(struct socket *sock)
  595. {
  596. struct sock *sk = sock->sk;
  597. BT_DBG("sock %p, sk %p", sock, sk);
  598. if (!sk) return 0;
  599. sock_orphan(sk);
  600. l2cap_sock_close(sk);
  601. return 0;
  602. }
  603. /* --------- L2CAP channels --------- */
  604. static struct sock * __l2cap_get_chan_by_dcid(struct l2cap_chan_list *l, __u16 cid)
  605. {
  606. struct sock *s;
  607. for (s = l->head; s; s = l2cap_pi(s)->next_c) {
  608. if (l2cap_pi(s)->dcid == cid)
  609. break;
  610. }
  611. return s;
  612. }
  613. static struct sock *__l2cap_get_chan_by_scid(struct l2cap_chan_list *l, __u16 cid)
  614. {
  615. struct sock *s;
  616. for (s = l->head; s; s = l2cap_pi(s)->next_c) {
  617. if (l2cap_pi(s)->scid == cid)
  618. break;
  619. }
  620. return s;
  621. }
  622. /* Find channel with given SCID.
  623.  * Returns locked socket */
  624. static inline struct sock *l2cap_get_chan_by_scid(struct l2cap_chan_list *l, __u16 cid)
  625. {
  626. struct sock *s;
  627. read_lock(&l->lock);
  628. s = __l2cap_get_chan_by_scid(l, cid);
  629. if (s) bh_lock_sock(s);
  630. read_unlock(&l->lock);
  631. return s;
  632. }
  633. static __u16 l2cap_alloc_cid(struct l2cap_chan_list *l)
  634. {
  635. __u16 cid = 0x0040;
  636. for (; cid < 0xffff; cid++) {
  637. if(!__l2cap_get_chan_by_scid(l, cid))
  638. return cid;
  639. }
  640. return 0;
  641. }
  642. static inline void __l2cap_chan_link(struct l2cap_chan_list *l, struct sock *sk)
  643. {
  644. sock_hold(sk);
  645. if (l->head)
  646. l2cap_pi(l->head)->prev_c = sk;
  647. l2cap_pi(sk)->next_c = l->head;
  648. l2cap_pi(sk)->prev_c = NULL;
  649. l->head = sk;
  650. }
  651. static inline void l2cap_chan_unlink(struct l2cap_chan_list *l, struct sock *sk)
  652. {
  653. struct sock *next = l2cap_pi(sk)->next_c, *prev = l2cap_pi(sk)->prev_c;
  654. write_lock(&l->lock);
  655. if (sk == l->head)
  656. l->head = next;
  657. if (next)
  658. l2cap_pi(next)->prev_c = prev;
  659. if (prev)
  660. l2cap_pi(prev)->next_c = next;
  661. write_unlock(&l->lock);
  662. __sock_put(sk);
  663. }
  664. static void __l2cap_chan_add(struct l2cap_conn *conn, struct sock *sk, struct sock *parent)
  665. {
  666. struct l2cap_chan_list *l = &conn->chan_list;
  667. BT_DBG("conn %p, psm 0x%2.2x, dcid 0x%4.4x", conn, l2cap_pi(sk)->psm, l2cap_pi(sk)->dcid);
  668. l2cap_pi(sk)->conn = conn;
  669. if (sk->type == SOCK_SEQPACKET) {
  670. /* Alloc CID for connection-oriented socket */
  671. l2cap_pi(sk)->scid = l2cap_alloc_cid(l);
  672. } else if (sk->type == SOCK_DGRAM) {
  673. /* Connectionless socket */
  674. l2cap_pi(sk)->scid = 0x0002;
  675. l2cap_pi(sk)->dcid = 0x0002;
  676. l2cap_pi(sk)->omtu = L2CAP_DEFAULT_MTU;
  677. } else {
  678. /* Raw socket can send/recv signalling messages only */
  679. l2cap_pi(sk)->scid = 0x0001;
  680. l2cap_pi(sk)->dcid = 0x0001;
  681. l2cap_pi(sk)->omtu = L2CAP_DEFAULT_MTU;
  682. }
  683. __l2cap_chan_link(l, sk);
  684. if (parent)
  685. bluez_accept_enqueue(parent, sk);
  686. }
  687. static inline void l2cap_chan_add(struct l2cap_conn *conn, struct sock *sk, struct sock *parent)
  688. {
  689. struct l2cap_chan_list *l = &conn->chan_list;
  690. write_lock(&l->lock);
  691. __l2cap_chan_add(conn, sk, parent);
  692. write_unlock(&l->lock);
  693. }
  694. /* Delete channel. 
  695.  * Must be called on the locked socket. */
  696. static void l2cap_chan_del(struct sock *sk, int err)
  697. {
  698. struct l2cap_conn *conn = l2cap_pi(sk)->conn;
  699. struct sock *parent = bluez_pi(sk)->parent;
  700. l2cap_sock_clear_timer(sk);
  701. BT_DBG("sk %p, conn %p, err %d", sk, conn, err);
  702. if (conn) { 
  703. /* Unlink from channel list */
  704. l2cap_chan_unlink(&conn->chan_list, sk);
  705. l2cap_pi(sk)->conn = NULL;
  706. hci_conn_put(conn->hcon);
  707. }
  708. sk->state = BT_CLOSED;
  709. sk->err   = err;
  710. sk->zapped = 1;
  711. if (parent)
  712. parent->data_ready(parent, 0);
  713. else
  714. sk->state_change(sk);
  715. }
  716. static void l2cap_conn_ready(struct l2cap_conn *conn)
  717. {
  718. struct l2cap_chan_list *l = &conn->chan_list;
  719. struct sock *sk;
  720. BT_DBG("conn %p", conn);
  721. read_lock(&l->lock);
  722. for (sk = l->head; sk; sk = l2cap_pi(sk)->next_c) {
  723. bh_lock_sock(sk);
  724. if (sk->type != SOCK_SEQPACKET) {
  725. l2cap_sock_clear_timer(sk);
  726. sk->state = BT_CONNECTED;
  727. sk->state_change(sk);
  728. } else if (sk->state == BT_CONNECT) {
  729. l2cap_conn_req req;
  730. req.scid = __cpu_to_le16(l2cap_pi(sk)->scid);
  731. req.psm  = l2cap_pi(sk)->psm;
  732. l2cap_send_req(conn, L2CAP_CONN_REQ, L2CAP_CONN_REQ_SIZE, &req);
  733. }
  734. bh_unlock_sock(sk);
  735. }
  736. read_unlock(&l->lock);
  737. }
  738. static void l2cap_chan_ready(struct sock *sk)
  739. {
  740. struct sock *parent = bluez_pi(sk)->parent;
  741. BT_DBG("sk %p, parent %p", sk, parent);
  742. l2cap_pi(sk)->conf_state = 0;
  743. l2cap_sock_clear_timer(sk);
  744. if (!parent) {
  745. /* Outgoing channel.
  746.  * Wake up socket sleeping on connect.
  747.  */
  748. sk->state = BT_CONNECTED;
  749. sk->state_change(sk);
  750. } else {
  751. /* Incomming channel.
  752.  * Wake up socket sleeping on accept.
  753.  */
  754. parent->data_ready(parent, 0);
  755. }
  756. }
  757. /* Copy frame to all raw sockets on that connection */
  758. void l2cap_raw_recv(struct l2cap_conn *conn, struct sk_buff *skb)
  759. {
  760. struct l2cap_chan_list *l = &conn->chan_list;
  761. struct sk_buff *nskb;
  762. struct sock * sk;
  763. BT_DBG("conn %p", conn);
  764. read_lock(&l->lock);
  765. for (sk = l->head; sk; sk = l2cap_pi(sk)->next_c) {
  766. if (sk->type != SOCK_RAW)
  767. continue;
  768. /* Don't send frame to the socket it came from */
  769. if (skb->sk == sk)
  770. continue;
  771. if (!(nskb = skb_clone(skb, GFP_ATOMIC)))
  772. continue;
  773. if (sock_queue_rcv_skb(sk, nskb))
  774. kfree_skb(nskb);
  775. }
  776. read_unlock(&l->lock);
  777. }
  778. static int l2cap_chan_send(struct sock *sk, struct msghdr *msg, int len)
  779. {
  780. struct l2cap_conn *conn = l2cap_pi(sk)->conn;
  781. struct sk_buff *skb, **frag;
  782. int err, hlen, count, sent=0;
  783. l2cap_hdr *lh;
  784. BT_DBG("sk %p len %d", sk, len);
  785. /* First fragment (with L2CAP header) */
  786. if (sk->type == SOCK_DGRAM)
  787. hlen = L2CAP_HDR_SIZE + 2;
  788. else
  789. hlen = L2CAP_HDR_SIZE;
  790. count = MIN(conn->mtu - hlen, len);
  791. skb = bluez_skb_send_alloc(sk, hlen + count,
  792. msg->msg_flags & MSG_DONTWAIT, &err);
  793. if (!skb)
  794. return err;
  795. /* Create L2CAP header */
  796. lh = (l2cap_hdr *) skb_put(skb, L2CAP_HDR_SIZE);
  797. lh->cid = __cpu_to_le16(l2cap_pi(sk)->dcid);
  798. lh->len = __cpu_to_le16(len + (hlen - L2CAP_HDR_SIZE));
  799. if (sk->type == SOCK_DGRAM)
  800. put_unaligned(l2cap_pi(sk)->psm, (__u16 *) skb_put(skb, 2));
  801. if (memcpy_fromiovec(skb_put(skb, count), msg->msg_iov, count)) {
  802. err = -EFAULT;
  803. goto fail;
  804. }
  805. sent += count;
  806. len  -= count;
  807. /* Continuation fragments (no L2CAP header) */
  808. frag = &skb_shinfo(skb)->frag_list;
  809. while (len) {
  810. count = MIN(conn->mtu, len);
  811. *frag = bluez_skb_send_alloc(sk, count, msg->msg_flags & MSG_DONTWAIT, &err);
  812. if (!*frag)
  813. goto fail;
  814. if (memcpy_fromiovec(skb_put(*frag, count), msg->msg_iov, count)) {
  815. err = -EFAULT;
  816. goto fail;
  817. }
  818. sent += count;
  819. len  -= count;
  820. frag = &(*frag)->next;
  821. }
  822. if ((err = hci_send_acl(conn->hcon, skb, 0)) < 0)
  823. goto fail;
  824. return sent;
  825. fail:
  826. kfree_skb(skb);
  827. return err;
  828. }
  829. /* --------- L2CAP signalling commands --------- */
  830. static inline __u8 l2cap_get_ident(struct l2cap_conn *conn)
  831. {
  832. __u8 id;
  833. /* Get next available identificator.
  834.  *    1 - 199 are used by kernel.
  835.  *  200 - 254 are used by utilities like l2ping, etc 
  836.  */
  837. spin_lock(&conn->lock);
  838. if (++conn->tx_ident > 199)
  839. conn->tx_ident = 1;
  840. id = conn->tx_ident;
  841. spin_unlock(&conn->lock);
  842. return id;
  843. }
  844. static struct sk_buff *l2cap_build_cmd(struct l2cap_conn *conn,
  845. __u8 code, __u8 ident, __u16 dlen, void *data)
  846. {
  847. struct sk_buff *skb, **frag;
  848. l2cap_cmd_hdr *cmd;
  849. l2cap_hdr *lh;
  850. int len, count;
  851. BT_DBG("conn %p, code 0x%2.2x, ident 0x%2.2x, len %d", conn, code, ident, dlen);
  852. len = L2CAP_HDR_SIZE + L2CAP_CMD_HDR_SIZE + dlen;
  853. count = MIN(conn->mtu, len);
  854. skb = bluez_skb_alloc(count, GFP_ATOMIC);
  855. if (!skb)
  856. return NULL;
  857. lh = (l2cap_hdr *) skb_put(skb, L2CAP_HDR_SIZE);
  858. lh->len = __cpu_to_le16(L2CAP_CMD_HDR_SIZE + dlen);
  859. lh->cid = __cpu_to_le16(0x0001);
  860. cmd = (l2cap_cmd_hdr *) skb_put(skb, L2CAP_CMD_HDR_SIZE);
  861. cmd->code  = code;
  862. cmd->ident = ident;
  863. cmd->len   = __cpu_to_le16(dlen);
  864. if (dlen) {
  865. count -= L2CAP_HDR_SIZE + L2CAP_CMD_HDR_SIZE;
  866. memcpy(skb_put(skb, count), data, count);
  867. data += count;
  868. }
  869. len -= skb->len;
  870. /* Continuation fragments (no L2CAP header) */
  871. frag = &skb_shinfo(skb)->frag_list;
  872. while (len) {
  873. count = MIN(conn->mtu, len);
  874. *frag = bluez_skb_alloc(count, GFP_ATOMIC);
  875. if (!*frag)
  876. goto fail;
  877. memcpy(skb_put(*frag, count), data, count);
  878. len  -= count;
  879. data += count;
  880. frag = &(*frag)->next;
  881. }
  882. return skb;
  883. fail:
  884. kfree_skb(skb);
  885. return NULL;
  886. }
  887. static int l2cap_send_req(struct l2cap_conn *conn, __u8 code, __u16 len, void *data)
  888. {
  889. __u8 ident = l2cap_get_ident(conn);
  890. struct sk_buff *skb = l2cap_build_cmd(conn, code, ident, len, data);
  891. BT_DBG("code 0x%2.2x", code);
  892. if (!skb)
  893. return -ENOMEM;
  894. return hci_send_acl(conn->hcon, skb, 0);
  895. }
  896. static int l2cap_send_rsp(struct l2cap_conn *conn, __u8 ident, __u8 code, __u16 len, void *data)
  897. {
  898. struct sk_buff *skb = l2cap_build_cmd(conn, code, ident, len, data);
  899. BT_DBG("code 0x%2.2x", code);
  900. if (!skb)
  901. return -ENOMEM;
  902. return hci_send_acl(conn->hcon, skb, 0);
  903. }
  904. static inline int l2cap_get_conf_opt(void **ptr, int *type, int *olen, unsigned long *val)
  905. {
  906. l2cap_conf_opt *opt = *ptr;
  907. int len;
  908. len = L2CAP_CONF_OPT_SIZE + opt->len;
  909. *ptr += len;
  910. *type = opt->type;
  911. *olen = opt->len;
  912. switch (opt->len) {
  913. case 1:
  914. *val = *((__u8 *) opt->val);
  915. break;
  916. case 2:
  917. *val = __le16_to_cpu(*((__u16 *)opt->val));
  918. break;
  919. case 4:
  920. *val = __le32_to_cpu(*((__u32 *)opt->val));
  921. break;
  922. default:
  923. *val = (unsigned long) opt->val;
  924. break;
  925. };
  926. BT_DBG("type 0x%2.2x len %d val 0x%lx", *type, opt->len, *val);
  927. return len;
  928. }
  929. static inline void l2cap_parse_conf_req(struct sock *sk, void *data, int len)
  930. {
  931. int type, hint, olen; 
  932. unsigned long val;
  933. void *ptr = data;
  934. BT_DBG("sk %p len %d", sk, len);
  935. while (len >= L2CAP_CONF_OPT_SIZE) {
  936. len -= l2cap_get_conf_opt(&ptr, &type, &olen, &val);
  937. hint  = type & 0x80;
  938. type &= 0x7f;
  939. switch (type) {
  940. case L2CAP_CONF_MTU:
  941. l2cap_pi(sk)->conf_mtu = val;
  942. break;
  943. case L2CAP_CONF_FLUSH_TO:
  944. l2cap_pi(sk)->flush_to = val;
  945. break;
  946. case L2CAP_CONF_QOS:
  947. break;
  948. default:
  949. if (hint)
  950. break;
  951. /* FIXME: Reject unknown option */
  952. break;
  953. };
  954. }
  955. }
  956. static void l2cap_add_conf_opt(void **ptr, __u8 type, __u8 len, unsigned long val)
  957. {
  958. register l2cap_conf_opt *opt = *ptr;
  959. BT_DBG("type 0x%2.2x len %d val 0x%lx", type, len, val);
  960. opt->type = type;
  961. opt->len  = len;
  962. switch (len) {
  963. case 1:
  964. *((__u8 *) opt->val)  = val;
  965. break;
  966. case 2:
  967. *((__u16 *) opt->val) = __cpu_to_le16(val);
  968. break;
  969. case 4:
  970. *((__u32 *) opt->val) = __cpu_to_le32(val);
  971. break;
  972. default:
  973. memcpy(opt->val, (void *) val, len);
  974. break;
  975. };
  976. *ptr += L2CAP_CONF_OPT_SIZE + len;
  977. }
  978. static int l2cap_build_conf_req(struct sock *sk, void *data)
  979. {
  980. struct l2cap_pinfo *pi = l2cap_pi(sk);
  981. l2cap_conf_req *req = (l2cap_conf_req *) data;
  982. void *ptr = req->data;
  983. BT_DBG("sk %p", sk);
  984. if (pi->imtu != L2CAP_DEFAULT_MTU)
  985. l2cap_add_conf_opt(&ptr, L2CAP_CONF_MTU, 2, pi->imtu);
  986. /* FIXME. Need actual value of the flush timeout */
  987. //if (flush_to != L2CAP_DEFAULT_FLUSH_TO)
  988. //   l2cap_add_conf_opt(&ptr, L2CAP_CONF_FLUSH_TO, 2, pi->flush_to);
  989. req->dcid  = __cpu_to_le16(pi->dcid);
  990. req->flags = __cpu_to_le16(0);
  991. return ptr - data;
  992. }
  993. static inline int l2cap_conf_output(struct sock *sk, void **ptr)
  994. {
  995. struct l2cap_pinfo *pi = l2cap_pi(sk);
  996. int result = 0;
  997. /* Configure output options and let the other side know
  998.  * which ones we don't like.
  999.  */
  1000. if (pi->conf_mtu < pi->omtu) {
  1001. l2cap_add_conf_opt(ptr, L2CAP_CONF_MTU, 2, pi->omtu);
  1002. result = L2CAP_CONF_UNACCEPT;
  1003. } else {
  1004. pi->omtu = pi->conf_mtu;
  1005. }
  1006. BT_DBG("sk %p result %d", sk, result);
  1007. return result;
  1008. }
  1009. static int l2cap_build_conf_rsp(struct sock *sk, void *data, int *result)
  1010. {
  1011. l2cap_conf_rsp *rsp = (l2cap_conf_rsp *) data;
  1012. void *ptr = rsp->data;
  1013. BT_DBG("sk %p complete %d", sk, result ? 1 : 0);
  1014. if (result)
  1015. *result = l2cap_conf_output(sk, &ptr);
  1016. rsp->scid   = __cpu_to_le16(l2cap_pi(sk)->dcid);
  1017. rsp->result = __cpu_to_le16(result ? *result : 0);
  1018. rsp->flags  = __cpu_to_le16(0);
  1019. return ptr - data;
  1020. }
  1021. static inline int l2cap_connect_req(struct l2cap_conn *conn, l2cap_cmd_hdr *cmd, __u8 *data)
  1022. {
  1023. struct l2cap_chan_list *list = &conn->chan_list;
  1024. l2cap_conn_req *req = (l2cap_conn_req *) data;
  1025. l2cap_conn_rsp rsp;
  1026. struct sock *sk, *parent;
  1027. int result = 0, status = 0;
  1028. __u16 dcid = 0, scid = __le16_to_cpu(req->scid);
  1029. __u16 psm  = req->psm;
  1030. BT_DBG("psm 0x%2.2x scid 0x%4.4x", psm, scid);
  1031. /* Check if we have socket listening on psm */
  1032. parent = l2cap_get_sock_by_psm(BT_LISTEN, psm, conn->src);
  1033. if (!parent) {
  1034. result = L2CAP_CR_BAD_PSM;
  1035. goto sendresp;
  1036. }
  1037. result = L2CAP_CR_NO_MEM;
  1038. /* Check for backlog size */
  1039. if (parent->ack_backlog > parent->max_ack_backlog) {
  1040. BT_DBG("backlog full %d", parent->ack_backlog); 
  1041. goto response;
  1042. }
  1043. sk = l2cap_sock_alloc(NULL, BTPROTO_L2CAP, GFP_ATOMIC);
  1044. if (!sk)
  1045. goto response;
  1046. write_lock(&list->lock);
  1047. /* Check if we already have channel with that dcid */
  1048. if (__l2cap_get_chan_by_dcid(list, scid)) {
  1049. write_unlock(&list->lock);
  1050. sk->zapped = 1;
  1051. l2cap_sock_kill(sk);
  1052. goto response;
  1053. }
  1054. hci_conn_hold(conn->hcon);
  1055. l2cap_sock_init(sk, parent);
  1056. bacpy(&bluez_pi(sk)->src, conn->src);
  1057. bacpy(&bluez_pi(sk)->dst, conn->dst);
  1058. l2cap_pi(sk)->psm  = psm;
  1059. l2cap_pi(sk)->dcid = scid;
  1060. __l2cap_chan_add(conn, sk, parent);
  1061. dcid = l2cap_pi(sk)->scid;
  1062. l2cap_sock_set_timer(sk, sk->sndtimeo);
  1063. /* Service level security */
  1064. result = L2CAP_CR_PEND;
  1065. status = L2CAP_CS_AUTHEN_PEND;
  1066. sk->state = BT_CONNECT2;
  1067. l2cap_pi(sk)->ident = cmd->ident;
  1068. if (l2cap_pi(sk)->link_mode & L2CAP_LM_ENCRYPT) {
  1069. if (!hci_conn_encrypt(conn->hcon))
  1070. goto done;
  1071. } else if (l2cap_pi(sk)->link_mode & L2CAP_LM_AUTH) {
  1072. if (!hci_conn_auth(conn->hcon))
  1073. goto done;
  1074. }
  1075. sk->state = BT_CONFIG;
  1076. result = status = 0;
  1077. done:
  1078. write_unlock(&list->lock);
  1079. response:
  1080. bh_unlock_sock(parent);
  1081. sendresp:
  1082. rsp.scid   = __cpu_to_le16(scid);
  1083. rsp.dcid   = __cpu_to_le16(dcid);
  1084. rsp.result = __cpu_to_le16(result);
  1085. rsp.status = __cpu_to_le16(status);
  1086. l2cap_send_rsp(conn, cmd->ident, L2CAP_CONN_RSP, L2CAP_CONN_RSP_SIZE, &rsp);
  1087. return 0;
  1088. }
  1089. static inline int l2cap_connect_rsp(struct l2cap_conn *conn, l2cap_cmd_hdr *cmd, __u8 *data)
  1090. {
  1091. l2cap_conn_rsp *rsp = (l2cap_conn_rsp *) data;
  1092. __u16 scid, dcid, result, status;
  1093. struct sock *sk;
  1094. char req[128];
  1095. scid   = __le16_to_cpu(rsp->scid);
  1096. dcid   = __le16_to_cpu(rsp->dcid);
  1097. result = __le16_to_cpu(rsp->result);
  1098. status = __le16_to_cpu(rsp->status);
  1099. BT_DBG("dcid 0x%4.4x scid 0x%4.4x result 0x%2.2x status 0x%2.2x", dcid, scid, result, status);
  1100. if (!(sk = l2cap_get_chan_by_scid(&conn->chan_list, scid)))
  1101. return -ENOENT;
  1102. switch (result) {
  1103. case L2CAP_CR_SUCCESS:
  1104. sk->state = BT_CONFIG;
  1105. l2cap_pi(sk)->dcid = dcid;
  1106. l2cap_pi(sk)->conf_state |= CONF_REQ_SENT;
  1107. l2cap_send_req(conn, L2CAP_CONF_REQ, l2cap_build_conf_req(sk, req), req);
  1108. break;
  1109. case L2CAP_CR_PEND:
  1110. break;
  1111. default:
  1112. l2cap_chan_del(sk, ECONNREFUSED);
  1113. break;
  1114. }
  1115. bh_unlock_sock(sk);
  1116. return 0;
  1117. }
  1118. static inline int l2cap_config_req(struct l2cap_conn *conn, l2cap_cmd_hdr *cmd, __u8 *data)
  1119. {
  1120. l2cap_conf_req * req = (l2cap_conf_req *) data;
  1121. __u16 dcid, flags;
  1122. __u8 rsp[64];
  1123. struct sock *sk;
  1124. int result;
  1125. dcid  = __le16_to_cpu(req->dcid);
  1126. flags = __le16_to_cpu(req->flags);
  1127. BT_DBG("dcid 0x%4.4x flags 0x%2.2x", dcid, flags);
  1128. if (!(sk = l2cap_get_chan_by_scid(&conn->chan_list, dcid)))
  1129. return -ENOENT;
  1130. l2cap_parse_conf_req(sk, req->data, cmd->len - L2CAP_CONF_REQ_SIZE);
  1131. if (flags & 0x01) {
  1132. /* Incomplete config. Send empty response. */
  1133. l2cap_send_rsp(conn, cmd->ident, L2CAP_CONF_RSP, l2cap_build_conf_rsp(sk, rsp, NULL), rsp);
  1134. goto unlock;
  1135. }
  1136. /* Complete config. */
  1137. l2cap_send_rsp(conn, cmd->ident, L2CAP_CONF_RSP, l2cap_build_conf_rsp(sk, rsp, &result), rsp);
  1138. if (result)
  1139. goto unlock;
  1140. /* Output config done */
  1141. l2cap_pi(sk)->conf_state |= CONF_OUTPUT_DONE;
  1142. if (l2cap_pi(sk)->conf_state & CONF_INPUT_DONE) {
  1143. sk->state = BT_CONNECTED;
  1144. l2cap_chan_ready(sk);
  1145. } else if (!(l2cap_pi(sk)->conf_state & CONF_REQ_SENT)) {
  1146. char req[64];
  1147. l2cap_send_req(conn, L2CAP_CONF_REQ, l2cap_build_conf_req(sk, req), req);
  1148. }
  1149. unlock:
  1150. bh_unlock_sock(sk);
  1151. return 0;
  1152. }
  1153. static inline int l2cap_config_rsp(struct l2cap_conn *conn, l2cap_cmd_hdr *cmd, __u8 *data)
  1154. {
  1155. l2cap_conf_rsp *rsp = (l2cap_conf_rsp *)data;
  1156. __u16 scid, flags, result;
  1157. struct sock *sk;
  1158. int err = 0;
  1159. scid   = __le16_to_cpu(rsp->scid);
  1160. flags  = __le16_to_cpu(rsp->flags);
  1161. result = __le16_to_cpu(rsp->result);
  1162. BT_DBG("scid 0x%4.4x flags 0x%2.2x result 0x%2.2x", scid, flags, result);
  1163. if (!(sk = l2cap_get_chan_by_scid(&conn->chan_list, scid)))
  1164. return -ENOENT;
  1165. if (result) {
  1166. l2cap_disconn_req req;
  1167. /* They didn't like our options. Well... we do not negotiate.
  1168.  * Close channel.
  1169.  */
  1170. sk->state = BT_DISCONN;
  1171. l2cap_sock_set_timer(sk, HZ * 5);
  1172. req.dcid = __cpu_to_le16(l2cap_pi(sk)->dcid);
  1173. req.scid = __cpu_to_le16(l2cap_pi(sk)->scid);
  1174. l2cap_send_req(conn, L2CAP_DISCONN_REQ, L2CAP_DISCONN_REQ_SIZE, &req);
  1175. goto done;
  1176. }
  1177. if (flags & 0x01)
  1178. goto done;
  1179. /* Input config done */
  1180. l2cap_pi(sk)->conf_state |= CONF_INPUT_DONE;
  1181. if (l2cap_pi(sk)->conf_state & CONF_OUTPUT_DONE) {
  1182. sk->state = BT_CONNECTED;
  1183. l2cap_chan_ready(sk);
  1184. }
  1185. done:
  1186. bh_unlock_sock(sk);
  1187. return err;
  1188. }
  1189. static inline int l2cap_disconnect_req(struct l2cap_conn *conn, l2cap_cmd_hdr *cmd, __u8 *data)
  1190. {
  1191. l2cap_disconn_req *req = (l2cap_disconn_req *) data;
  1192. l2cap_disconn_rsp rsp;
  1193. __u16 dcid, scid;
  1194. struct sock *sk;
  1195. scid = __le16_to_cpu(req->scid);
  1196. dcid = __le16_to_cpu(req->dcid);
  1197. BT_DBG("scid 0x%4.4x dcid 0x%4.4x", scid, dcid);
  1198. if (!(sk = l2cap_get_chan_by_scid(&conn->chan_list, dcid)))
  1199. return 0;
  1200. rsp.dcid = __cpu_to_le16(l2cap_pi(sk)->scid);
  1201. rsp.scid = __cpu_to_le16(l2cap_pi(sk)->dcid);
  1202. l2cap_send_rsp(conn, cmd->ident, L2CAP_DISCONN_RSP, L2CAP_DISCONN_RSP_SIZE, &rsp);
  1203. sk->shutdown = SHUTDOWN_MASK;
  1204. l2cap_chan_del(sk, ECONNRESET);
  1205. bh_unlock_sock(sk);
  1206. l2cap_sock_kill(sk);
  1207. return 0;
  1208. }
  1209. static inline int l2cap_disconnect_rsp(struct l2cap_conn *conn, l2cap_cmd_hdr *cmd, __u8 *data)
  1210. {
  1211. l2cap_disconn_rsp *rsp = (l2cap_disconn_rsp *) data;
  1212. __u16 dcid, scid;
  1213. struct sock *sk;
  1214. scid = __le16_to_cpu(rsp->scid);
  1215. dcid = __le16_to_cpu(rsp->dcid);
  1216. BT_DBG("dcid 0x%4.4x scid 0x%4.4x", dcid, scid);
  1217. if (!(sk = l2cap_get_chan_by_scid(&conn->chan_list, scid)))
  1218. return 0;
  1219. l2cap_chan_del(sk, ECONNABORTED);
  1220. bh_unlock_sock(sk);
  1221. l2cap_sock_kill(sk);
  1222. return 0;
  1223. }
  1224. static inline void l2cap_sig_channel(struct l2cap_conn *conn, struct sk_buff *skb)
  1225. {
  1226. __u8 *data = skb->data;
  1227. int len = skb->len;
  1228. l2cap_cmd_hdr cmd;
  1229. int err = 0;
  1230. while (len >= L2CAP_CMD_HDR_SIZE) {
  1231. memcpy(&cmd, data, L2CAP_CMD_HDR_SIZE);
  1232. data += L2CAP_CMD_HDR_SIZE;
  1233. len  -= L2CAP_CMD_HDR_SIZE;
  1234. cmd.len = __le16_to_cpu(cmd.len);
  1235. BT_DBG("code 0x%2.2x len %d id 0x%2.2x", cmd.code, cmd.len, cmd.ident);
  1236. if (cmd.len > len || !cmd.ident) {
  1237. BT_DBG("corrupted command");
  1238. break;
  1239. }
  1240. switch (cmd.code) {
  1241. case L2CAP_CONN_REQ:
  1242. err = l2cap_connect_req(conn, &cmd, data);
  1243. break;
  1244. case L2CAP_CONN_RSP:
  1245. err = l2cap_connect_rsp(conn, &cmd, data);
  1246. break;
  1247. case L2CAP_CONF_REQ:
  1248. err = l2cap_config_req(conn, &cmd, data);
  1249. break;
  1250. case L2CAP_CONF_RSP:
  1251. err = l2cap_config_rsp(conn, &cmd, data);
  1252. break;
  1253. case L2CAP_DISCONN_REQ:
  1254. err = l2cap_disconnect_req(conn, &cmd, data);
  1255. break;
  1256. case L2CAP_DISCONN_RSP:
  1257. err = l2cap_disconnect_rsp(conn, &cmd, data);
  1258. break;
  1259. case L2CAP_COMMAND_REJ:
  1260. /* FIXME: We should process this */
  1261. l2cap_raw_recv(conn, skb);
  1262. break;
  1263. case L2CAP_ECHO_REQ:
  1264. l2cap_send_rsp(conn, cmd.ident, L2CAP_ECHO_RSP, cmd.len, data);
  1265. break;
  1266. case L2CAP_ECHO_RSP:
  1267. case L2CAP_INFO_REQ:
  1268. case L2CAP_INFO_RSP:
  1269. l2cap_raw_recv(conn, skb);
  1270. break;
  1271. default:
  1272. BT_ERR("Uknown signaling command 0x%2.2x", cmd.code);
  1273. err = -EINVAL;
  1274. break;
  1275. };
  1276. if (err) {
  1277. l2cap_cmd_rej rej;
  1278. BT_DBG("error %d", err);
  1279. /* FIXME: Map err to a valid reason. */
  1280. rej.reason = __cpu_to_le16(0);
  1281. l2cap_send_rsp(conn, cmd.ident, L2CAP_COMMAND_REJ, L2CAP_CMD_REJ_SIZE, &rej);
  1282. }
  1283. data += cmd.len;
  1284. len  -= cmd.len;
  1285. }
  1286. kfree_skb(skb);
  1287. }
  1288. static inline int l2cap_data_channel(struct l2cap_conn *conn, __u16 cid, struct sk_buff *skb)
  1289. {
  1290. struct sock *sk;
  1291. sk = l2cap_get_chan_by_scid(&conn->chan_list, cid);
  1292. if (!sk) {
  1293. BT_DBG("unknown cid 0x%4.4x", cid);
  1294. goto drop;
  1295. }
  1296. BT_DBG("sk %p, len %d", sk, skb->len);
  1297. if (sk->state != BT_CONNECTED)
  1298. goto drop;
  1299. if (l2cap_pi(sk)->imtu < skb->len)
  1300. goto drop;
  1301. /* If socket recv buffers overflows we drop data here 
  1302.  * which is *bad* because L2CAP has to be reliable. 
  1303.  * But we don't have any other choice. L2CAP doesn't 
  1304.  * provide flow control mechanism */ 
  1305. if (!sock_queue_rcv_skb(sk, skb))
  1306. goto done;
  1307. drop:
  1308. kfree_skb(skb);
  1309. done:
  1310. if (sk) bh_unlock_sock(sk);
  1311. return 0;
  1312. }
  1313. static inline int l2cap_conless_channel(struct l2cap_conn *conn, __u16 psm, struct sk_buff *skb)
  1314. {
  1315. struct sock *sk;
  1316. sk = l2cap_get_sock_by_psm(0, psm, conn->src);
  1317. if (!sk)
  1318. goto drop;
  1319. BT_DBG("sk %p, len %d", sk, skb->len);
  1320. if (sk->state != BT_BOUND && sk->state != BT_CONNECTED)
  1321. goto drop;
  1322. if (l2cap_pi(sk)->imtu < skb->len)
  1323. goto drop;
  1324. if (!sock_queue_rcv_skb(sk, skb))
  1325. goto done;
  1326. drop:
  1327. kfree_skb(skb);
  1328. done:
  1329. if (sk) bh_unlock_sock(sk);
  1330. return 0;
  1331. }
  1332. static void l2cap_recv_frame(struct l2cap_conn *conn, struct sk_buff *skb)
  1333. {
  1334. l2cap_hdr *lh = (l2cap_hdr *) skb->data;
  1335. __u16 cid, psm, len;
  1336. skb_pull(skb, L2CAP_HDR_SIZE);
  1337. cid = __le16_to_cpu(lh->cid);
  1338. len = __le16_to_cpu(lh->len);
  1339. BT_DBG("len %d, cid 0x%4.4x", len, cid);
  1340. switch (cid) {
  1341. case 0x0001:
  1342. l2cap_sig_channel(conn, skb);
  1343. break;
  1344. case 0x0002:
  1345. psm = get_unaligned((__u16 *) skb->data);
  1346. skb_pull(skb, 2);
  1347. l2cap_conless_channel(conn, psm, skb);
  1348. break;
  1349. default:
  1350. l2cap_data_channel(conn, cid, skb);
  1351. break;
  1352. }
  1353. }
  1354. /* ------------ L2CAP interface with lower layer (HCI) ------------- */
  1355. static int l2cap_connect_ind(struct hci_dev *hdev, bdaddr_t *bdaddr, __u8 type)
  1356. {
  1357. int exact = 0, lm1 = 0, lm2 = 0;
  1358. register struct sock *sk;
  1359. if (type != ACL_LINK)
  1360. return 0;
  1361. BT_DBG("hdev %s, bdaddr %s", hdev->name, batostr(bdaddr));
  1362. /* Find listening sockets and check their link_mode */
  1363. read_lock(&l2cap_sk_list.lock);
  1364. for (sk = l2cap_sk_list.head; sk; sk = sk->next) {
  1365. if (sk->state != BT_LISTEN)
  1366. continue;
  1367. if (!bacmp(&bluez_pi(sk)->src, bdaddr)) {
  1368. lm1 |= (HCI_LM_ACCEPT | l2cap_pi(sk)->link_mode);
  1369. exact++;
  1370. } else if (!bacmp(&bluez_pi(sk)->src, BDADDR_ANY))
  1371. lm2 |= (HCI_LM_ACCEPT | l2cap_pi(sk)->link_mode);
  1372. }
  1373. read_unlock(&l2cap_sk_list.lock);
  1374. return exact ? lm1 : lm2;
  1375. }
  1376. static int l2cap_connect_cfm(struct hci_conn *hcon, __u8 status)
  1377. {
  1378. BT_DBG("hcon %p bdaddr %s status %d", hcon, batostr(&hcon->dst), status);
  1379. if (hcon->type != ACL_LINK)
  1380. return 0;
  1381. if (!status) {
  1382. struct l2cap_conn *conn;
  1383. conn = l2cap_conn_add(hcon, status);
  1384. if (conn)
  1385. l2cap_conn_ready(conn);
  1386. } else 
  1387. l2cap_conn_del(hcon, bterr(status));
  1388. return 0;
  1389. }
  1390. static int l2cap_disconn_ind(struct hci_conn *hcon, __u8 reason)
  1391. {
  1392. BT_DBG("hcon %p reason %d", hcon, reason);
  1393. if (hcon->type != ACL_LINK)
  1394. return 0;
  1395. l2cap_conn_del(hcon, bterr(reason));
  1396. return 0;
  1397. }
  1398. static int l2cap_auth_cfm(struct hci_conn *hcon, __u8 status)
  1399. {
  1400. struct l2cap_chan_list *l;
  1401. struct l2cap_conn *conn;
  1402. l2cap_conn_rsp rsp;
  1403. struct sock *sk;
  1404. int result;
  1405. if (!(conn = hcon->l2cap_data))
  1406. return 0;
  1407. l = &conn->chan_list;
  1408. BT_DBG("conn %p", conn);
  1409. read_lock(&l->lock);
  1410. for (sk = l->head; sk; sk = l2cap_pi(sk)->next_c) {
  1411. bh_lock_sock(sk);
  1412. if (sk->state != BT_CONNECT2 ||
  1413. (l2cap_pi(sk)->link_mode & L2CAP_LM_ENCRYPT)) {
  1414. bh_unlock_sock(sk);
  1415. continue;
  1416. }
  1417. if (!status) {
  1418. sk->state = BT_CONFIG;
  1419. result = 0;
  1420. } else {
  1421. sk->state = BT_DISCONN;
  1422. l2cap_sock_set_timer(sk, HZ/10);
  1423. result = L2CAP_CR_SEC_BLOCK;
  1424. }
  1425. rsp.scid   = __cpu_to_le16(l2cap_pi(sk)->dcid);
  1426. rsp.dcid   = __cpu_to_le16(l2cap_pi(sk)->scid);
  1427. rsp.result = __cpu_to_le16(result);
  1428. rsp.status = __cpu_to_le16(0);
  1429. l2cap_send_rsp(conn, l2cap_pi(sk)->ident, L2CAP_CONN_RSP,
  1430. L2CAP_CONN_RSP_SIZE, &rsp);
  1431. bh_unlock_sock(sk);
  1432. }
  1433. read_unlock(&l->lock);
  1434. return 0;
  1435. }
  1436. static int l2cap_encrypt_cfm(struct hci_conn *hcon, __u8 status)
  1437. {
  1438. struct l2cap_chan_list *l;
  1439. struct l2cap_conn *conn;
  1440. l2cap_conn_rsp rsp;
  1441. struct sock *sk;
  1442. int result;
  1443. if (!(conn = hcon->l2cap_data))
  1444. return 0;
  1445. l = &conn->chan_list;
  1446. BT_DBG("conn %p", conn);
  1447. read_lock(&l->lock);
  1448. for (sk = l->head; sk; sk = l2cap_pi(sk)->next_c) {
  1449. bh_lock_sock(sk);
  1450. if (sk->state != BT_CONNECT2) {
  1451. bh_unlock_sock(sk);
  1452. continue;
  1453. }
  1454. if (!status) {
  1455. sk->state = BT_CONFIG;
  1456. result = 0;
  1457. } else {
  1458. sk->state = BT_DISCONN;
  1459. l2cap_sock_set_timer(sk, HZ/10);
  1460. result = L2CAP_CR_SEC_BLOCK;
  1461. }
  1462. rsp.scid   = __cpu_to_le16(l2cap_pi(sk)->dcid);
  1463. rsp.dcid   = __cpu_to_le16(l2cap_pi(sk)->scid);
  1464. rsp.result = __cpu_to_le16(result);
  1465. rsp.status = __cpu_to_le16(0);
  1466. l2cap_send_rsp(conn, l2cap_pi(sk)->ident, L2CAP_CONN_RSP, 
  1467. L2CAP_CONN_RSP_SIZE, &rsp);
  1468. bh_unlock_sock(sk);
  1469. }
  1470. read_unlock(&l->lock);
  1471. return 0;
  1472. }
  1473. static int l2cap_recv_acldata(struct hci_conn *hcon, struct sk_buff *skb, __u16 flags)
  1474. {
  1475. struct l2cap_conn *conn = hcon->l2cap_data;
  1476. if (!conn && !(conn = l2cap_conn_add(hcon, 0)))
  1477. goto drop;
  1478. BT_DBG("conn %p len %d flags 0x%x", conn, skb->len, flags);
  1479. if (flags & ACL_START) {
  1480. l2cap_hdr *hdr;
  1481. int len;
  1482. if (conn->rx_len) {
  1483. BT_ERR("Unexpected start frame (len %d)", skb->len);
  1484. kfree_skb(conn->rx_skb);
  1485. conn->rx_skb = NULL;
  1486. conn->rx_len = 0;
  1487. }
  1488. if (skb->len < 2) {
  1489. BT_ERR("Frame is too small (len %d)", skb->len);
  1490. goto drop;
  1491. }
  1492. hdr = (l2cap_hdr *) skb->data;
  1493. len = __le16_to_cpu(hdr->len) + L2CAP_HDR_SIZE;
  1494. BT_DBG("Start: total len %d, frag len %d", len, skb->len);
  1495. if (len == skb->len) {
  1496. /* Complete frame received */
  1497. l2cap_recv_frame(conn, skb);
  1498. return 0;
  1499. }
  1500. /* Allocate skb for the complete frame (with header) */
  1501. if (!(conn->rx_skb = bluez_skb_alloc(len, GFP_ATOMIC)))
  1502. goto drop;
  1503. memcpy(skb_put(conn->rx_skb, skb->len), skb->data, skb->len);
  1504. conn->rx_len = len - skb->len;
  1505. } else {
  1506. BT_DBG("Cont: frag len %d (expecting %d)", skb->len, conn->rx_len);
  1507. if (!conn->rx_len) {
  1508. BT_ERR("Unexpected continuation frame (len %d)", skb->len);
  1509. goto drop;
  1510. }
  1511. if (skb->len > conn->rx_len) {
  1512. BT_ERR("Fragment is too large (len %d, expect %d)",
  1513. skb->len, conn->rx_len);
  1514. kfree_skb(conn->rx_skb);
  1515. conn->rx_skb = NULL;
  1516. conn->rx_len = 0;
  1517. goto drop;
  1518. }
  1519. memcpy(skb_put(conn->rx_skb, skb->len), skb->data, skb->len);
  1520. conn->rx_len -= skb->len;
  1521. if (!conn->rx_len) {
  1522. /* Complete frame received */
  1523. l2cap_recv_frame(conn, conn->rx_skb);
  1524. conn->rx_skb = NULL;
  1525. }
  1526. }
  1527. drop:
  1528. kfree_skb(skb);
  1529. return 0;
  1530. }
  1531. /* ----- Proc fs support ------ */
  1532. static int l2cap_sock_dump(char *buf, struct bluez_sock_list *list)
  1533. {
  1534. struct l2cap_pinfo *pi;
  1535. struct sock *sk;
  1536. char *ptr = buf;
  1537. read_lock_bh(&list->lock);
  1538. for (sk = list->head; sk; sk = sk->next) {
  1539. pi = l2cap_pi(sk);
  1540. ptr += sprintf(ptr, "%s %s %d %d 0x%4.4x 0x%4.4x %d %d 0x%xn",
  1541. batostr(&bluez_pi(sk)->src), batostr(&bluez_pi(sk)->dst), 
  1542. sk->state, pi->psm, pi->scid, pi->dcid, pi->imtu, pi->omtu,
  1543. pi->link_mode);
  1544. }
  1545. read_unlock_bh(&list->lock);
  1546. ptr += sprintf(ptr, "n");
  1547. return ptr - buf;
  1548. }
  1549. static int l2cap_read_proc(char *buf, char **start, off_t offset, int count, int *eof, void *priv)
  1550. {
  1551. char *ptr = buf;
  1552. int len;
  1553. BT_DBG("count %d, offset %ld", count, offset);
  1554. ptr += l2cap_sock_dump(ptr, &l2cap_sk_list);
  1555. len  = ptr - buf;
  1556. if (len <= count + offset)
  1557. *eof = 1;
  1558. *start = buf + offset;
  1559. len -= offset;
  1560. if (len > count)
  1561. len = count;
  1562. if (len < 0)
  1563. len = 0;
  1564. return len;
  1565. }
  1566. static struct proto_ops l2cap_sock_ops = {
  1567. family: PF_BLUETOOTH,
  1568. release: l2cap_sock_release,
  1569. bind: l2cap_sock_bind,
  1570. connect: l2cap_sock_connect,
  1571. listen: l2cap_sock_listen,
  1572. accept: l2cap_sock_accept,
  1573. getname: l2cap_sock_getname,
  1574. sendmsg: l2cap_sock_sendmsg,
  1575. recvmsg: bluez_sock_recvmsg,
  1576. poll: bluez_sock_poll,
  1577. socketpair: sock_no_socketpair,
  1578. ioctl: sock_no_ioctl,
  1579. shutdown: l2cap_sock_shutdown,
  1580. setsockopt: l2cap_sock_setsockopt,
  1581. getsockopt: l2cap_sock_getsockopt,
  1582. mmap: sock_no_mmap
  1583. };
  1584. static struct net_proto_family l2cap_sock_family_ops = {
  1585. family: PF_BLUETOOTH,
  1586. create: l2cap_sock_create
  1587. };
  1588. static struct hci_proto l2cap_hci_proto = {
  1589. name: "L2CAP",
  1590. id: HCI_PROTO_L2CAP,
  1591. connect_ind: l2cap_connect_ind,
  1592. connect_cfm: l2cap_connect_cfm,
  1593. disconn_ind: l2cap_disconn_ind,
  1594. recv_acldata: l2cap_recv_acldata,
  1595. auth_cfm: l2cap_auth_cfm,
  1596. encrypt_cfm: l2cap_encrypt_cfm
  1597. };
  1598. int __init l2cap_init(void)
  1599. {
  1600. int err;
  1601. if ((err = bluez_sock_register(BTPROTO_L2CAP, &l2cap_sock_family_ops))) {
  1602. BT_ERR("Can't register L2CAP socket");
  1603. return err;
  1604. }
  1605. if ((err = hci_register_proto(&l2cap_hci_proto))) {
  1606. BT_ERR("Can't register L2CAP protocol");
  1607. return err;
  1608. }
  1609. create_proc_read_entry("bluetooth/l2cap", 0, 0, l2cap_read_proc, NULL);
  1610. BT_INFO("BlueZ L2CAP ver %s Copyright (C) 2000,2001 Qualcomm Inc", VERSION);
  1611. BT_INFO("Written 2000,2001 by Maxim Krasnyansky <maxk@qualcomm.com>");
  1612. return 0;
  1613. }
  1614. void l2cap_cleanup(void)
  1615. {
  1616. remove_proc_entry("bluetooth/l2cap", NULL);
  1617. /* Unregister socket and protocol */
  1618. if (bluez_sock_unregister(BTPROTO_L2CAP))
  1619. BT_ERR("Can't unregister L2CAP socket");
  1620. if (hci_unregister_proto(&l2cap_hci_proto))
  1621. BT_ERR("Can't unregister L2CAP protocol");
  1622. }
  1623. module_init(l2cap_init);
  1624. module_exit(l2cap_cleanup);
  1625. MODULE_AUTHOR("Maxim Krasnyansky <maxk@qualcomm.com>");
  1626. MODULE_DESCRIPTION("BlueZ L2CAP ver " VERSION);
  1627. MODULE_LICENSE("GPL");