l2cap_core.c 107.3 KB
Newer Older
1
/*
L
Linus Torvalds 已提交
2 3
   BlueZ - Bluetooth protocol stack for Linux
   Copyright (C) 2000-2001 Qualcomm Incorporated
4
   Copyright (C) 2009-2010 Gustavo F. Padovan <gustavo@padovan.org>
5
   Copyright (C) 2010 Google Inc.
6
   Copyright (C) 2011 ProFUSION Embedded Systems
L
Linus Torvalds 已提交
7 8 9 10 11 12 13 14 15 16 17

   Written 2000,2001 by Maxim Krasnyansky <maxk@qualcomm.com>

   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License version 2 as
   published by the Free Software Foundation;

   THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
   OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
   FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS.
   IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) AND AUTHOR(S) BE LIABLE FOR ANY
18 19 20
   CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES
   WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
   ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
L
Linus Torvalds 已提交
21 22
   OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.

23 24
   ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS,
   COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS, RELATING TO USE OF THIS
L
Linus Torvalds 已提交
25 26 27
   SOFTWARE IS DISCLAIMED.
*/

28
/* Bluetooth L2CAP core. */
L
Linus Torvalds 已提交
29 30 31 32

#include <linux/module.h>

#include <linux/types.h>
33
#include <linux/capability.h>
L
Linus Torvalds 已提交
34 35 36 37 38 39 40 41 42 43 44
#include <linux/errno.h>
#include <linux/kernel.h>
#include <linux/sched.h>
#include <linux/slab.h>
#include <linux/poll.h>
#include <linux/fcntl.h>
#include <linux/init.h>
#include <linux/interrupt.h>
#include <linux/socket.h>
#include <linux/skbuff.h>
#include <linux/list.h>
45
#include <linux/device.h>
46 47
#include <linux/debugfs.h>
#include <linux/seq_file.h>
48
#include <linux/uaccess.h>
49
#include <linux/crc16.h>
L
Linus Torvalds 已提交
50 51 52 53 54 55 56 57
#include <net/sock.h>

#include <asm/system.h>
#include <asm/unaligned.h>

#include <net/bluetooth/bluetooth.h>
#include <net/bluetooth/hci_core.h>
#include <net/bluetooth/l2cap.h>
58
#include <net/bluetooth/smp.h>
L
Linus Torvalds 已提交
59

60
bool disable_ertm;
61

62
static u32 l2cap_feat_mask = L2CAP_FEAT_FIXED_CHAN;
63
static u8 l2cap_fixed_chan[8] = { L2CAP_FC_L2CAP, };
L
Linus Torvalds 已提交
64

65 66
static LIST_HEAD(chan_list);
static DEFINE_RWLOCK(chan_list_lock);
L
Linus Torvalds 已提交
67 68 69

static struct sk_buff *l2cap_build_cmd(struct l2cap_conn *conn,
				u8 code, u8 ident, u16 dlen, void *data);
70 71
static void l2cap_send_cmd(struct l2cap_conn *conn, u8 ident, u8 code, u16 len,
								void *data);
72
static int l2cap_build_conf_req(struct l2cap_chan *chan, void *data);
73 74
static void l2cap_send_disconn_req(struct l2cap_conn *conn,
				struct l2cap_chan *chan, int err);
L
Linus Torvalds 已提交
75

76
/* ---- L2CAP channels ---- */
77

78
static struct l2cap_chan *__l2cap_get_chan_by_dcid(struct l2cap_conn *conn, u16 cid)
79
{
80
	struct l2cap_chan *c;
81

82 83 84
	list_for_each_entry(c, &conn->chan_l, list) {
		if (c->dcid == cid)
			return c;
85
	}
86
	return NULL;
87 88
}

89
static struct l2cap_chan *__l2cap_get_chan_by_scid(struct l2cap_conn *conn, u16 cid)
90
{
91
	struct l2cap_chan *c;
92

93 94 95
	list_for_each_entry(c, &conn->chan_l, list) {
		if (c->scid == cid)
			return c;
96
	}
97
	return NULL;
98 99 100 101
}

/* Find channel with given SCID.
 * Returns locked socket */
102
static struct l2cap_chan *l2cap_get_chan_by_scid(struct l2cap_conn *conn, u16 cid)
103
{
104
	struct l2cap_chan *c;
105

106
	mutex_lock(&conn->chan_lock);
107
	c = __l2cap_get_chan_by_scid(conn, cid);
108 109
	mutex_unlock(&conn->chan_lock);

110
	return c;
111 112
}

113
static struct l2cap_chan *__l2cap_get_chan_by_ident(struct l2cap_conn *conn, u8 ident)
114
{
115
	struct l2cap_chan *c;
116

117 118 119
	list_for_each_entry(c, &conn->chan_l, list) {
		if (c->ident == ident)
			return c;
120
	}
121
	return NULL;
122 123
}

124
static inline struct l2cap_chan *l2cap_get_chan_by_ident(struct l2cap_conn *conn, u8 ident)
125
{
126
	struct l2cap_chan *c;
127

128
	mutex_lock(&conn->chan_lock);
129
	c = __l2cap_get_chan_by_ident(conn, ident);
130 131
	mutex_unlock(&conn->chan_lock);

132
	return c;
133 134
}

135
static struct l2cap_chan *__l2cap_global_chan_by_addr(__le16 psm, bdaddr_t *src)
136
{
137
	struct l2cap_chan *c;
138

139 140
	list_for_each_entry(c, &chan_list, global_l) {
		if (c->sport == psm && !bacmp(&bt_sk(c->sk)->src, src))
141
			return c;
142
	}
143
	return NULL;
144 145 146 147
}

int l2cap_add_psm(struct l2cap_chan *chan, bdaddr_t *src, __le16 psm)
{
148 149
	int err;

150
	write_lock(&chan_list_lock);
151

152
	if (psm && __l2cap_global_chan_by_addr(psm, src)) {
153 154
		err = -EADDRINUSE;
		goto done;
155 156
	}

157 158 159 160 161 162 163 164 165
	if (psm) {
		chan->psm = psm;
		chan->sport = psm;
		err = 0;
	} else {
		u16 p;

		err = -EINVAL;
		for (p = 0x1001; p < 0x1100; p += 2)
166
			if (!__l2cap_global_chan_by_addr(cpu_to_le16(p), src)) {
167 168 169 170 171 172
				chan->psm   = cpu_to_le16(p);
				chan->sport = cpu_to_le16(p);
				err = 0;
				break;
			}
	}
173

174
done:
175
	write_unlock(&chan_list_lock);
176
	return err;
177 178 179 180
}

int l2cap_add_scid(struct l2cap_chan *chan,  __u16 scid)
{
181
	write_lock(&chan_list_lock);
182 183 184

	chan->scid = scid;

185
	write_unlock(&chan_list_lock);
186 187 188 189

	return 0;
}

190
static u16 l2cap_alloc_cid(struct l2cap_conn *conn)
191
{
192
	u16 cid = L2CAP_CID_DYN_START;
193

194
	for (; cid < L2CAP_CID_DYN_END; cid++) {
195
		if (!__l2cap_get_chan_by_scid(conn, cid))
196 197 198 199 200 201
			return cid;
	}

	return 0;
}

202 203
static void l2cap_state_change(struct l2cap_chan *chan, int state)
{
204
	BT_DBG("chan %p %s -> %s", chan, state_to_string(chan->state),
205 206
						state_to_string(state));

207 208 209 210
	chan->state = state;
	chan->ops->state_change(chan->data, state);
}

211
static void l2cap_chan_timeout(struct work_struct *work)
212
{
213 214
	struct l2cap_chan *chan = container_of(work, struct l2cap_chan,
							chan_timer.work);
215
	struct l2cap_conn *conn = chan->conn;
216 217 218
	struct sock *sk = chan->sk;
	int reason;

219
	BT_DBG("chan %p state %s", chan, state_to_string(chan->state));
220

221
	mutex_lock(&conn->chan_lock);
222
	lock_sock(sk);
223

224
	if (chan->state == BT_CONNECTED || chan->state == BT_CONFIG)
225
		reason = ECONNREFUSED;
226
	else if (chan->state == BT_CONNECT &&
227 228 229 230 231
					chan->sec_level != BT_SECURITY_SDP)
		reason = ECONNREFUSED;
	else
		reason = ETIMEDOUT;

232
	l2cap_chan_close(chan, reason);
233

234
	release_sock(sk);
235

236
	chan->ops->close(chan->data);
237 238
	mutex_unlock(&conn->chan_lock);

239
	l2cap_chan_put(chan);
240 241
}

242
struct l2cap_chan *l2cap_chan_create(struct sock *sk)
243 244 245 246 247 248 249
{
	struct l2cap_chan *chan;

	chan = kzalloc(sizeof(*chan), GFP_ATOMIC);
	if (!chan)
		return NULL;

250 251
	mutex_init(&chan->lock);

252 253
	chan->sk = sk;

254
	write_lock(&chan_list_lock);
255
	list_add(&chan->global_l, &chan_list);
256
	write_unlock(&chan_list_lock);
257

258
	INIT_DELAYED_WORK(&chan->chan_timer, l2cap_chan_timeout);
259

260 261
	chan->state = BT_OPEN;

262 263
	atomic_set(&chan->refcnt, 1);

264 265
	BT_DBG("sk %p chan %p", sk, chan);

266 267 268
	return chan;
}

269
void l2cap_chan_destroy(struct l2cap_chan *chan)
270
{
271
	write_lock(&chan_list_lock);
272
	list_del(&chan->global_l);
273
	write_unlock(&chan_list_lock);
274

275
	l2cap_chan_put(chan);
276 277
}

278
static void l2cap_chan_add(struct l2cap_conn *conn, struct l2cap_chan *chan)
279
{
280
	BT_DBG("conn %p, psm 0x%2.2x, dcid 0x%4.4x", conn,
281
			chan->psm, chan->dcid);
282

283
	conn->disc_reason = HCI_ERROR_REMOTE_USER_TERM;
284

285
	chan->conn = conn;
286

287 288
	switch (chan->chan_type) {
	case L2CAP_CHAN_CONN_ORIENTED:
289 290
		if (conn->hcon->type == LE_LINK) {
			/* LE connection */
291
			chan->omtu = L2CAP_LE_DEFAULT_MTU;
292 293
			chan->scid = L2CAP_CID_LE_DATA;
			chan->dcid = L2CAP_CID_LE_DATA;
294 295
		} else {
			/* Alloc CID for connection-oriented socket */
296
			chan->scid = l2cap_alloc_cid(conn);
297
			chan->omtu = L2CAP_DEFAULT_MTU;
298
		}
299 300 301
		break;

	case L2CAP_CHAN_CONN_LESS:
302
		/* Connectionless socket */
303 304
		chan->scid = L2CAP_CID_CONN_LESS;
		chan->dcid = L2CAP_CID_CONN_LESS;
305
		chan->omtu = L2CAP_DEFAULT_MTU;
306 307 308
		break;

	default:
309
		/* Raw socket can send/recv signalling messages only */
310 311
		chan->scid = L2CAP_CID_SIGNALING;
		chan->dcid = L2CAP_CID_SIGNALING;
312
		chan->omtu = L2CAP_DEFAULT_MTU;
313 314
	}

315 316 317 318 319 320 321
	chan->local_id		= L2CAP_BESTEFFORT_ID;
	chan->local_stype	= L2CAP_SERV_BESTEFFORT;
	chan->local_msdu	= L2CAP_DEFAULT_MAX_SDU_SIZE;
	chan->local_sdu_itime	= L2CAP_DEFAULT_SDU_ITIME;
	chan->local_acc_lat	= L2CAP_DEFAULT_ACC_LAT;
	chan->local_flush_to	= L2CAP_DEFAULT_FLUSH_TO;

322
	l2cap_chan_hold(chan);
323

324 325 326
	mutex_lock(&conn->chan_lock);
	list_add(&chan->list, &conn->chan_l);
	mutex_unlock(&conn->chan_lock);
327 328
}

329
/* Delete channel.
330
 * Must be called on the locked socket. */
331
static void l2cap_chan_del(struct l2cap_chan *chan, int err)
332
{
333
	struct sock *sk = chan->sk;
334
	struct l2cap_conn *conn = chan->conn;
335 336
	struct sock *parent = bt_sk(sk)->parent;

337
	__clear_chan_timer(chan);
338

339
	BT_DBG("chan %p, conn %p, err %d", chan, conn, err);
340

341
	if (conn) {
342
		/* Delete from channel list */
343
		list_del(&chan->list);
344

345
		l2cap_chan_put(chan);
346

347
		chan->conn = NULL;
348 349 350
		hci_conn_put(conn->hcon);
	}

351
	l2cap_state_change(chan, BT_CLOSED);
352 353 354 355 356 357 358 359 360 361
	sock_set_flag(sk, SOCK_ZAPPED);

	if (err)
		sk->sk_err = err;

	if (parent) {
		bt_accept_unlink(sk);
		parent->sk_data_ready(parent, 0);
	} else
		sk->sk_state_change(sk);
362

363 364
	if (!(test_bit(CONF_OUTPUT_DONE, &chan->conf_state) &&
			test_bit(CONF_INPUT_DONE, &chan->conf_state)))
365
		return;
366

367
	skb_queue_purge(&chan->tx_q);
368

369
	if (chan->mode == L2CAP_MODE_ERTM) {
370 371
		struct srej_list *l, *tmp;

372 373 374
		__clear_retrans_timer(chan);
		__clear_monitor_timer(chan);
		__clear_ack_timer(chan);
375

376
		skb_queue_purge(&chan->srej_q);
377

378
		list_for_each_entry_safe(l, tmp, &chan->srej_l, list) {
379 380 381 382
			list_del(&l->list);
			kfree(l);
		}
	}
383 384
}

385 386 387 388 389 390 391
static void l2cap_chan_cleanup_listen(struct sock *parent)
{
	struct sock *sk;

	BT_DBG("parent %p", parent);

	/* Close not yet accepted channels */
392
	while ((sk = bt_accept_dequeue(parent, NULL))) {
393
		struct l2cap_chan *chan = l2cap_pi(sk)->chan;
394

395
		__clear_chan_timer(chan);
396
		lock_sock(sk);
397
		l2cap_chan_close(chan, ECONNRESET);
398
		release_sock(sk);
399

400
		chan->ops->close(chan->data);
401
	}
402 403
}

404
void l2cap_chan_close(struct l2cap_chan *chan, int reason)
405 406 407 408
{
	struct l2cap_conn *conn = chan->conn;
	struct sock *sk = chan->sk;

409 410
	BT_DBG("chan %p state %s sk %p", chan,
					state_to_string(chan->state), sk);
411

412
	switch (chan->state) {
413 414
	case BT_LISTEN:
		l2cap_chan_cleanup_listen(sk);
415 416 417

		l2cap_state_change(chan, BT_CLOSED);
		sock_set_flag(sk, SOCK_ZAPPED);
418 419 420 421
		break;

	case BT_CONNECTED:
	case BT_CONFIG:
422
		if (chan->chan_type == L2CAP_CHAN_CONN_ORIENTED &&
423
					conn->hcon->type == ACL_LINK) {
424 425
			__clear_chan_timer(chan);
			__set_chan_timer(chan, sk->sk_sndtimeo);
426 427 428 429 430 431
			l2cap_send_disconn_req(conn, chan, reason);
		} else
			l2cap_chan_del(chan, reason);
		break;

	case BT_CONNECT2:
432
		if (chan->chan_type == L2CAP_CHAN_CONN_ORIENTED &&
433 434 435 436 437 438 439 440
					conn->hcon->type == ACL_LINK) {
			struct l2cap_conn_rsp rsp;
			__u16 result;

			if (bt_sk(sk)->defer_setup)
				result = L2CAP_CR_SEC_BLOCK;
			else
				result = L2CAP_CR_BAD_PSM;
441
			l2cap_state_change(chan, BT_DISCONN);
442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464

			rsp.scid   = cpu_to_le16(chan->dcid);
			rsp.dcid   = cpu_to_le16(chan->scid);
			rsp.result = cpu_to_le16(result);
			rsp.status = cpu_to_le16(L2CAP_CS_NO_INFO);
			l2cap_send_cmd(conn, chan->ident, L2CAP_CONN_RSP,
							sizeof(rsp), &rsp);
		}

		l2cap_chan_del(chan, reason);
		break;

	case BT_CONNECT:
	case BT_DISCONN:
		l2cap_chan_del(chan, reason);
		break;

	default:
		sock_set_flag(sk, SOCK_ZAPPED);
		break;
	}
}

465
static inline u8 l2cap_get_auth_type(struct l2cap_chan *chan)
466
{
467
	if (chan->chan_type == L2CAP_CHAN_RAW) {
468
		switch (chan->sec_level) {
469 470 471 472 473 474 475
		case BT_SECURITY_HIGH:
			return HCI_AT_DEDICATED_BONDING_MITM;
		case BT_SECURITY_MEDIUM:
			return HCI_AT_DEDICATED_BONDING;
		default:
			return HCI_AT_NO_BONDING;
		}
476
	} else if (chan->psm == cpu_to_le16(0x0001)) {
477 478
		if (chan->sec_level == BT_SECURITY_LOW)
			chan->sec_level = BT_SECURITY_SDP;
479

480
		if (chan->sec_level == BT_SECURITY_HIGH)
481
			return HCI_AT_NO_BONDING_MITM;
482
		else
483
			return HCI_AT_NO_BONDING;
484
	} else {
485
		switch (chan->sec_level) {
486
		case BT_SECURITY_HIGH:
487
			return HCI_AT_GENERAL_BONDING_MITM;
488
		case BT_SECURITY_MEDIUM:
489
			return HCI_AT_GENERAL_BONDING;
490
		default:
491
			return HCI_AT_NO_BONDING;
492
		}
493
	}
494 495 496
}

/* Service level security */
497
int l2cap_chan_check_security(struct l2cap_chan *chan)
498
{
499
	struct l2cap_conn *conn = chan->conn;
500 501
	__u8 auth_type;

502
	auth_type = l2cap_get_auth_type(chan);
503

504
	return hci_conn_security(conn->hcon, chan->sec_level, auth_type);
505 506
}

507
static u8 l2cap_get_ident(struct l2cap_conn *conn)
508 509 510 511 512 513 514 515 516
{
	u8 id;

	/* Get next available identificator.
	 *    1 - 128 are used by kernel.
	 *  129 - 199 are reserved.
	 *  200 - 254 are used by utilities like l2ping, etc.
	 */

517
	spin_lock(&conn->lock);
518 519 520 521 522 523

	if (++conn->tx_ident > 128)
		conn->tx_ident = 1;

	id = conn->tx_ident;

524
	spin_unlock(&conn->lock);
525 526 527 528

	return id;
}

529
static void l2cap_send_cmd(struct l2cap_conn *conn, u8 ident, u8 code, u16 len, void *data)
530 531
{
	struct sk_buff *skb = l2cap_build_cmd(conn, code, ident, len, data);
532
	u8 flags;
533 534 535 536

	BT_DBG("code 0x%2.2x", code);

	if (!skb)
537
		return;
538

539 540 541 542 543
	if (lmp_no_flush_capable(conn->hcon->hdev))
		flags = ACL_START_NO_FLUSH;
	else
		flags = ACL_START;

544
	bt_cb(skb)->force_active = BT_POWER_FORCE_ACTIVE_ON;
545
	skb->priority = HCI_PRIO_MAX;
546

547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562
	hci_send_acl(conn->hchan, skb, flags);
}

static void l2cap_do_send(struct l2cap_chan *chan, struct sk_buff *skb)
{
	struct hci_conn *hcon = chan->conn->hcon;
	u16 flags;

	BT_DBG("chan %p, skb %p len %d priority %u", chan, skb, skb->len,
							skb->priority);

	if (!test_bit(FLAG_FLUSHABLE, &chan->flags) &&
					lmp_no_flush_capable(hcon->hdev))
		flags = ACL_START_NO_FLUSH;
	else
		flags = ACL_START;
563

564 565
	bt_cb(skb)->force_active = test_bit(FLAG_FORCE_ACTIVE, &chan->flags);
	hci_send_acl(chan->conn->hchan, skb, flags);
566 567
}

568
static inline void l2cap_send_sframe(struct l2cap_chan *chan, u32 control)
569 570 571
{
	struct sk_buff *skb;
	struct l2cap_hdr *lh;
572
	struct l2cap_conn *conn = chan->conn;
573
	int count, hlen;
574

575
	if (chan->state != BT_CONNECTED)
576 577
		return;

578 579 580 581 582
	if (test_bit(FLAG_EXT_CTRL, &chan->flags))
		hlen = L2CAP_EXT_HDR_SIZE;
	else
		hlen = L2CAP_ENH_HDR_SIZE;

583
	if (chan->fcs == L2CAP_FCS_CRC16)
584
		hlen += L2CAP_FCS_SIZE;
585

586
	BT_DBG("chan %p, control 0x%8.8x", chan, control);
587

588
	count = min_t(unsigned int, conn->mtu, hlen);
589 590

	control |= __set_sframe(chan);
591

592
	if (test_and_clear_bit(CONN_SEND_FBIT, &chan->conn_state))
593
		control |= __set_ctrl_final(chan);
594

595
	if (test_and_clear_bit(CONN_SEND_PBIT, &chan->conn_state))
596
		control |= __set_ctrl_poll(chan);
597

598 599
	skb = bt_skb_alloc(count, GFP_ATOMIC);
	if (!skb)
600
		return;
601 602

	lh = (struct l2cap_hdr *) skb_put(skb, L2CAP_HDR_SIZE);
603
	lh->len = cpu_to_le16(hlen - L2CAP_HDR_SIZE);
604
	lh->cid = cpu_to_le16(chan->dcid);
605 606

	__put_control(chan, control, skb_put(skb, __ctrl_size(chan)));
607

608
	if (chan->fcs == L2CAP_FCS_CRC16) {
609 610
		u16 fcs = crc16(0, (u8 *)lh, count - L2CAP_FCS_SIZE);
		put_unaligned_le16(fcs, skb_put(skb, L2CAP_FCS_SIZE));
611 612
	}

613 614
	skb->priority = HCI_PRIO_MAX;
	l2cap_do_send(chan, skb);
615 616
}

617
static inline void l2cap_send_rr_or_rnr(struct l2cap_chan *chan, u32 control)
618
{
619
	if (test_bit(CONN_LOCAL_BUSY, &chan->conn_state)) {
620
		control |= __set_ctrl_super(chan, L2CAP_SUPER_RNR);
621
		set_bit(CONN_RNR_SENT, &chan->conn_state);
622
	} else
623
		control |= __set_ctrl_super(chan, L2CAP_SUPER_RR);
624

625
	control |= __set_reqseq(chan, chan->buffer_seq);
626

627
	l2cap_send_sframe(chan, control);
628 629
}

630
static inline int __l2cap_no_conn_pending(struct l2cap_chan *chan)
631
{
632
	return !test_bit(CONF_CONNECT_PEND, &chan->conf_state);
633 634
}

635
static void l2cap_do_start(struct l2cap_chan *chan)
636
{
637
	struct l2cap_conn *conn = chan->conn;
638 639

	if (conn->info_state & L2CAP_INFO_FEAT_MASK_REQ_SENT) {
640 641 642
		if (!(conn->info_state & L2CAP_INFO_FEAT_MASK_REQ_DONE))
			return;

643
		if (l2cap_chan_check_security(chan) &&
644
				__l2cap_no_conn_pending(chan)) {
645
			struct l2cap_conn_req req;
646 647
			req.scid = cpu_to_le16(chan->scid);
			req.psm  = chan->psm;
648

649
			chan->ident = l2cap_get_ident(conn);
650
			set_bit(CONF_CONNECT_PEND, &chan->conf_state);
651

652 653
			l2cap_send_cmd(conn, chan->ident, L2CAP_CONN_REQ,
							sizeof(req), &req);
654
		}
655 656 657 658 659 660 661
	} else {
		struct l2cap_info_req req;
		req.type = cpu_to_le16(L2CAP_IT_FEAT_MASK);

		conn->info_state |= L2CAP_INFO_FEAT_MASK_REQ_SENT;
		conn->info_ident = l2cap_get_ident(conn);

662
		schedule_delayed_work(&conn->info_timer,
663 664 665 666 667 668 669
					msecs_to_jiffies(L2CAP_INFO_TIMEOUT));

		l2cap_send_cmd(conn, conn->info_ident,
					L2CAP_INFO_REQ, sizeof(req), &req);
	}
}

670 671 672
static inline int l2cap_mode_supported(__u8 mode, __u32 feat_mask)
{
	u32 local_feat_mask = l2cap_feat_mask;
673
	if (!disable_ertm)
674 675 676 677 678 679 680 681 682 683 684 685
		local_feat_mask |= L2CAP_FEAT_ERTM | L2CAP_FEAT_STREAMING;

	switch (mode) {
	case L2CAP_MODE_ERTM:
		return L2CAP_FEAT_ERTM & feat_mask & local_feat_mask;
	case L2CAP_MODE_STREAMING:
		return L2CAP_FEAT_STREAMING & feat_mask & local_feat_mask;
	default:
		return 0x00;
	}
}

686
static void l2cap_send_disconn_req(struct l2cap_conn *conn, struct l2cap_chan *chan, int err)
687
{
688
	struct sock *sk;
689 690
	struct l2cap_disconn_req req;

691 692 693
	if (!conn)
		return;

694 695
	sk = chan->sk;

696
	if (chan->mode == L2CAP_MODE_ERTM) {
697 698 699
		__clear_retrans_timer(chan);
		__clear_monitor_timer(chan);
		__clear_ack_timer(chan);
700 701
	}

702 703
	req.dcid = cpu_to_le16(chan->dcid);
	req.scid = cpu_to_le16(chan->scid);
704 705
	l2cap_send_cmd(conn, l2cap_get_ident(conn),
			L2CAP_DISCONN_REQ, sizeof(req), &req);
706

707
	l2cap_state_change(chan, BT_DISCONN);
708
	sk->sk_err = err;
709 710
}

L
Linus Torvalds 已提交
711
/* ---- L2CAP connections ---- */
712 713
static void l2cap_conn_start(struct l2cap_conn *conn)
{
714
	struct l2cap_chan *chan, *tmp;
715 716 717

	BT_DBG("conn %p", conn);

718
	mutex_lock(&conn->chan_lock);
719

720
	list_for_each_entry_safe(chan, tmp, &conn->chan_l, list) {
721
		struct sock *sk = chan->sk;
722

723 724
		bh_lock_sock(sk);

725
		if (chan->chan_type != L2CAP_CHAN_CONN_ORIENTED) {
726 727 728 729
			bh_unlock_sock(sk);
			continue;
		}

730
		if (chan->state == BT_CONNECT) {
731
			struct l2cap_conn_req req;
732

733
			if (!l2cap_chan_check_security(chan) ||
734
					!__l2cap_no_conn_pending(chan)) {
735 736 737
				bh_unlock_sock(sk);
				continue;
			}
738

739 740 741
			if (!l2cap_mode_supported(chan->mode, conn->feat_mask)
					&& test_bit(CONF_STATE2_DEVICE,
					&chan->conf_state)) {
742
				/* l2cap_chan_close() calls list_del(chan)
743
				 * so release the lock */
744
				l2cap_chan_close(chan, ECONNRESET);
745 746
				bh_unlock_sock(sk);
				continue;
747
			}
748

749 750
			req.scid = cpu_to_le16(chan->scid);
			req.psm  = chan->psm;
751

752
			chan->ident = l2cap_get_ident(conn);
753
			set_bit(CONF_CONNECT_PEND, &chan->conf_state);
754

755 756
			l2cap_send_cmd(conn, chan->ident, L2CAP_CONN_REQ,
							sizeof(req), &req);
757

758
		} else if (chan->state == BT_CONNECT2) {
759
			struct l2cap_conn_rsp rsp;
760
			char buf[128];
761 762
			rsp.scid = cpu_to_le16(chan->dcid);
			rsp.dcid = cpu_to_le16(chan->scid);
763

764
			if (l2cap_chan_check_security(chan)) {
765 766 767 768
				if (bt_sk(sk)->defer_setup) {
					struct sock *parent = bt_sk(sk)->parent;
					rsp.result = cpu_to_le16(L2CAP_CR_PEND);
					rsp.status = cpu_to_le16(L2CAP_CS_AUTHOR_PEND);
769 770
					if (parent)
						parent->sk_data_ready(parent, 0);
771 772

				} else {
773
					l2cap_state_change(chan, BT_CONFIG);
774 775 776
					rsp.result = cpu_to_le16(L2CAP_CR_SUCCESS);
					rsp.status = cpu_to_le16(L2CAP_CS_NO_INFO);
				}
777 778 779 780 781
			} else {
				rsp.result = cpu_to_le16(L2CAP_CR_PEND);
				rsp.status = cpu_to_le16(L2CAP_CS_AUTHEN_PEND);
			}

782 783
			l2cap_send_cmd(conn, chan->ident, L2CAP_CONN_RSP,
							sizeof(rsp), &rsp);
784

785
			if (test_bit(CONF_REQ_SENT, &chan->conf_state) ||
786 787 788 789 790
					rsp.result != L2CAP_CR_SUCCESS) {
				bh_unlock_sock(sk);
				continue;
			}

791
			set_bit(CONF_REQ_SENT, &chan->conf_state);
792
			l2cap_send_cmd(conn, l2cap_get_ident(conn), L2CAP_CONF_REQ,
793 794
						l2cap_build_conf_req(chan, buf), buf);
			chan->num_conf_req++;
795 796 797 798 799
		}

		bh_unlock_sock(sk);
	}

800
	mutex_unlock(&conn->chan_lock);
801 802
}

803 804 805
/* Find socket with cid and source bdaddr.
 * Returns closest match, locked.
 */
806
static struct l2cap_chan *l2cap_global_chan_by_scid(int state, __le16 cid, bdaddr_t *src)
807
{
808
	struct l2cap_chan *c, *c1 = NULL;
809

810
	read_lock(&chan_list_lock);
811

812 813
	list_for_each_entry(c, &chan_list, global_l) {
		struct sock *sk = c->sk;
814

815
		if (state && c->state != state)
816 817
			continue;

818
		if (c->scid == cid) {
819
			/* Exact match. */
820 821 822 823
			if (!bacmp(&bt_sk(sk)->src, src)) {
				read_unlock(&chan_list_lock);
				return c;
			}
824 825 826

			/* Closest match */
			if (!bacmp(&bt_sk(sk)->src, BDADDR_ANY))
827
				c1 = c;
828 829
		}
	}
830

831
	read_unlock(&chan_list_lock);
832

833
	return c1;
834 835 836 837
}

static void l2cap_le_conn_ready(struct l2cap_conn *conn)
{
838
	struct sock *parent, *sk;
839
	struct l2cap_chan *chan, *pchan;
840 841 842 843

	BT_DBG("");

	/* Check if we have socket listening on cid */
844
	pchan = l2cap_global_chan_by_scid(BT_LISTEN, L2CAP_CID_LE_DATA,
845
							conn->src);
846
	if (!pchan)
847 848
		return;

849 850
	parent = pchan->sk;

851
	lock_sock(parent);
852

853 854 855 856 857 858
	/* Check for backlog size */
	if (sk_acceptq_is_full(parent)) {
		BT_DBG("backlog full %d", parent->sk_ack_backlog);
		goto clean;
	}

859 860
	chan = pchan->ops->new_connection(pchan->data);
	if (!chan)
861 862
		goto clean;

863
	sk = chan->sk;
864

865 866 867 868 869
	hci_conn_hold(conn->hcon);

	bacpy(&bt_sk(sk)->src, conn->src);
	bacpy(&bt_sk(sk)->dst, conn->dst);

870 871
	bt_accept_enqueue(parent, sk);

872
	l2cap_chan_add(conn, chan);
873

874
	__set_chan_timer(chan, sk->sk_sndtimeo);
875

876
	l2cap_state_change(chan, BT_CONNECTED);
877 878 879
	parent->sk_data_ready(parent, 0);

clean:
880
	release_sock(parent);
881 882
}

883
static void l2cap_chan_ready(struct l2cap_chan *chan)
884
{
885
	struct sock *sk = chan->sk;
886 887 888 889 890 891 892
	struct sock *parent = bt_sk(sk)->parent;

	BT_DBG("sk %p, parent %p", sk, parent);

	chan->conf_state = 0;
	__clear_chan_timer(chan);

893
	l2cap_state_change(chan, BT_CONNECTED);
894 895 896 897 898 899
	sk->sk_state_change(sk);

	if (parent)
		parent->sk_data_ready(parent, 0);
}

900 901
static void l2cap_conn_ready(struct l2cap_conn *conn)
{
902
	struct l2cap_chan *chan;
903

904
	BT_DBG("conn %p", conn);
905

906 907 908
	if (!conn->hcon->out && conn->hcon->type == LE_LINK)
		l2cap_le_conn_ready(conn);

909 910 911
	if (conn->hcon->out && conn->hcon->type == LE_LINK)
		smp_conn_security(conn, conn->hcon->pending_sec_level);

912
	mutex_lock(&conn->chan_lock);
913

914
	list_for_each_entry(chan, &conn->chan_l, list) {
915
		struct sock *sk = chan->sk;
916

917
		bh_lock_sock(sk);
918

919
		if (conn->hcon->type == LE_LINK) {
920
			if (smp_conn_security(conn, chan->sec_level))
921
				l2cap_chan_ready(chan);
922

923
		} else if (chan->chan_type != L2CAP_CHAN_CONN_ORIENTED) {
924
			__clear_chan_timer(chan);
925
			l2cap_state_change(chan, BT_CONNECTED);
926
			sk->sk_state_change(sk);
927

928
		} else if (chan->state == BT_CONNECT)
929
			l2cap_do_start(chan);
930

931
		bh_unlock_sock(sk);
932
	}
933

934
	mutex_unlock(&conn->chan_lock);
935 936 937 938 939
}

/* Notify sockets that we cannot guaranty reliability anymore */
static void l2cap_conn_unreliable(struct l2cap_conn *conn, int err)
{
940
	struct l2cap_chan *chan;
941 942 943

	BT_DBG("conn %p", conn);

944
	mutex_lock(&conn->chan_lock);
945

946
	list_for_each_entry(chan, &conn->chan_l, list) {
947
		struct sock *sk = chan->sk;
948

949
		if (test_bit(FLAG_FORCE_RELIABLE, &chan->flags))
950 951 952
			sk->sk_err = err;
	}

953
	mutex_unlock(&conn->chan_lock);
954 955
}

956
static void l2cap_info_timeout(struct work_struct *work)
957
{
958
	struct l2cap_conn *conn = container_of(work, struct l2cap_conn,
959
							info_timer.work);
960

961
	conn->info_state |= L2CAP_INFO_FEAT_MASK_REQ_DONE;
962
	conn->info_ident = 0;
963

964 965 966
	l2cap_conn_start(conn);
}

967 968 969 970 971 972 973 974 975 976 977 978 979
static void l2cap_conn_del(struct hci_conn *hcon, int err)
{
	struct l2cap_conn *conn = hcon->l2cap_data;
	struct l2cap_chan *chan, *l;
	struct sock *sk;

	if (!conn)
		return;

	BT_DBG("hcon %p conn %p, err %d", hcon, conn, err);

	kfree_skb(conn->rx_skb);

980 981
	mutex_lock(&conn->chan_lock);

982 983 984
	/* Kill channels */
	list_for_each_entry_safe(chan, l, &conn->chan_l, list) {
		sk = chan->sk;
985
		lock_sock(sk);
986
		l2cap_chan_del(chan, err);
987
		release_sock(sk);
988 989 990
		chan->ops->close(chan->data);
	}

991 992
	mutex_unlock(&conn->chan_lock);

993 994
	hci_chan_del(conn->hchan);

995
	if (conn->info_state & L2CAP_INFO_FEAT_MASK_REQ_SENT)
996
		cancel_delayed_work_sync(&conn->info_timer);
997

998
	if (test_and_clear_bit(HCI_CONN_LE_SMP_PEND, &hcon->flags)) {
999
		cancel_delayed_work_sync(&conn->security_timer);
1000
		smp_chan_destroy(conn);
1001
	}
1002 1003 1004 1005 1006

	hcon->l2cap_data = NULL;
	kfree(conn);
}

1007
static void security_timeout(struct work_struct *work)
1008
{
1009 1010
	struct l2cap_conn *conn = container_of(work, struct l2cap_conn,
						security_timer.work);
1011 1012 1013 1014

	l2cap_conn_del(conn->hcon, ETIMEDOUT);
}

L
Linus Torvalds 已提交
1015 1016
static struct l2cap_conn *l2cap_conn_add(struct hci_conn *hcon, u8 status)
{
1017
	struct l2cap_conn *conn = hcon->l2cap_data;
1018
	struct hci_chan *hchan;
L
Linus Torvalds 已提交
1019

1020
	if (conn || status)
L
Linus Torvalds 已提交
1021 1022
		return conn;

1023 1024 1025 1026
	hchan = hci_chan_create(hcon);
	if (!hchan)
		return NULL;

1027
	conn = kzalloc(sizeof(struct l2cap_conn), GFP_ATOMIC);
1028 1029
	if (!conn) {
		hci_chan_del(hchan);
L
Linus Torvalds 已提交
1030
		return NULL;
1031
	}
L
Linus Torvalds 已提交
1032 1033 1034

	hcon->l2cap_data = conn;
	conn->hcon = hcon;
1035
	conn->hchan = hchan;
L
Linus Torvalds 已提交
1036

1037
	BT_DBG("hcon %p conn %p hchan %p", hcon, conn, hchan);
1038

1039 1040 1041 1042 1043
	if (hcon->hdev->le_mtu && hcon->type == LE_LINK)
		conn->mtu = hcon->hdev->le_mtu;
	else
		conn->mtu = hcon->hdev->acl_mtu;

L
Linus Torvalds 已提交
1044 1045 1046
	conn->src = &hcon->hdev->bdaddr;
	conn->dst = &hcon->dst;

1047 1048
	conn->feat_mask = 0;

L
Linus Torvalds 已提交
1049
	spin_lock_init(&conn->lock);
1050
	mutex_init(&conn->chan_lock);
1051 1052

	INIT_LIST_HEAD(&conn->chan_l);
L
Linus Torvalds 已提交
1053

1054
	if (hcon->type == LE_LINK)
1055
		INIT_DELAYED_WORK(&conn->security_timer, security_timeout);
1056
	else
1057
		INIT_DELAYED_WORK(&conn->info_timer, l2cap_info_timeout);
D
Dave Young 已提交
1058

1059
	conn->disc_reason = HCI_ERROR_REMOTE_USER_TERM;
1060

L
Linus Torvalds 已提交
1061 1062 1063 1064 1065 1066 1067 1068
	return conn;
}

/* ---- Socket interface ---- */

/* Find socket with psm and source bdaddr.
 * Returns closest match.
 */
1069
static struct l2cap_chan *l2cap_global_chan_by_psm(int state, __le16 psm, bdaddr_t *src)
L
Linus Torvalds 已提交
1070
{
1071
	struct l2cap_chan *c, *c1 = NULL;
L
Linus Torvalds 已提交
1072

1073
	read_lock(&chan_list_lock);
1074

1075 1076
	list_for_each_entry(c, &chan_list, global_l) {
		struct sock *sk = c->sk;
1077

1078
		if (state && c->state != state)
L
Linus Torvalds 已提交
1079 1080
			continue;

1081
		if (c->psm == psm) {
L
Linus Torvalds 已提交
1082
			/* Exact match. */
1083
			if (!bacmp(&bt_sk(sk)->src, src)) {
1084
				read_unlock(&chan_list_lock);
1085 1086
				return c;
			}
L
Linus Torvalds 已提交
1087 1088 1089

			/* Closest match */
			if (!bacmp(&bt_sk(sk)->src, BDADDR_ANY))
1090
				c1 = c;
L
Linus Torvalds 已提交
1091 1092 1093
		}
	}

1094
	read_unlock(&chan_list_lock);
1095

1096
	return c1;
L
Linus Torvalds 已提交
1097 1098
}

1099
int l2cap_chan_connect(struct l2cap_chan *chan, __le16 psm, u16 cid, bdaddr_t *dst)
L
Linus Torvalds 已提交
1100
{
1101
	struct sock *sk = chan->sk;
L
Linus Torvalds 已提交
1102 1103 1104 1105
	bdaddr_t *src = &bt_sk(sk)->src;
	struct l2cap_conn *conn;
	struct hci_conn *hcon;
	struct hci_dev *hdev;
1106
	__u8 auth_type;
1107
	int err;
L
Linus Torvalds 已提交
1108

1109
	BT_DBG("%s -> %s psm 0x%2.2x", batostr(src), batostr(dst),
1110
							chan->psm);
L
Linus Torvalds 已提交
1111

1112 1113
	hdev = hci_get_route(dst, src);
	if (!hdev)
L
Linus Torvalds 已提交
1114 1115
		return -EHOSTUNREACH;

1116
	hci_dev_lock(hdev);
L
Linus Torvalds 已提交
1117

1118 1119 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155 1156 1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1167 1168
	lock_sock(sk);

	/* PSM must be odd and lsb of upper byte must be 0 */
	if ((__le16_to_cpu(psm) & 0x0101) != 0x0001 && !cid &&
					chan->chan_type != L2CAP_CHAN_RAW) {
		err = -EINVAL;
		goto done;
	}

	if (chan->chan_type == L2CAP_CHAN_CONN_ORIENTED && !(psm || cid)) {
		err = -EINVAL;
		goto done;
	}

	switch (chan->mode) {
	case L2CAP_MODE_BASIC:
		break;
	case L2CAP_MODE_ERTM:
	case L2CAP_MODE_STREAMING:
		if (!disable_ertm)
			break;
		/* fall through */
	default:
		err = -ENOTSUPP;
		goto done;
	}

	switch (sk->sk_state) {
	case BT_CONNECT:
	case BT_CONNECT2:
	case BT_CONFIG:
		/* Already connecting */
		err = 0;
		goto done;

	case BT_CONNECTED:
		/* Already connected */
		err = -EISCONN;
		goto done;

	case BT_OPEN:
	case BT_BOUND:
		/* Can connect */
		break;

	default:
		err = -EBADFD;
		goto done;
	}

	/* Set destination address and psm */
1169
	bacpy(&bt_sk(sk)->dst, dst);
1170 1171
	chan->psm = psm;
	chan->dcid = cid;
L
Linus Torvalds 已提交
1172

1173
	auth_type = l2cap_get_auth_type(chan);
1174

1175
	if (chan->dcid == L2CAP_CID_LE_DATA)
1176
		hcon = hci_connect(hdev, LE_LINK, dst,
1177
					chan->sec_level, auth_type);
1178 1179
	else
		hcon = hci_connect(hdev, ACL_LINK, dst,
1180
					chan->sec_level, auth_type);
1181

1182 1183
	if (IS_ERR(hcon)) {
		err = PTR_ERR(hcon);
L
Linus Torvalds 已提交
1184
		goto done;
1185
	}
L
Linus Torvalds 已提交
1186 1187 1188 1189

	conn = l2cap_conn_add(hcon, 0);
	if (!conn) {
		hci_conn_put(hcon);
1190
		err = -ENOMEM;
L
Linus Torvalds 已提交
1191 1192 1193 1194 1195 1196
		goto done;
	}

	/* Update source addr of the socket */
	bacpy(src, conn->src);

1197 1198
	l2cap_chan_add(conn, chan);

1199
	l2cap_state_change(chan, BT_CONNECT);
1200
	__set_chan_timer(chan, sk->sk_sndtimeo);
L
Linus Torvalds 已提交
1201 1202

	if (hcon->state == BT_CONNECTED) {
1203
		if (chan->chan_type != L2CAP_CHAN_CONN_ORIENTED) {
1204
			__clear_chan_timer(chan);
1205
			if (l2cap_chan_check_security(chan))
1206
				l2cap_state_change(chan, BT_CONNECTED);
1207
		} else
1208
			l2cap_do_start(chan);
L
Linus Torvalds 已提交
1209 1210
	}

1211 1212
	err = 0;

L
Linus Torvalds 已提交
1213
done:
1214
	hci_dev_unlock(hdev);
L
Linus Torvalds 已提交
1215 1216 1217 1218
	hci_dev_put(hdev);
	return err;
}

1219
int __l2cap_wait_ack(struct sock *sk)
1220
{
1221
	struct l2cap_chan *chan = l2cap_pi(sk)->chan;
1222 1223 1224 1225
	DECLARE_WAITQUEUE(wait, current);
	int err = 0;
	int timeo = HZ/5;

1226
	add_wait_queue(sk_sleep(sk), &wait);
1227 1228
	set_current_state(TASK_INTERRUPTIBLE);
	while (chan->unacked_frames > 0 && chan->conn) {
1229 1230 1231 1232 1233 1234 1235 1236 1237 1238 1239
		if (!timeo)
			timeo = HZ/5;

		if (signal_pending(current)) {
			err = sock_intr_errno(timeo);
			break;
		}

		release_sock(sk);
		timeo = schedule_timeout(timeo);
		lock_sock(sk);
1240
		set_current_state(TASK_INTERRUPTIBLE);
1241 1242 1243 1244 1245 1246

		err = sock_error(sk);
		if (err)
			break;
	}
	set_current_state(TASK_RUNNING);
1247
	remove_wait_queue(sk_sleep(sk), &wait);
1248 1249 1250
	return err;
}

1251
static void l2cap_monitor_timeout(struct work_struct *work)
1252
{
1253 1254
	struct l2cap_chan *chan = container_of(work, struct l2cap_chan,
							monitor_timer.work);
1255
	struct sock *sk = chan->sk;
1256

1257
	BT_DBG("chan %p", chan);
1258

1259
	lock_sock(sk);
1260
	if (chan->retry_count >= chan->remote_max_tx) {
1261
		l2cap_send_disconn_req(chan->conn, chan, ECONNABORTED);
1262
		release_sock(sk);
1263 1264 1265
		return;
	}

1266
	chan->retry_count++;
1267
	__set_monitor_timer(chan);
1268

1269
	l2cap_send_rr_or_rnr(chan, L2CAP_CTRL_POLL);
1270
	release_sock(sk);
1271 1272
}

1273
static void l2cap_retrans_timeout(struct work_struct *work)
1274
{
1275 1276
	struct l2cap_chan *chan = container_of(work, struct l2cap_chan,
							retrans_timer.work);
1277
	struct sock *sk = chan->sk;
1278

1279
	BT_DBG("chan %p", chan);
1280

1281
	lock_sock(sk);
1282
	chan->retry_count = 1;
1283
	__set_monitor_timer(chan);
1284

1285
	set_bit(CONN_WAIT_F, &chan->conn_state);
1286

1287
	l2cap_send_rr_or_rnr(chan, L2CAP_CTRL_POLL);
1288
	release_sock(sk);
1289 1290
}

1291
static void l2cap_drop_acked_frames(struct l2cap_chan *chan)
L
Linus Torvalds 已提交
1292
{
1293
	struct sk_buff *skb;
L
Linus Torvalds 已提交
1294

1295
	while ((skb = skb_peek(&chan->tx_q)) &&
1296
			chan->unacked_frames) {
1297
		if (bt_cb(skb)->tx_seq == chan->expected_ack_seq)
1298
			break;
L
Linus Torvalds 已提交
1299

1300
		skb = skb_dequeue(&chan->tx_q);
1301
		kfree_skb(skb);
L
Linus Torvalds 已提交
1302

1303
		chan->unacked_frames--;
1304
	}
L
Linus Torvalds 已提交
1305

1306
	if (!chan->unacked_frames)
1307
		__clear_retrans_timer(chan);
1308
}
L
Linus Torvalds 已提交
1309

1310
static void l2cap_streaming_send(struct l2cap_chan *chan)
1311
{
1312
	struct sk_buff *skb;
1313 1314
	u32 control;
	u16 fcs;
1315

1316
	while ((skb = skb_dequeue(&chan->tx_q))) {
1317
		control = __get_control(chan, skb->data + L2CAP_HDR_SIZE);
1318
		control |= __set_txseq(chan, chan->next_tx_seq);
1319
		__put_control(chan, control, skb->data + L2CAP_HDR_SIZE);
1320

1321
		if (chan->fcs == L2CAP_FCS_CRC16) {
1322 1323 1324 1325
			fcs = crc16(0, (u8 *)skb->data,
						skb->len - L2CAP_FCS_SIZE);
			put_unaligned_le16(fcs,
					skb->data + skb->len - L2CAP_FCS_SIZE);
1326 1327
		}

1328
		l2cap_do_send(chan, skb);
1329

1330
		chan->next_tx_seq = __next_seq(chan, chan->next_tx_seq);
1331 1332 1333
	}
}

1334
static void l2cap_retransmit_one_frame(struct l2cap_chan *chan, u16 tx_seq)
1335 1336
{
	struct sk_buff *skb, *tx_skb;
1337 1338
	u16 fcs;
	u32 control;
1339

1340
	skb = skb_peek(&chan->tx_q);
1341 1342
	if (!skb)
		return;
1343

1344
	while (bt_cb(skb)->tx_seq != tx_seq) {
1345
		if (skb_queue_is_last(&chan->tx_q, skb))
1346
			return;
1347

1348 1349
		skb = skb_queue_next(&chan->tx_q, skb);
	}
1350

1351 1352
	if (chan->remote_max_tx &&
			bt_cb(skb)->retries == chan->remote_max_tx) {
1353
		l2cap_send_disconn_req(chan->conn, chan, ECONNABORTED);
1354 1355 1356 1357 1358
		return;
	}

	tx_skb = skb_clone(skb, GFP_ATOMIC);
	bt_cb(skb)->retries++;
1359 1360

	control = __get_control(chan, tx_skb->data + L2CAP_HDR_SIZE);
1361
	control &= __get_sar_mask(chan);
1362

1363
	if (test_and_clear_bit(CONN_SEND_FBIT, &chan->conn_state))
1364
		control |= __set_ctrl_final(chan);
1365

1366
	control |= __set_reqseq(chan, chan->buffer_seq);
1367
	control |= __set_txseq(chan, tx_seq);
1368

1369
	__put_control(chan, control, tx_skb->data + L2CAP_HDR_SIZE);
1370

1371
	if (chan->fcs == L2CAP_FCS_CRC16) {
1372 1373 1374 1375
		fcs = crc16(0, (u8 *)tx_skb->data,
						tx_skb->len - L2CAP_FCS_SIZE);
		put_unaligned_le16(fcs,
				tx_skb->data + tx_skb->len - L2CAP_FCS_SIZE);
1376 1377
	}

1378
	l2cap_do_send(chan, tx_skb);
1379 1380
}

1381
static int l2cap_ertm_send(struct l2cap_chan *chan)
1382 1383
{
	struct sk_buff *skb, *tx_skb;
1384 1385
	u16 fcs;
	u32 control;
1386
	int nsent = 0;
1387

1388
	if (chan->state != BT_CONNECTED)
1389
		return -ENOTCONN;
1390

1391
	while ((skb = chan->tx_send_head) && (!l2cap_tx_window_full(chan))) {
1392

1393 1394
		if (chan->remote_max_tx &&
				bt_cb(skb)->retries == chan->remote_max_tx) {
1395
			l2cap_send_disconn_req(chan->conn, chan, ECONNABORTED);
1396 1397 1398
			break;
		}

1399 1400
		tx_skb = skb_clone(skb, GFP_ATOMIC);

1401 1402
		bt_cb(skb)->retries++;

1403
		control = __get_control(chan, tx_skb->data + L2CAP_HDR_SIZE);
1404
		control &= __get_sar_mask(chan);
1405

1406
		if (test_and_clear_bit(CONN_SEND_FBIT, &chan->conn_state))
1407
			control |= __set_ctrl_final(chan);
1408

1409
		control |= __set_reqseq(chan, chan->buffer_seq);
1410
		control |= __set_txseq(chan, chan->next_tx_seq);
1411

1412
		__put_control(chan, control, tx_skb->data + L2CAP_HDR_SIZE);
1413

1414
		if (chan->fcs == L2CAP_FCS_CRC16) {
1415 1416 1417 1418
			fcs = crc16(0, (u8 *)skb->data,
						tx_skb->len - L2CAP_FCS_SIZE);
			put_unaligned_le16(fcs, skb->data +
						tx_skb->len - L2CAP_FCS_SIZE);
1419 1420
		}

1421
		l2cap_do_send(chan, tx_skb);
1422

1423
		__set_retrans_timer(chan);
1424

1425
		bt_cb(skb)->tx_seq = chan->next_tx_seq;
1426 1427

		chan->next_tx_seq = __next_seq(chan, chan->next_tx_seq);
1428

1429
		if (bt_cb(skb)->retries == 1) {
1430
			chan->unacked_frames++;
1431 1432 1433

			if (!nsent++)
				__clear_ack_timer(chan);
1434
		}
1435

1436
		chan->frames_sent++;
1437

1438 1439
		if (skb_queue_is_last(&chan->tx_q, skb))
			chan->tx_send_head = NULL;
1440
		else
1441
			chan->tx_send_head = skb_queue_next(&chan->tx_q, skb);
1442 1443
	}

1444 1445 1446
	return nsent;
}

1447
static int l2cap_retransmit_frames(struct l2cap_chan *chan)
1448 1449 1450
{
	int ret;

1451 1452
	if (!skb_queue_empty(&chan->tx_q))
		chan->tx_send_head = chan->tx_q.next;
1453

1454
	chan->next_tx_seq = chan->expected_ack_seq;
1455
	ret = l2cap_ertm_send(chan);
1456 1457 1458
	return ret;
}

1459
static void __l2cap_send_ack(struct l2cap_chan *chan)
1460
{
1461
	u32 control = 0;
1462

1463
	control |= __set_reqseq(chan, chan->buffer_seq);
1464

1465
	if (test_bit(CONN_LOCAL_BUSY, &chan->conn_state)) {
1466
		control |= __set_ctrl_super(chan, L2CAP_SUPER_RNR);
1467
		set_bit(CONN_RNR_SENT, &chan->conn_state);
1468
		l2cap_send_sframe(chan, control);
1469
		return;
1470
	}
1471

1472
	if (l2cap_ertm_send(chan) > 0)
1473 1474
		return;

1475
	control |= __set_ctrl_super(chan, L2CAP_SUPER_RR);
1476
	l2cap_send_sframe(chan, control);
1477 1478
}

1479 1480 1481 1482 1483 1484
static void l2cap_send_ack(struct l2cap_chan *chan)
{
	__clear_ack_timer(chan);
	__l2cap_send_ack(chan);
}

1485
static void l2cap_send_srejtail(struct l2cap_chan *chan)
1486 1487
{
	struct srej_list *tail;
1488
	u32 control;
1489

1490
	control = __set_ctrl_super(chan, L2CAP_SUPER_SREJ);
1491
	control |= __set_ctrl_final(chan);
1492

1493
	tail = list_entry((&chan->srej_l)->prev, struct srej_list, list);
1494
	control |= __set_reqseq(chan, tail->tx_seq);
1495

1496
	l2cap_send_sframe(chan, control);
1497 1498
}

1499
static inline int l2cap_skbuff_fromiovec(struct l2cap_chan *chan, struct msghdr *msg, int len, int count, struct sk_buff *skb)
1500
{
1501
	struct l2cap_conn *conn = chan->conn;
1502 1503
	struct sk_buff **frag;
	int err, sent = 0;
L
Linus Torvalds 已提交
1504

1505
	if (memcpy_fromiovec(skb_put(skb, count), msg->msg_iov, count))
1506
		return -EFAULT;
L
Linus Torvalds 已提交
1507 1508 1509 1510 1511 1512 1513 1514 1515

	sent += count;
	len  -= count;

	/* Continuation fragments (no L2CAP header) */
	frag = &skb_shinfo(skb)->frag_list;
	while (len) {
		count = min_t(unsigned int, conn->mtu, len);

1516 1517 1518
		*frag = chan->ops->alloc_skb(chan, count,
					msg->msg_flags & MSG_DONTWAIT, &err);

L
Linus Torvalds 已提交
1519
		if (!*frag)
1520
			return err;
1521 1522
		if (memcpy_fromiovec(skb_put(*frag, count), msg->msg_iov, count))
			return -EFAULT;
L
Linus Torvalds 已提交
1523

1524 1525
		(*frag)->priority = skb->priority;

L
Linus Torvalds 已提交
1526 1527 1528 1529 1530 1531 1532
		sent += count;
		len  -= count;

		frag = &(*frag)->next;
	}

	return sent;
1533
}
L
Linus Torvalds 已提交
1534

1535 1536 1537
static struct sk_buff *l2cap_create_connless_pdu(struct l2cap_chan *chan,
						struct msghdr *msg, size_t len,
						u32 priority)
1538
{
1539
	struct l2cap_conn *conn = chan->conn;
1540
	struct sk_buff *skb;
1541
	int err, count, hlen = L2CAP_HDR_SIZE + L2CAP_PSMLEN_SIZE;
1542 1543
	struct l2cap_hdr *lh;

1544
	BT_DBG("chan %p len %d priority %u", chan, (int)len, priority);
1545 1546

	count = min_t(unsigned int, (conn->mtu - hlen), len);
1547 1548 1549 1550

	skb = chan->ops->alloc_skb(chan, count + hlen,
					msg->msg_flags & MSG_DONTWAIT, &err);

1551
	if (!skb)
1552
		return ERR_PTR(err);
1553

1554 1555
	skb->priority = priority;

1556 1557
	/* Create L2CAP header */
	lh = (struct l2cap_hdr *) skb_put(skb, L2CAP_HDR_SIZE);
1558
	lh->cid = cpu_to_le16(chan->dcid);
1559
	lh->len = cpu_to_le16(len + (hlen - L2CAP_HDR_SIZE));
1560
	put_unaligned_le16(chan->psm, skb_put(skb, 2));
1561

1562
	err = l2cap_skbuff_fromiovec(chan, msg, len, count, skb);
1563 1564 1565 1566 1567 1568 1569
	if (unlikely(err < 0)) {
		kfree_skb(skb);
		return ERR_PTR(err);
	}
	return skb;
}

1570 1571 1572
static struct sk_buff *l2cap_create_basic_pdu(struct l2cap_chan *chan,
						struct msghdr *msg, size_t len,
						u32 priority)
1573
{
1574
	struct l2cap_conn *conn = chan->conn;
1575 1576 1577 1578
	struct sk_buff *skb;
	int err, count, hlen = L2CAP_HDR_SIZE;
	struct l2cap_hdr *lh;

1579
	BT_DBG("chan %p len %d", chan, (int)len);
1580 1581

	count = min_t(unsigned int, (conn->mtu - hlen), len);
1582 1583 1584 1585

	skb = chan->ops->alloc_skb(chan, count + hlen,
					msg->msg_flags & MSG_DONTWAIT, &err);

1586
	if (!skb)
1587
		return ERR_PTR(err);
1588

1589 1590
	skb->priority = priority;

1591 1592
	/* Create L2CAP header */
	lh = (struct l2cap_hdr *) skb_put(skb, L2CAP_HDR_SIZE);
1593
	lh->cid = cpu_to_le16(chan->dcid);
1594 1595
	lh->len = cpu_to_le16(len + (hlen - L2CAP_HDR_SIZE));

1596
	err = l2cap_skbuff_fromiovec(chan, msg, len, count, skb);
1597 1598 1599 1600 1601 1602 1603
	if (unlikely(err < 0)) {
		kfree_skb(skb);
		return ERR_PTR(err);
	}
	return skb;
}

1604 1605
static struct sk_buff *l2cap_create_iframe_pdu(struct l2cap_chan *chan,
						struct msghdr *msg, size_t len,
1606
						u32 control, u16 sdulen)
1607
{
1608
	struct l2cap_conn *conn = chan->conn;
1609
	struct sk_buff *skb;
1610
	int err, count, hlen;
1611 1612
	struct l2cap_hdr *lh;

1613
	BT_DBG("chan %p len %d", chan, (int)len);
1614

1615 1616 1617
	if (!conn)
		return ERR_PTR(-ENOTCONN);

1618 1619 1620 1621 1622
	if (test_bit(FLAG_EXT_CTRL, &chan->flags))
		hlen = L2CAP_EXT_HDR_SIZE;
	else
		hlen = L2CAP_ENH_HDR_SIZE;

1623
	if (sdulen)
1624
		hlen += L2CAP_SDULEN_SIZE;
1625

1626
	if (chan->fcs == L2CAP_FCS_CRC16)
1627
		hlen += L2CAP_FCS_SIZE;
1628

1629
	count = min_t(unsigned int, (conn->mtu - hlen), len);
1630 1631 1632 1633

	skb = chan->ops->alloc_skb(chan, count + hlen,
					msg->msg_flags & MSG_DONTWAIT, &err);

1634
	if (!skb)
1635
		return ERR_PTR(err);
1636 1637 1638

	/* Create L2CAP header */
	lh = (struct l2cap_hdr *) skb_put(skb, L2CAP_HDR_SIZE);
1639
	lh->cid = cpu_to_le16(chan->dcid);
1640
	lh->len = cpu_to_le16(len + (hlen - L2CAP_HDR_SIZE));
1641 1642 1643

	__put_control(chan, control, skb_put(skb, __ctrl_size(chan)));

1644
	if (sdulen)
1645
		put_unaligned_le16(sdulen, skb_put(skb, L2CAP_SDULEN_SIZE));
1646

1647
	err = l2cap_skbuff_fromiovec(chan, msg, len, count, skb);
1648 1649 1650 1651
	if (unlikely(err < 0)) {
		kfree_skb(skb);
		return ERR_PTR(err);
	}
1652

1653
	if (chan->fcs == L2CAP_FCS_CRC16)
1654
		put_unaligned_le16(0, skb_put(skb, L2CAP_FCS_SIZE));
1655

1656
	bt_cb(skb)->retries = 0;
1657
	return skb;
L
Linus Torvalds 已提交
1658 1659
}

1660
static int l2cap_sar_segment_sdu(struct l2cap_chan *chan, struct msghdr *msg, size_t len)
1661 1662 1663
{
	struct sk_buff *skb;
	struct sk_buff_head sar_queue;
1664
	u32 control;
1665 1666
	size_t size = 0;

1667
	skb_queue_head_init(&sar_queue);
1668
	control = __set_ctrl_sar(chan, L2CAP_SAR_START);
1669
	skb = l2cap_create_iframe_pdu(chan, msg, chan->remote_mps, control, len);
1670 1671 1672 1673
	if (IS_ERR(skb))
		return PTR_ERR(skb);

	__skb_queue_tail(&sar_queue, skb);
1674 1675
	len -= chan->remote_mps;
	size += chan->remote_mps;
1676 1677 1678 1679

	while (len > 0) {
		size_t buflen;

1680
		if (len > chan->remote_mps) {
1681
			control = __set_ctrl_sar(chan, L2CAP_SAR_CONTINUE);
1682
			buflen = chan->remote_mps;
1683
		} else {
1684
			control = __set_ctrl_sar(chan, L2CAP_SAR_END);
1685 1686 1687
			buflen = len;
		}

1688
		skb = l2cap_create_iframe_pdu(chan, msg, buflen, control, 0);
1689 1690 1691 1692 1693 1694 1695 1696 1697
		if (IS_ERR(skb)) {
			skb_queue_purge(&sar_queue);
			return PTR_ERR(skb);
		}

		__skb_queue_tail(&sar_queue, skb);
		len -= buflen;
		size += buflen;
	}
1698 1699 1700
	skb_queue_splice_tail(&sar_queue, &chan->tx_q);
	if (chan->tx_send_head == NULL)
		chan->tx_send_head = sar_queue.next;
1701 1702 1703 1704

	return size;
}

1705 1706
int l2cap_chan_send(struct l2cap_chan *chan, struct msghdr *msg, size_t len,
								u32 priority)
1707 1708
{
	struct sk_buff *skb;
1709
	u32 control;
1710 1711 1712
	int err;

	/* Connectionless channel */
1713
	if (chan->chan_type == L2CAP_CHAN_CONN_LESS) {
1714
		skb = l2cap_create_connless_pdu(chan, msg, len, priority);
1715 1716 1717 1718 1719 1720 1721 1722 1723 1724 1725 1726 1727 1728
		if (IS_ERR(skb))
			return PTR_ERR(skb);

		l2cap_do_send(chan, skb);
		return len;
	}

	switch (chan->mode) {
	case L2CAP_MODE_BASIC:
		/* Check outgoing MTU */
		if (len > chan->omtu)
			return -EMSGSIZE;

		/* Create a basic PDU */
1729
		skb = l2cap_create_basic_pdu(chan, msg, len, priority);
1730 1731 1732 1733 1734 1735 1736 1737 1738 1739 1740
		if (IS_ERR(skb))
			return PTR_ERR(skb);

		l2cap_do_send(chan, skb);
		err = len;
		break;

	case L2CAP_MODE_ERTM:
	case L2CAP_MODE_STREAMING:
		/* Entire SDU fits into one PDU */
		if (len <= chan->remote_mps) {
1741
			control = __set_ctrl_sar(chan, L2CAP_SAR_UNSEGMENTED);
1742 1743 1744 1745 1746 1747 1748 1749 1750 1751 1752 1753 1754 1755 1756 1757 1758 1759 1760 1761 1762 1763 1764
			skb = l2cap_create_iframe_pdu(chan, msg, len, control,
									0);
			if (IS_ERR(skb))
				return PTR_ERR(skb);

			__skb_queue_tail(&chan->tx_q, skb);

			if (chan->tx_send_head == NULL)
				chan->tx_send_head = skb;

		} else {
			/* Segment SDU into multiples PDUs */
			err = l2cap_sar_segment_sdu(chan, msg, len);
			if (err < 0)
				return err;
		}

		if (chan->mode == L2CAP_MODE_STREAMING) {
			l2cap_streaming_send(chan);
			err = len;
			break;
		}

1765 1766
		if (test_bit(CONN_REMOTE_BUSY, &chan->conn_state) &&
				test_bit(CONN_WAIT_F, &chan->conn_state)) {
1767 1768 1769 1770 1771 1772 1773 1774 1775 1776 1777 1778 1779 1780 1781 1782 1783 1784
			err = len;
			break;
		}

		err = l2cap_ertm_send(chan);
		if (err >= 0)
			err = len;

		break;

	default:
		BT_DBG("bad state %1.1x", chan->mode);
		err = -EBADFD;
	}

	return err;
}

L
Linus Torvalds 已提交
1785 1786 1787 1788
/* Copy frame to all raw sockets on that connection */
static void l2cap_raw_recv(struct l2cap_conn *conn, struct sk_buff *skb)
{
	struct sk_buff *nskb;
1789
	struct l2cap_chan *chan;
L
Linus Torvalds 已提交
1790 1791 1792

	BT_DBG("conn %p", conn);

1793
	mutex_lock(&conn->chan_lock);
1794

1795
	list_for_each_entry(chan, &conn->chan_l, list) {
1796
		struct sock *sk = chan->sk;
1797
		if (chan->chan_type != L2CAP_CHAN_RAW)
L
Linus Torvalds 已提交
1798 1799 1800 1801 1802
			continue;

		/* Don't send frame to the socket it came from */
		if (skb->sk == sk)
			continue;
1803 1804
		nskb = skb_clone(skb, GFP_ATOMIC);
		if (!nskb)
L
Linus Torvalds 已提交
1805 1806
			continue;

1807
		if (chan->ops->recv(chan->data, nskb))
L
Linus Torvalds 已提交
1808 1809
			kfree_skb(nskb);
	}
1810

1811
	mutex_unlock(&conn->chan_lock);
L
Linus Torvalds 已提交
1812 1813 1814 1815 1816 1817 1818 1819 1820 1821 1822
}

/* ---- L2CAP signalling commands ---- */
static struct sk_buff *l2cap_build_cmd(struct l2cap_conn *conn,
				u8 code, u8 ident, u16 dlen, void *data)
{
	struct sk_buff *skb, **frag;
	struct l2cap_cmd_hdr *cmd;
	struct l2cap_hdr *lh;
	int len, count;

1823 1824
	BT_DBG("conn %p, code 0x%2.2x, ident 0x%2.2x, len %d",
			conn, code, ident, dlen);
L
Linus Torvalds 已提交
1825 1826 1827 1828 1829 1830 1831 1832 1833

	len = L2CAP_HDR_SIZE + L2CAP_CMD_HDR_SIZE + dlen;
	count = min_t(unsigned int, conn->mtu, len);

	skb = bt_skb_alloc(count, GFP_ATOMIC);
	if (!skb)
		return NULL;

	lh = (struct l2cap_hdr *) skb_put(skb, L2CAP_HDR_SIZE);
1834
	lh->len = cpu_to_le16(L2CAP_CMD_HDR_SIZE + dlen);
1835 1836 1837 1838 1839

	if (conn->hcon->type == LE_LINK)
		lh->cid = cpu_to_le16(L2CAP_CID_LE_SIGNALING);
	else
		lh->cid = cpu_to_le16(L2CAP_CID_SIGNALING);
L
Linus Torvalds 已提交
1840 1841 1842 1843

	cmd = (struct l2cap_cmd_hdr *) skb_put(skb, L2CAP_CMD_HDR_SIZE);
	cmd->code  = code;
	cmd->ident = ident;
1844
	cmd->len   = cpu_to_le16(dlen);
L
Linus Torvalds 已提交
1845 1846 1847 1848 1849 1850 1851 1852 1853 1854 1855 1856 1857 1858 1859 1860 1861 1862 1863 1864 1865 1866 1867 1868 1869 1870 1871 1872 1873 1874 1875 1876 1877 1878 1879 1880 1881 1882 1883 1884 1885 1886 1887 1888 1889 1890 1891 1892 1893 1894

	if (dlen) {
		count -= L2CAP_HDR_SIZE + L2CAP_CMD_HDR_SIZE;
		memcpy(skb_put(skb, count), data, count);
		data += count;
	}

	len -= skb->len;

	/* Continuation fragments (no L2CAP header) */
	frag = &skb_shinfo(skb)->frag_list;
	while (len) {
		count = min_t(unsigned int, conn->mtu, len);

		*frag = bt_skb_alloc(count, GFP_ATOMIC);
		if (!*frag)
			goto fail;

		memcpy(skb_put(*frag, count), data, count);

		len  -= count;
		data += count;

		frag = &(*frag)->next;
	}

	return skb;

fail:
	kfree_skb(skb);
	return NULL;
}

static inline int l2cap_get_conf_opt(void **ptr, int *type, int *olen, unsigned long *val)
{
	struct l2cap_conf_opt *opt = *ptr;
	int len;

	len = L2CAP_CONF_OPT_SIZE + opt->len;
	*ptr += len;

	*type = opt->type;
	*olen = opt->len;

	switch (opt->len) {
	case 1:
		*val = *((u8 *) opt->val);
		break;

	case 2:
1895
		*val = get_unaligned_le16(opt->val);
L
Linus Torvalds 已提交
1896 1897 1898
		break;

	case 4:
1899
		*val = get_unaligned_le32(opt->val);
L
Linus Torvalds 已提交
1900 1901 1902 1903 1904 1905 1906 1907 1908 1909 1910 1911 1912 1913 1914 1915 1916 1917 1918 1919 1920 1921 1922 1923 1924 1925
		break;

	default:
		*val = (unsigned long) opt->val;
		break;
	}

	BT_DBG("type 0x%2.2x len %d val 0x%lx", *type, opt->len, *val);
	return len;
}

static void l2cap_add_conf_opt(void **ptr, u8 type, u8 len, unsigned long val)
{
	struct l2cap_conf_opt *opt = *ptr;

	BT_DBG("type 0x%2.2x len %d val 0x%lx", type, len, val);

	opt->type = type;
	opt->len  = len;

	switch (len) {
	case 1:
		*((u8 *) opt->val)  = val;
		break;

	case 2:
1926
		put_unaligned_le16(val, opt->val);
L
Linus Torvalds 已提交
1927 1928 1929
		break;

	case 4:
1930
		put_unaligned_le32(val, opt->val);
L
Linus Torvalds 已提交
1931 1932 1933 1934 1935 1936 1937 1938 1939 1940
		break;

	default:
		memcpy(opt->val, (void *) val, len);
		break;
	}

	*ptr += L2CAP_CONF_OPT_SIZE + len;
}

1941 1942 1943 1944
static void l2cap_add_opt_efs(void **ptr, struct l2cap_chan *chan)
{
	struct l2cap_conf_efs efs;

1945
	switch (chan->mode) {
1946 1947 1948 1949 1950 1951 1952 1953 1954 1955 1956 1957 1958 1959 1960 1961 1962 1963 1964 1965 1966 1967 1968 1969 1970 1971
	case L2CAP_MODE_ERTM:
		efs.id		= chan->local_id;
		efs.stype	= chan->local_stype;
		efs.msdu	= cpu_to_le16(chan->local_msdu);
		efs.sdu_itime	= cpu_to_le32(chan->local_sdu_itime);
		efs.acc_lat	= cpu_to_le32(L2CAP_DEFAULT_ACC_LAT);
		efs.flush_to	= cpu_to_le32(L2CAP_DEFAULT_FLUSH_TO);
		break;

	case L2CAP_MODE_STREAMING:
		efs.id		= 1;
		efs.stype	= L2CAP_SERV_BESTEFFORT;
		efs.msdu	= cpu_to_le16(chan->local_msdu);
		efs.sdu_itime	= cpu_to_le32(chan->local_sdu_itime);
		efs.acc_lat	= 0;
		efs.flush_to	= 0;
		break;

	default:
		return;
	}

	l2cap_add_conf_opt(ptr, L2CAP_CONF_EFS, sizeof(efs),
							(unsigned long) &efs);
}

1972
static void l2cap_ack_timeout(struct work_struct *work)
1973
{
1974 1975
	struct l2cap_chan *chan = container_of(work, struct l2cap_chan,
							ack_timer.work);
1976

1977 1978
	BT_DBG("chan %p", chan);

1979
	lock_sock(chan->sk);
1980
	__l2cap_send_ack(chan);
1981
	release_sock(chan->sk);
1982 1983

	l2cap_chan_put(chan);
1984 1985
}

1986
static inline void l2cap_ertm_init(struct l2cap_chan *chan)
1987
{
1988
	chan->expected_ack_seq = 0;
1989
	chan->unacked_frames = 0;
1990
	chan->buffer_seq = 0;
1991 1992
	chan->num_acked = 0;
	chan->frames_sent = 0;
1993

1994 1995 1996
	INIT_DELAYED_WORK(&chan->retrans_timer, l2cap_retrans_timeout);
	INIT_DELAYED_WORK(&chan->monitor_timer, l2cap_monitor_timeout);
	INIT_DELAYED_WORK(&chan->ack_timer, l2cap_ack_timeout);
1997

1998
	skb_queue_head_init(&chan->srej_q);
1999

2000
	INIT_LIST_HEAD(&chan->srej_l);
2001 2002
}

2003 2004 2005 2006 2007 2008 2009 2010 2011 2012 2013 2014 2015
static inline __u8 l2cap_select_mode(__u8 mode, __u16 remote_feat_mask)
{
	switch (mode) {
	case L2CAP_MODE_STREAMING:
	case L2CAP_MODE_ERTM:
		if (l2cap_mode_supported(mode, remote_feat_mask))
			return mode;
		/* fall through */
	default:
		return L2CAP_MODE_BASIC;
	}
}

2016 2017 2018 2019 2020
static inline bool __l2cap_ews_supported(struct l2cap_chan *chan)
{
	return enable_hs && chan->conn->feat_mask & L2CAP_FEAT_EXT_WINDOW;
}

2021 2022 2023 2024 2025
static inline bool __l2cap_efs_supported(struct l2cap_chan *chan)
{
	return enable_hs && chan->conn->feat_mask & L2CAP_FEAT_EXT_FLOW;
}

2026 2027 2028
static inline void l2cap_txwin_setup(struct l2cap_chan *chan)
{
	if (chan->tx_win > L2CAP_DEFAULT_TX_WINDOW &&
2029
						__l2cap_ews_supported(chan)) {
2030 2031
		/* use extended control field */
		set_bit(FLAG_EXT_CTRL, &chan->flags);
2032 2033
		chan->tx_win_max = L2CAP_DEFAULT_EXT_WINDOW;
	} else {
2034 2035
		chan->tx_win = min_t(u16, chan->tx_win,
						L2CAP_DEFAULT_TX_WINDOW);
2036 2037
		chan->tx_win_max = L2CAP_DEFAULT_TX_WINDOW;
	}
2038 2039
}

2040
static int l2cap_build_conf_req(struct l2cap_chan *chan, void *data)
L
Linus Torvalds 已提交
2041 2042
{
	struct l2cap_conf_req *req = data;
2043
	struct l2cap_conf_rfc rfc = { .mode = chan->mode };
L
Linus Torvalds 已提交
2044
	void *ptr = req->data;
2045
	u16 size;
L
Linus Torvalds 已提交
2046

2047
	BT_DBG("chan %p", chan);
L
Linus Torvalds 已提交
2048

2049
	if (chan->num_conf_req || chan->num_conf_rsp)
2050 2051
		goto done;

2052
	switch (chan->mode) {
2053 2054
	case L2CAP_MODE_STREAMING:
	case L2CAP_MODE_ERTM:
2055
		if (test_bit(CONF_STATE2_DEVICE, &chan->conf_state))
2056 2057
			break;

2058 2059 2060
		if (__l2cap_efs_supported(chan))
			set_bit(FLAG_EFS_ENABLE, &chan->flags);

2061
		/* fall through */
2062
	default:
2063
		chan->mode = l2cap_select_mode(rfc.mode, chan->conn->feat_mask);
2064 2065 2066 2067
		break;
	}

done:
2068 2069
	if (chan->imtu != L2CAP_DEFAULT_MTU)
		l2cap_add_conf_opt(&ptr, L2CAP_CONF_MTU, 2, chan->imtu);
2070

2071
	switch (chan->mode) {
2072
	case L2CAP_MODE_BASIC:
2073 2074
		if (!(chan->conn->feat_mask & L2CAP_FEAT_ERTM) &&
				!(chan->conn->feat_mask & L2CAP_FEAT_STREAMING))
2075 2076
			break;

2077 2078 2079 2080 2081 2082 2083
		rfc.mode            = L2CAP_MODE_BASIC;
		rfc.txwin_size      = 0;
		rfc.max_transmit    = 0;
		rfc.retrans_timeout = 0;
		rfc.monitor_timeout = 0;
		rfc.max_pdu_size    = 0;

2084 2085
		l2cap_add_conf_opt(&ptr, L2CAP_CONF_RFC, sizeof(rfc),
							(unsigned long) &rfc);
2086 2087 2088 2089
		break;

	case L2CAP_MODE_ERTM:
		rfc.mode            = L2CAP_MODE_ERTM;
2090
		rfc.max_transmit    = chan->max_tx;
2091 2092
		rfc.retrans_timeout = 0;
		rfc.monitor_timeout = 0;
2093 2094 2095 2096 2097 2098

		size = min_t(u16, L2CAP_DEFAULT_MAX_PDU_SIZE, chan->conn->mtu -
						L2CAP_EXT_HDR_SIZE -
						L2CAP_SDULEN_SIZE -
						L2CAP_FCS_SIZE);
		rfc.max_pdu_size = cpu_to_le16(size);
2099

2100 2101 2102 2103
		l2cap_txwin_setup(chan);

		rfc.txwin_size = min_t(u16, chan->tx_win,
						L2CAP_DEFAULT_TX_WINDOW);
2104

2105 2106 2107
		l2cap_add_conf_opt(&ptr, L2CAP_CONF_RFC, sizeof(rfc),
							(unsigned long) &rfc);

2108 2109 2110
		if (test_bit(FLAG_EFS_ENABLE, &chan->flags))
			l2cap_add_opt_efs(&ptr, chan);

2111
		if (!(chan->conn->feat_mask & L2CAP_FEAT_FCS))
2112 2113
			break;

2114
		if (chan->fcs == L2CAP_FCS_NONE ||
2115
				test_bit(CONF_NO_FCS_RECV, &chan->conf_state)) {
2116 2117
			chan->fcs = L2CAP_FCS_NONE;
			l2cap_add_conf_opt(&ptr, L2CAP_CONF_FCS, 1, chan->fcs);
2118
		}
2119 2120 2121 2122

		if (test_bit(FLAG_EXT_CTRL, &chan->flags))
			l2cap_add_conf_opt(&ptr, L2CAP_CONF_EWS, 2,
								chan->tx_win);
2123 2124 2125 2126 2127 2128 2129 2130
		break;

	case L2CAP_MODE_STREAMING:
		rfc.mode            = L2CAP_MODE_STREAMING;
		rfc.txwin_size      = 0;
		rfc.max_transmit    = 0;
		rfc.retrans_timeout = 0;
		rfc.monitor_timeout = 0;
2131 2132 2133 2134 2135 2136

		size = min_t(u16, L2CAP_DEFAULT_MAX_PDU_SIZE, chan->conn->mtu -
						L2CAP_EXT_HDR_SIZE -
						L2CAP_SDULEN_SIZE -
						L2CAP_FCS_SIZE);
		rfc.max_pdu_size = cpu_to_le16(size);
2137

2138 2139 2140
		l2cap_add_conf_opt(&ptr, L2CAP_CONF_RFC, sizeof(rfc),
							(unsigned long) &rfc);

2141 2142 2143
		if (test_bit(FLAG_EFS_ENABLE, &chan->flags))
			l2cap_add_opt_efs(&ptr, chan);

2144
		if (!(chan->conn->feat_mask & L2CAP_FEAT_FCS))
2145 2146
			break;

2147
		if (chan->fcs == L2CAP_FCS_NONE ||
2148
				test_bit(CONF_NO_FCS_RECV, &chan->conf_state)) {
2149 2150
			chan->fcs = L2CAP_FCS_NONE;
			l2cap_add_conf_opt(&ptr, L2CAP_CONF_FCS, 1, chan->fcs);
2151
		}
2152 2153
		break;
	}
L
Linus Torvalds 已提交
2154

2155
	req->dcid  = cpu_to_le16(chan->dcid);
2156
	req->flags = cpu_to_le16(0);
L
Linus Torvalds 已提交
2157 2158 2159 2160

	return ptr - data;
}

2161
static int l2cap_parse_conf_req(struct l2cap_chan *chan, void *data)
L
Linus Torvalds 已提交
2162
{
2163 2164
	struct l2cap_conf_rsp *rsp = data;
	void *ptr = rsp->data;
2165 2166
	void *req = chan->conf_req;
	int len = chan->conf_len;
2167 2168
	int type, hint, olen;
	unsigned long val;
2169
	struct l2cap_conf_rfc rfc = { .mode = L2CAP_MODE_BASIC };
2170 2171
	struct l2cap_conf_efs efs;
	u8 remote_efs = 0;
2172
	u16 mtu = L2CAP_DEFAULT_MTU;
2173
	u16 result = L2CAP_CONF_SUCCESS;
2174
	u16 size;
L
Linus Torvalds 已提交
2175

2176
	BT_DBG("chan %p", chan);
2177

2178 2179
	while (len >= L2CAP_CONF_OPT_SIZE) {
		len -= l2cap_get_conf_opt(&req, &type, &olen, &val);
L
Linus Torvalds 已提交
2180

2181
		hint  = type & L2CAP_CONF_HINT;
2182
		type &= L2CAP_CONF_MASK;
2183 2184 2185

		switch (type) {
		case L2CAP_CONF_MTU:
2186
			mtu = val;
2187 2188 2189
			break;

		case L2CAP_CONF_FLUSH_TO:
2190
			chan->flush_to = val;
2191 2192 2193 2194 2195
			break;

		case L2CAP_CONF_QOS:
			break;

2196 2197 2198 2199 2200
		case L2CAP_CONF_RFC:
			if (olen == sizeof(rfc))
				memcpy(&rfc, (void *) val, olen);
			break;

2201 2202
		case L2CAP_CONF_FCS:
			if (val == L2CAP_FCS_NONE)
2203
				set_bit(CONF_NO_FCS_RECV, &chan->conf_state);
2204
			break;
2205

2206 2207 2208 2209
		case L2CAP_CONF_EFS:
			remote_efs = 1;
			if (olen == sizeof(efs))
				memcpy(&efs, (void *) val, olen);
2210 2211
			break;

2212 2213 2214
		case L2CAP_CONF_EWS:
			if (!enable_hs)
				return -ECONNREFUSED;
2215

2216 2217
			set_bit(FLAG_EXT_CTRL, &chan->flags);
			set_bit(CONF_EWS_RECV, &chan->conf_state);
2218
			chan->tx_win_max = L2CAP_DEFAULT_EXT_WINDOW;
2219
			chan->remote_tx_win = val;
2220 2221
			break;

2222 2223 2224 2225 2226 2227 2228 2229 2230 2231
		default:
			if (hint)
				break;

			result = L2CAP_CONF_UNKNOWN;
			*((u8 *) ptr++) = type;
			break;
		}
	}

2232
	if (chan->num_conf_rsp || chan->num_conf_req > 1)
2233 2234
		goto done;

2235
	switch (chan->mode) {
2236 2237
	case L2CAP_MODE_STREAMING:
	case L2CAP_MODE_ERTM:
2238
		if (!test_bit(CONF_STATE2_DEVICE, &chan->conf_state)) {
2239
			chan->mode = l2cap_select_mode(rfc.mode,
2240
					chan->conn->feat_mask);
2241 2242 2243
			break;
		}

2244 2245 2246 2247 2248 2249 2250
		if (remote_efs) {
			if (__l2cap_efs_supported(chan))
				set_bit(FLAG_EFS_ENABLE, &chan->flags);
			else
				return -ECONNREFUSED;
		}

2251
		if (chan->mode != rfc.mode)
2252
			return -ECONNREFUSED;
2253

2254 2255 2256 2257
		break;
	}

done:
2258
	if (chan->mode != rfc.mode) {
2259
		result = L2CAP_CONF_UNACCEPT;
2260
		rfc.mode = chan->mode;
2261

2262
		if (chan->num_conf_rsp == 1)
2263 2264 2265 2266 2267 2268
			return -ECONNREFUSED;

		l2cap_add_conf_opt(&ptr, L2CAP_CONF_RFC,
					sizeof(rfc), (unsigned long) &rfc);
	}

2269 2270 2271 2272
	if (result == L2CAP_CONF_SUCCESS) {
		/* Configure output options and let the other side know
		 * which ones we don't like. */

2273 2274 2275
		if (mtu < L2CAP_DEFAULT_MIN_MTU)
			result = L2CAP_CONF_UNACCEPT;
		else {
2276
			chan->omtu = mtu;
2277
			set_bit(CONF_MTU_DONE, &chan->conf_state);
2278
		}
2279
		l2cap_add_conf_opt(&ptr, L2CAP_CONF_MTU, 2, chan->omtu);
2280

2281 2282 2283 2284 2285 2286 2287 2288 2289 2290 2291
		if (remote_efs) {
			if (chan->local_stype != L2CAP_SERV_NOTRAFIC &&
					efs.stype != L2CAP_SERV_NOTRAFIC &&
					efs.stype != chan->local_stype) {

				result = L2CAP_CONF_UNACCEPT;

				if (chan->num_conf_req >= 1)
					return -ECONNREFUSED;

				l2cap_add_conf_opt(&ptr, L2CAP_CONF_EFS,
2292
							sizeof(efs),
2293
							(unsigned long) &efs);
2294
			} else {
2295
				/* Send PENDING Conf Rsp */
2296 2297
				result = L2CAP_CONF_PENDING;
				set_bit(CONF_LOC_CONF_PEND, &chan->conf_state);
2298 2299 2300
			}
		}

2301 2302
		switch (rfc.mode) {
		case L2CAP_MODE_BASIC:
2303
			chan->fcs = L2CAP_FCS_NONE;
2304
			set_bit(CONF_MODE_DONE, &chan->conf_state);
2305 2306 2307
			break;

		case L2CAP_MODE_ERTM:
2308 2309 2310 2311
			if (!test_bit(CONF_EWS_RECV, &chan->conf_state))
				chan->remote_tx_win = rfc.txwin_size;
			else
				rfc.txwin_size = L2CAP_DEFAULT_TX_WINDOW;
2312

2313
			chan->remote_max_tx = rfc.max_transmit;
2314

2315 2316 2317 2318 2319 2320 2321
			size = min_t(u16, le16_to_cpu(rfc.max_pdu_size),
						chan->conn->mtu -
						L2CAP_EXT_HDR_SIZE -
						L2CAP_SDULEN_SIZE -
						L2CAP_FCS_SIZE);
			rfc.max_pdu_size = cpu_to_le16(size);
			chan->remote_mps = size;
2322

2323 2324 2325 2326
			rfc.retrans_timeout =
				le16_to_cpu(L2CAP_DEFAULT_RETRANS_TO);
			rfc.monitor_timeout =
				le16_to_cpu(L2CAP_DEFAULT_MONITOR_TO);
2327

2328
			set_bit(CONF_MODE_DONE, &chan->conf_state);
2329 2330 2331 2332

			l2cap_add_conf_opt(&ptr, L2CAP_CONF_RFC,
					sizeof(rfc), (unsigned long) &rfc);

2333 2334 2335 2336 2337 2338 2339 2340 2341 2342 2343 2344 2345
			if (test_bit(FLAG_EFS_ENABLE, &chan->flags)) {
				chan->remote_id = efs.id;
				chan->remote_stype = efs.stype;
				chan->remote_msdu = le16_to_cpu(efs.msdu);
				chan->remote_flush_to =
						le32_to_cpu(efs.flush_to);
				chan->remote_acc_lat =
						le32_to_cpu(efs.acc_lat);
				chan->remote_sdu_itime =
					le32_to_cpu(efs.sdu_itime);
				l2cap_add_conf_opt(&ptr, L2CAP_CONF_EFS,
					sizeof(efs), (unsigned long) &efs);
			}
2346 2347 2348
			break;

		case L2CAP_MODE_STREAMING:
2349 2350 2351 2352 2353 2354 2355
			size = min_t(u16, le16_to_cpu(rfc.max_pdu_size),
						chan->conn->mtu -
						L2CAP_EXT_HDR_SIZE -
						L2CAP_SDULEN_SIZE -
						L2CAP_FCS_SIZE);
			rfc.max_pdu_size = cpu_to_le16(size);
			chan->remote_mps = size;
2356

2357
			set_bit(CONF_MODE_DONE, &chan->conf_state);
2358 2359 2360 2361

			l2cap_add_conf_opt(&ptr, L2CAP_CONF_RFC,
					sizeof(rfc), (unsigned long) &rfc);

2362 2363 2364
			break;

		default:
2365 2366
			result = L2CAP_CONF_UNACCEPT;

2367
			memset(&rfc, 0, sizeof(rfc));
2368
			rfc.mode = chan->mode;
2369
		}
2370

2371
		if (result == L2CAP_CONF_SUCCESS)
2372
			set_bit(CONF_OUTPUT_DONE, &chan->conf_state);
2373
	}
2374
	rsp->scid   = cpu_to_le16(chan->dcid);
2375 2376 2377 2378
	rsp->result = cpu_to_le16(result);
	rsp->flags  = cpu_to_le16(0x0000);

	return ptr - data;
L
Linus Torvalds 已提交
2379 2380
}

2381
static int l2cap_parse_conf_rsp(struct l2cap_chan *chan, void *rsp, int len, void *data, u16 *result)
2382 2383 2384 2385 2386
{
	struct l2cap_conf_req *req = data;
	void *ptr = req->data;
	int type, olen;
	unsigned long val;
2387
	struct l2cap_conf_rfc rfc = { .mode = L2CAP_MODE_BASIC };
2388
	struct l2cap_conf_efs efs;
2389

2390
	BT_DBG("chan %p, rsp %p, len %d, req %p", chan, rsp, len, data);
2391 2392 2393 2394 2395 2396 2397 2398

	while (len >= L2CAP_CONF_OPT_SIZE) {
		len -= l2cap_get_conf_opt(&rsp, &type, &olen, &val);

		switch (type) {
		case L2CAP_CONF_MTU:
			if (val < L2CAP_DEFAULT_MIN_MTU) {
				*result = L2CAP_CONF_UNACCEPT;
2399
				chan->imtu = L2CAP_DEFAULT_MIN_MTU;
2400
			} else
2401 2402
				chan->imtu = val;
			l2cap_add_conf_opt(&ptr, L2CAP_CONF_MTU, 2, chan->imtu);
2403 2404 2405
			break;

		case L2CAP_CONF_FLUSH_TO:
2406
			chan->flush_to = val;
2407
			l2cap_add_conf_opt(&ptr, L2CAP_CONF_FLUSH_TO,
2408
							2, chan->flush_to);
2409 2410 2411 2412 2413 2414
			break;

		case L2CAP_CONF_RFC:
			if (olen == sizeof(rfc))
				memcpy(&rfc, (void *)val, olen);

2415
			if (test_bit(CONF_STATE2_DEVICE, &chan->conf_state) &&
2416
							rfc.mode != chan->mode)
2417 2418
				return -ECONNREFUSED;

2419
			chan->fcs = 0;
2420 2421 2422 2423

			l2cap_add_conf_opt(&ptr, L2CAP_CONF_RFC,
					sizeof(rfc), (unsigned long) &rfc);
			break;
2424 2425 2426 2427

		case L2CAP_CONF_EWS:
			chan->tx_win = min_t(u16, val,
						L2CAP_DEFAULT_EXT_WINDOW);
2428 2429
			l2cap_add_conf_opt(&ptr, L2CAP_CONF_EWS, 2,
							chan->tx_win);
2430
			break;
2431 2432 2433 2434 2435 2436 2437 2438 2439 2440 2441 2442 2443

		case L2CAP_CONF_EFS:
			if (olen == sizeof(efs))
				memcpy(&efs, (void *)val, olen);

			if (chan->local_stype != L2CAP_SERV_NOTRAFIC &&
					efs.stype != L2CAP_SERV_NOTRAFIC &&
					efs.stype != chan->local_stype)
				return -ECONNREFUSED;

			l2cap_add_conf_opt(&ptr, L2CAP_CONF_EFS,
					sizeof(efs), (unsigned long) &efs);
			break;
2444 2445 2446
		}
	}

2447
	if (chan->mode == L2CAP_MODE_BASIC && chan->mode != rfc.mode)
2448 2449
		return -ECONNREFUSED;

2450
	chan->mode = rfc.mode;
2451

2452
	if (*result == L2CAP_CONF_SUCCESS || *result == L2CAP_CONF_PENDING) {
2453 2454
		switch (rfc.mode) {
		case L2CAP_MODE_ERTM:
2455 2456 2457
			chan->retrans_timeout = le16_to_cpu(rfc.retrans_timeout);
			chan->monitor_timeout = le16_to_cpu(rfc.monitor_timeout);
			chan->mps    = le16_to_cpu(rfc.max_pdu_size);
2458 2459 2460 2461 2462 2463 2464 2465 2466

			if (test_bit(FLAG_EFS_ENABLE, &chan->flags)) {
				chan->local_msdu = le16_to_cpu(efs.msdu);
				chan->local_sdu_itime =
						le32_to_cpu(efs.sdu_itime);
				chan->local_acc_lat = le32_to_cpu(efs.acc_lat);
				chan->local_flush_to =
						le32_to_cpu(efs.flush_to);
			}
2467
			break;
2468

2469
		case L2CAP_MODE_STREAMING:
2470
			chan->mps    = le16_to_cpu(rfc.max_pdu_size);
2471 2472 2473
		}
	}

2474
	req->dcid   = cpu_to_le16(chan->dcid);
2475 2476 2477 2478 2479
	req->flags  = cpu_to_le16(0x0000);

	return ptr - data;
}

2480
static int l2cap_build_conf_rsp(struct l2cap_chan *chan, void *data, u16 result, u16 flags)
L
Linus Torvalds 已提交
2481 2482 2483 2484
{
	struct l2cap_conf_rsp *rsp = data;
	void *ptr = rsp->data;

2485
	BT_DBG("chan %p", chan);
L
Linus Torvalds 已提交
2486

2487
	rsp->scid   = cpu_to_le16(chan->dcid);
2488
	rsp->result = cpu_to_le16(result);
2489
	rsp->flags  = cpu_to_le16(flags);
L
Linus Torvalds 已提交
2490 2491 2492 2493

	return ptr - data;
}

2494
void __l2cap_connect_rsp_defer(struct l2cap_chan *chan)
2495 2496
{
	struct l2cap_conn_rsp rsp;
2497
	struct l2cap_conn *conn = chan->conn;
2498 2499
	u8 buf[128];

2500 2501
	rsp.scid   = cpu_to_le16(chan->dcid);
	rsp.dcid   = cpu_to_le16(chan->scid);
2502 2503 2504 2505 2506
	rsp.result = cpu_to_le16(L2CAP_CR_SUCCESS);
	rsp.status = cpu_to_le16(L2CAP_CS_NO_INFO);
	l2cap_send_cmd(conn, chan->ident,
				L2CAP_CONN_RSP, sizeof(rsp), &rsp);

2507
	if (test_and_set_bit(CONF_REQ_SENT, &chan->conf_state))
2508 2509 2510 2511 2512 2513 2514
		return;

	l2cap_send_cmd(conn, l2cap_get_ident(conn), L2CAP_CONF_REQ,
			l2cap_build_conf_req(chan, buf), buf);
	chan->num_conf_req++;
}

2515
static void l2cap_conf_rfc_get(struct l2cap_chan *chan, void *rsp, int len)
2516 2517 2518 2519 2520
{
	int type, olen;
	unsigned long val;
	struct l2cap_conf_rfc rfc;

2521
	BT_DBG("chan %p, rsp %p, len %d", chan, rsp, len);
2522

2523
	if ((chan->mode != L2CAP_MODE_ERTM) && (chan->mode != L2CAP_MODE_STREAMING))
2524 2525 2526 2527 2528 2529 2530 2531 2532 2533 2534 2535 2536
		return;

	while (len >= L2CAP_CONF_OPT_SIZE) {
		len -= l2cap_get_conf_opt(&rsp, &type, &olen, &val);

		switch (type) {
		case L2CAP_CONF_RFC:
			if (olen == sizeof(rfc))
				memcpy(&rfc, (void *)val, olen);
			goto done;
		}
	}

2537 2538 2539 2540 2541 2542 2543 2544 2545 2546
	/* Use sane default values in case a misbehaving remote device
	 * did not send an RFC option.
	 */
	rfc.mode = chan->mode;
	rfc.retrans_timeout = cpu_to_le16(L2CAP_DEFAULT_RETRANS_TO);
	rfc.monitor_timeout = cpu_to_le16(L2CAP_DEFAULT_MONITOR_TO);
	rfc.max_pdu_size = cpu_to_le16(chan->imtu);

	BT_ERR("Expected RFC option was not found, using defaults");

2547 2548 2549
done:
	switch (rfc.mode) {
	case L2CAP_MODE_ERTM:
2550 2551 2552
		chan->retrans_timeout = le16_to_cpu(rfc.retrans_timeout);
		chan->monitor_timeout = le16_to_cpu(rfc.monitor_timeout);
		chan->mps    = le16_to_cpu(rfc.max_pdu_size);
2553 2554
		break;
	case L2CAP_MODE_STREAMING:
2555
		chan->mps    = le16_to_cpu(rfc.max_pdu_size);
2556 2557 2558
	}
}

2559 2560
static inline int l2cap_command_rej(struct l2cap_conn *conn, struct l2cap_cmd_hdr *cmd, u8 *data)
{
2561
	struct l2cap_cmd_rej_unk *rej = (struct l2cap_cmd_rej_unk *) data;
2562

2563
	if (rej->reason != L2CAP_REJ_NOT_UNDERSTOOD)
2564 2565 2566 2567
		return 0;

	if ((conn->info_state & L2CAP_INFO_FEAT_MASK_REQ_SENT) &&
					cmd->ident == conn->info_ident) {
2568
		cancel_delayed_work(&conn->info_timer);
2569 2570

		conn->info_state |= L2CAP_INFO_FEAT_MASK_REQ_DONE;
2571
		conn->info_ident = 0;
2572

2573 2574 2575 2576 2577 2578
		l2cap_conn_start(conn);
	}

	return 0;
}

L
Linus Torvalds 已提交
2579 2580 2581 2582
static inline int l2cap_connect_req(struct l2cap_conn *conn, struct l2cap_cmd_hdr *cmd, u8 *data)
{
	struct l2cap_conn_req *req = (struct l2cap_conn_req *) data;
	struct l2cap_conn_rsp rsp;
2583
	struct l2cap_chan *chan = NULL, *pchan;
2584
	struct sock *parent, *sk = NULL;
2585
	int result, status = L2CAP_CS_NO_INFO;
L
Linus Torvalds 已提交
2586 2587

	u16 dcid = 0, scid = __le16_to_cpu(req->scid);
2588
	__le16 psm = req->psm;
L
Linus Torvalds 已提交
2589 2590 2591 2592

	BT_DBG("psm 0x%2.2x scid 0x%4.4x", psm, scid);

	/* Check if we have socket listening on psm */
2593 2594
	pchan = l2cap_global_chan_by_psm(BT_LISTEN, psm, conn->src);
	if (!pchan) {
L
Linus Torvalds 已提交
2595 2596 2597 2598
		result = L2CAP_CR_BAD_PSM;
		goto sendresp;
	}

2599 2600
	parent = pchan->sk;

2601
	mutex_lock(&conn->chan_lock);
2602
	lock_sock(parent);
2603

2604 2605 2606
	/* Check if the ACL is secure enough (if not SDP) */
	if (psm != cpu_to_le16(0x0001) &&
				!hci_conn_check_link_mode(conn->hcon)) {
2607
		conn->disc_reason = HCI_ERROR_AUTH_FAILURE;
2608 2609 2610 2611
		result = L2CAP_CR_SEC_BLOCK;
		goto response;
	}

L
Linus Torvalds 已提交
2612 2613 2614 2615
	result = L2CAP_CR_NO_MEM;

	/* Check for backlog size */
	if (sk_acceptq_is_full(parent)) {
2616
		BT_DBG("backlog full %d", parent->sk_ack_backlog);
L
Linus Torvalds 已提交
2617 2618 2619
		goto response;
	}

2620 2621
	chan = pchan->ops->new_connection(pchan->data);
	if (!chan)
L
Linus Torvalds 已提交
2622 2623
		goto response;

2624 2625
	sk = chan->sk;

L
Linus Torvalds 已提交
2626
	/* Check if we already have channel with that dcid */
2627
	if (__l2cap_get_chan_by_dcid(conn, scid)) {
L
Linus Torvalds 已提交
2628
		sock_set_flag(sk, SOCK_ZAPPED);
2629
		chan->ops->close(chan->data);
L
Linus Torvalds 已提交
2630 2631 2632 2633 2634 2635 2636
		goto response;
	}

	hci_conn_hold(conn->hcon);

	bacpy(&bt_sk(sk)->src, conn->src);
	bacpy(&bt_sk(sk)->dst, conn->dst);
2637 2638
	chan->psm  = psm;
	chan->dcid = scid;
L
Linus Torvalds 已提交
2639

2640 2641
	bt_accept_enqueue(parent, sk);

2642
	l2cap_chan_add(conn, chan);
2643

2644
	dcid = chan->scid;
L
Linus Torvalds 已提交
2645

2646
	__set_chan_timer(chan, sk->sk_sndtimeo);
L
Linus Torvalds 已提交
2647

2648
	chan->ident = cmd->ident;
L
Linus Torvalds 已提交
2649

2650
	if (conn->info_state & L2CAP_INFO_FEAT_MASK_REQ_DONE) {
2651
		if (l2cap_chan_check_security(chan)) {
2652
			if (bt_sk(sk)->defer_setup) {
2653
				l2cap_state_change(chan, BT_CONNECT2);
2654 2655 2656 2657
				result = L2CAP_CR_PEND;
				status = L2CAP_CS_AUTHOR_PEND;
				parent->sk_data_ready(parent, 0);
			} else {
2658
				l2cap_state_change(chan, BT_CONFIG);
2659 2660 2661
				result = L2CAP_CR_SUCCESS;
				status = L2CAP_CS_NO_INFO;
			}
2662
		} else {
2663
			l2cap_state_change(chan, BT_CONNECT2);
2664 2665 2666 2667
			result = L2CAP_CR_PEND;
			status = L2CAP_CS_AUTHEN_PEND;
		}
	} else {
2668
		l2cap_state_change(chan, BT_CONNECT2);
2669 2670
		result = L2CAP_CR_PEND;
		status = L2CAP_CS_NO_INFO;
L
Linus Torvalds 已提交
2671 2672 2673
	}

response:
2674
	release_sock(parent);
2675
	mutex_unlock(&conn->chan_lock);
L
Linus Torvalds 已提交
2676 2677

sendresp:
2678 2679 2680 2681
	rsp.scid   = cpu_to_le16(scid);
	rsp.dcid   = cpu_to_le16(dcid);
	rsp.result = cpu_to_le16(result);
	rsp.status = cpu_to_le16(status);
L
Linus Torvalds 已提交
2682
	l2cap_send_cmd(conn, cmd->ident, L2CAP_CONN_RSP, sizeof(rsp), &rsp);
2683 2684 2685 2686 2687 2688 2689 2690

	if (result == L2CAP_CR_PEND && status == L2CAP_CS_NO_INFO) {
		struct l2cap_info_req info;
		info.type = cpu_to_le16(L2CAP_IT_FEAT_MASK);

		conn->info_state |= L2CAP_INFO_FEAT_MASK_REQ_SENT;
		conn->info_ident = l2cap_get_ident(conn);

2691
		schedule_delayed_work(&conn->info_timer,
2692 2693 2694 2695 2696 2697
					msecs_to_jiffies(L2CAP_INFO_TIMEOUT));

		l2cap_send_cmd(conn, conn->info_ident,
					L2CAP_INFO_REQ, sizeof(info), &info);
	}

2698
	if (chan && !test_bit(CONF_REQ_SENT, &chan->conf_state) &&
2699 2700
				result == L2CAP_CR_SUCCESS) {
		u8 buf[128];
2701
		set_bit(CONF_REQ_SENT, &chan->conf_state);
2702
		l2cap_send_cmd(conn, l2cap_get_ident(conn), L2CAP_CONF_REQ,
2703 2704
					l2cap_build_conf_req(chan, buf), buf);
		chan->num_conf_req++;
2705 2706
	}

L
Linus Torvalds 已提交
2707 2708 2709 2710 2711 2712 2713
	return 0;
}

static inline int l2cap_connect_rsp(struct l2cap_conn *conn, struct l2cap_cmd_hdr *cmd, u8 *data)
{
	struct l2cap_conn_rsp *rsp = (struct l2cap_conn_rsp *) data;
	u16 scid, dcid, result, status;
2714
	struct l2cap_chan *chan;
L
Linus Torvalds 已提交
2715 2716
	struct sock *sk;
	u8 req[128];
2717
	int err;
L
Linus Torvalds 已提交
2718 2719 2720 2721 2722 2723

	scid   = __le16_to_cpu(rsp->scid);
	dcid   = __le16_to_cpu(rsp->dcid);
	result = __le16_to_cpu(rsp->result);
	status = __le16_to_cpu(rsp->status);

2724 2725
	BT_DBG("dcid 0x%4.4x scid 0x%4.4x result 0x%2.2x status 0x%2.2x",
						dcid, scid, result, status);
L
Linus Torvalds 已提交
2726

2727 2728
	mutex_lock(&conn->chan_lock);

L
Linus Torvalds 已提交
2729
	if (scid) {
2730 2731 2732 2733 2734
		chan = __l2cap_get_chan_by_scid(conn, scid);
		if (!chan) {
			err = -EFAULT;
			goto unlock;
		}
L
Linus Torvalds 已提交
2735
	} else {
2736 2737 2738 2739 2740
		chan = __l2cap_get_chan_by_ident(conn, cmd->ident);
		if (!chan) {
			err = -EFAULT;
			goto unlock;
		}
L
Linus Torvalds 已提交
2741 2742
	}

2743 2744
	err = 0;

2745
	sk = chan->sk;
2746
	lock_sock(sk);
2747

L
Linus Torvalds 已提交
2748 2749
	switch (result) {
	case L2CAP_CR_SUCCESS:
2750
		l2cap_state_change(chan, BT_CONFIG);
2751
		chan->ident = 0;
2752
		chan->dcid = dcid;
2753
		clear_bit(CONF_CONNECT_PEND, &chan->conf_state);
2754

2755
		if (test_and_set_bit(CONF_REQ_SENT, &chan->conf_state))
2756 2757
			break;

L
Linus Torvalds 已提交
2758
		l2cap_send_cmd(conn, l2cap_get_ident(conn), L2CAP_CONF_REQ,
2759 2760
					l2cap_build_conf_req(chan, req), req);
		chan->num_conf_req++;
L
Linus Torvalds 已提交
2761 2762 2763
		break;

	case L2CAP_CR_PEND:
2764
		set_bit(CONF_CONNECT_PEND, &chan->conf_state);
L
Linus Torvalds 已提交
2765 2766 2767
		break;

	default:
2768
		l2cap_chan_del(chan, ECONNREFUSED);
L
Linus Torvalds 已提交
2769 2770 2771
		break;
	}

2772
	release_sock(sk);
2773 2774 2775 2776 2777

unlock:
	mutex_unlock(&conn->chan_lock);

	return err;
L
Linus Torvalds 已提交
2778 2779
}

2780
static inline void set_default_fcs(struct l2cap_chan *chan)
2781 2782 2783 2784
{
	/* FCS is enabled only in ERTM or streaming mode, if one or both
	 * sides request it.
	 */
2785
	if (chan->mode != L2CAP_MODE_ERTM && chan->mode != L2CAP_MODE_STREAMING)
2786
		chan->fcs = L2CAP_FCS_NONE;
2787
	else if (!test_bit(CONF_NO_FCS_RECV, &chan->conf_state))
2788
		chan->fcs = L2CAP_FCS_CRC16;
2789 2790
}

2791
static inline int l2cap_config_req(struct l2cap_conn *conn, struct l2cap_cmd_hdr *cmd, u16 cmd_len, u8 *data)
L
Linus Torvalds 已提交
2792 2793 2794 2795
{
	struct l2cap_conf_req *req = (struct l2cap_conf_req *) data;
	u16 dcid, flags;
	u8 rsp[64];
2796
	struct l2cap_chan *chan;
L
Linus Torvalds 已提交
2797
	struct sock *sk;
2798
	int len;
L
Linus Torvalds 已提交
2799 2800 2801 2802 2803 2804

	dcid  = __le16_to_cpu(req->dcid);
	flags = __le16_to_cpu(req->flags);

	BT_DBG("dcid 0x%4.4x flags 0x%2.2x", dcid, flags);

2805
	chan = l2cap_get_chan_by_scid(conn, dcid);
2806
	if (!chan)
L
Linus Torvalds 已提交
2807 2808
		return -ENOENT;

2809
	sk = chan->sk;
2810
	lock_sock(sk);
2811

2812
	if (chan->state != BT_CONFIG && chan->state != BT_CONNECT2) {
2813 2814 2815 2816 2817
		struct l2cap_cmd_rej_cid rej;

		rej.reason = cpu_to_le16(L2CAP_REJ_INVALID_CID);
		rej.scid = cpu_to_le16(chan->scid);
		rej.dcid = cpu_to_le16(chan->dcid);
2818 2819 2820

		l2cap_send_cmd(conn, cmd->ident, L2CAP_COMMAND_REJ,
				sizeof(rej), &rej);
2821
		goto unlock;
2822
	}
2823

2824
	/* Reject if config buffer is too small. */
2825
	len = cmd_len - sizeof(*req);
2826
	if (len < 0 || chan->conf_len + len > sizeof(chan->conf_req)) {
2827
		l2cap_send_cmd(conn, cmd->ident, L2CAP_CONF_RSP,
2828
				l2cap_build_conf_rsp(chan, rsp,
2829 2830 2831 2832 2833
					L2CAP_CONF_REJECT, flags), rsp);
		goto unlock;
	}

	/* Store config. */
2834 2835
	memcpy(chan->conf_req + chan->conf_len, req->data, len);
	chan->conf_len += len;
L
Linus Torvalds 已提交
2836 2837 2838 2839

	if (flags & 0x0001) {
		/* Incomplete config. Send empty response. */
		l2cap_send_cmd(conn, cmd->ident, L2CAP_CONF_RSP,
2840
				l2cap_build_conf_rsp(chan, rsp,
2841
					L2CAP_CONF_SUCCESS, 0x0001), rsp);
L
Linus Torvalds 已提交
2842 2843 2844 2845
		goto unlock;
	}

	/* Complete config. */
2846
	len = l2cap_parse_conf_req(chan, rsp);
2847
	if (len < 0) {
2848
		l2cap_send_disconn_req(conn, chan, ECONNRESET);
L
Linus Torvalds 已提交
2849
		goto unlock;
2850
	}
L
Linus Torvalds 已提交
2851

2852
	l2cap_send_cmd(conn, cmd->ident, L2CAP_CONF_RSP, len, rsp);
2853
	chan->num_conf_rsp++;
2854 2855

	/* Reset config buffer. */
2856
	chan->conf_len = 0;
2857

2858
	if (!test_bit(CONF_OUTPUT_DONE, &chan->conf_state))
2859 2860
		goto unlock;

2861
	if (test_bit(CONF_INPUT_DONE, &chan->conf_state)) {
2862
		set_default_fcs(chan);
2863

2864
		l2cap_state_change(chan, BT_CONNECTED);
2865

2866 2867
		chan->next_tx_seq = 0;
		chan->expected_tx_seq = 0;
2868
		skb_queue_head_init(&chan->tx_q);
2869
		if (chan->mode == L2CAP_MODE_ERTM)
2870
			l2cap_ertm_init(chan);
2871

2872
		l2cap_chan_ready(chan);
2873 2874 2875
		goto unlock;
	}

2876
	if (!test_and_set_bit(CONF_REQ_SENT, &chan->conf_state)) {
2877
		u8 buf[64];
L
Linus Torvalds 已提交
2878
		l2cap_send_cmd(conn, l2cap_get_ident(conn), L2CAP_CONF_REQ,
2879 2880
					l2cap_build_conf_req(chan, buf), buf);
		chan->num_conf_req++;
L
Linus Torvalds 已提交
2881 2882
	}

2883 2884 2885 2886 2887 2888 2889 2890 2891 2892 2893
	/* Got Conf Rsp PENDING from remote side and asume we sent
	   Conf Rsp PENDING in the code above */
	if (test_bit(CONF_REM_CONF_PEND, &chan->conf_state) &&
			test_bit(CONF_LOC_CONF_PEND, &chan->conf_state)) {

		/* check compatibility */

		clear_bit(CONF_LOC_CONF_PEND, &chan->conf_state);
		set_bit(CONF_OUTPUT_DONE, &chan->conf_state);

		l2cap_send_cmd(conn, cmd->ident, L2CAP_CONF_RSP,
2894
					l2cap_build_conf_rsp(chan, rsp,
2895 2896 2897
					L2CAP_CONF_SUCCESS, 0x0000), rsp);
	}

L
Linus Torvalds 已提交
2898
unlock:
2899
	release_sock(sk);
L
Linus Torvalds 已提交
2900 2901 2902 2903 2904 2905 2906
	return 0;
}

static inline int l2cap_config_rsp(struct l2cap_conn *conn, struct l2cap_cmd_hdr *cmd, u8 *data)
{
	struct l2cap_conf_rsp *rsp = (struct l2cap_conf_rsp *)data;
	u16 scid, flags, result;
2907
	struct l2cap_chan *chan;
L
Linus Torvalds 已提交
2908
	struct sock *sk;
2909
	int len = cmd->len - sizeof(*rsp);
L
Linus Torvalds 已提交
2910 2911 2912 2913 2914

	scid   = __le16_to_cpu(rsp->scid);
	flags  = __le16_to_cpu(rsp->flags);
	result = __le16_to_cpu(rsp->result);

2915 2916
	BT_DBG("scid 0x%4.4x flags 0x%2.2x result 0x%2.2x",
			scid, flags, result);
L
Linus Torvalds 已提交
2917

2918
	chan = l2cap_get_chan_by_scid(conn, scid);
2919
	if (!chan)
L
Linus Torvalds 已提交
2920 2921
		return 0;

2922
	sk = chan->sk;
2923
	lock_sock(sk);
2924

L
Linus Torvalds 已提交
2925 2926
	switch (result) {
	case L2CAP_CONF_SUCCESS:
2927
		l2cap_conf_rfc_get(chan, rsp->data, len);
2928
		clear_bit(CONF_REM_CONF_PEND, &chan->conf_state);
L
Linus Torvalds 已提交
2929 2930
		break;

2931 2932 2933 2934 2935 2936 2937 2938 2939 2940 2941 2942 2943 2944 2945 2946 2947 2948 2949
	case L2CAP_CONF_PENDING:
		set_bit(CONF_REM_CONF_PEND, &chan->conf_state);

		if (test_bit(CONF_LOC_CONF_PEND, &chan->conf_state)) {
			char buf[64];

			len = l2cap_parse_conf_rsp(chan, rsp->data, len,
								buf, &result);
			if (len < 0) {
				l2cap_send_disconn_req(conn, chan, ECONNRESET);
				goto done;
			}

			/* check compatibility */

			clear_bit(CONF_LOC_CONF_PEND, &chan->conf_state);
			set_bit(CONF_OUTPUT_DONE, &chan->conf_state);

			l2cap_send_cmd(conn, cmd->ident, L2CAP_CONF_RSP,
2950
						l2cap_build_conf_rsp(chan, buf,
2951 2952 2953 2954
						L2CAP_CONF_SUCCESS, 0x0000), buf);
		}
		goto done;

L
Linus Torvalds 已提交
2955
	case L2CAP_CONF_UNACCEPT:
2956
		if (chan->num_conf_rsp <= L2CAP_CONF_MAX_CONF_RSP) {
2957 2958
			char req[64];

2959
			if (len > sizeof(req) - sizeof(struct l2cap_conf_req)) {
2960
				l2cap_send_disconn_req(conn, chan, ECONNRESET);
2961 2962 2963
				goto done;
			}

2964 2965
			/* throw out any old stored conf requests */
			result = L2CAP_CONF_SUCCESS;
2966 2967
			len = l2cap_parse_conf_rsp(chan, rsp->data, len,
								req, &result);
2968
			if (len < 0) {
2969
				l2cap_send_disconn_req(conn, chan, ECONNRESET);
2970 2971 2972 2973 2974
				goto done;
			}

			l2cap_send_cmd(conn, l2cap_get_ident(conn),
						L2CAP_CONF_REQ, len, req);
2975
			chan->num_conf_req++;
2976 2977 2978
			if (result != L2CAP_CONF_SUCCESS)
				goto done;
			break;
L
Linus Torvalds 已提交
2979 2980
		}

2981
	default:
2982
		sk->sk_err = ECONNRESET;
2983 2984
		__set_chan_timer(chan,
				msecs_to_jiffies(L2CAP_DISC_REJ_TIMEOUT));
2985
		l2cap_send_disconn_req(conn, chan, ECONNRESET);
L
Linus Torvalds 已提交
2986 2987 2988 2989 2990 2991
		goto done;
	}

	if (flags & 0x01)
		goto done;

2992
	set_bit(CONF_INPUT_DONE, &chan->conf_state);
L
Linus Torvalds 已提交
2993

2994
	if (test_bit(CONF_OUTPUT_DONE, &chan->conf_state)) {
2995
		set_default_fcs(chan);
2996

2997
		l2cap_state_change(chan, BT_CONNECTED);
2998 2999
		chan->next_tx_seq = 0;
		chan->expected_tx_seq = 0;
3000
		skb_queue_head_init(&chan->tx_q);
3001
		if (chan->mode ==  L2CAP_MODE_ERTM)
3002
			l2cap_ertm_init(chan);
3003

3004
		l2cap_chan_ready(chan);
L
Linus Torvalds 已提交
3005 3006 3007
	}

done:
3008
	release_sock(sk);
L
Linus Torvalds 已提交
3009 3010 3011 3012 3013 3014 3015 3016
	return 0;
}

static inline int l2cap_disconnect_req(struct l2cap_conn *conn, struct l2cap_cmd_hdr *cmd, u8 *data)
{
	struct l2cap_disconn_req *req = (struct l2cap_disconn_req *) data;
	struct l2cap_disconn_rsp rsp;
	u16 dcid, scid;
3017
	struct l2cap_chan *chan;
L
Linus Torvalds 已提交
3018 3019 3020 3021 3022 3023 3024
	struct sock *sk;

	scid = __le16_to_cpu(req->scid);
	dcid = __le16_to_cpu(req->dcid);

	BT_DBG("scid 0x%4.4x dcid 0x%4.4x", scid, dcid);

3025 3026 3027 3028 3029
	mutex_lock(&conn->chan_lock);

	chan = __l2cap_get_chan_by_scid(conn, dcid);
	if (!chan) {
		mutex_unlock(&conn->chan_lock);
L
Linus Torvalds 已提交
3030
		return 0;
3031
	}
L
Linus Torvalds 已提交
3032

3033
	sk = chan->sk;
3034
	lock_sock(sk);
3035

3036 3037
	rsp.dcid = cpu_to_le16(chan->scid);
	rsp.scid = cpu_to_le16(chan->dcid);
L
Linus Torvalds 已提交
3038 3039 3040 3041
	l2cap_send_cmd(conn, cmd->ident, L2CAP_DISCONN_RSP, sizeof(rsp), &rsp);

	sk->sk_shutdown = SHUTDOWN_MASK;

3042
	l2cap_chan_del(chan, ECONNRESET);
3043
	release_sock(sk);
L
Linus Torvalds 已提交
3044

3045
	chan->ops->close(chan->data);
3046 3047 3048

	mutex_unlock(&conn->chan_lock);

L
Linus Torvalds 已提交
3049 3050 3051 3052 3053 3054 3055
	return 0;
}

static inline int l2cap_disconnect_rsp(struct l2cap_conn *conn, struct l2cap_cmd_hdr *cmd, u8 *data)
{
	struct l2cap_disconn_rsp *rsp = (struct l2cap_disconn_rsp *) data;
	u16 dcid, scid;
3056
	struct l2cap_chan *chan;
L
Linus Torvalds 已提交
3057 3058 3059 3060 3061 3062 3063
	struct sock *sk;

	scid = __le16_to_cpu(rsp->scid);
	dcid = __le16_to_cpu(rsp->dcid);

	BT_DBG("dcid 0x%4.4x scid 0x%4.4x", dcid, scid);

3064 3065 3066 3067 3068
	mutex_lock(&conn->chan_lock);

	chan = __l2cap_get_chan_by_scid(conn, scid);
	if (!chan) {
		mutex_unlock(&conn->chan_lock);
L
Linus Torvalds 已提交
3069
		return 0;
3070
	}
L
Linus Torvalds 已提交
3071

3072
	sk = chan->sk;
3073
	lock_sock(sk);
3074 3075

	l2cap_chan_del(chan, 0);
3076
	release_sock(sk);
L
Linus Torvalds 已提交
3077

3078
	chan->ops->close(chan->data);
3079 3080 3081

	mutex_unlock(&conn->chan_lock);

L
Linus Torvalds 已提交
3082 3083 3084 3085 3086 3087 3088 3089 3090 3091 3092 3093
	return 0;
}

static inline int l2cap_information_req(struct l2cap_conn *conn, struct l2cap_cmd_hdr *cmd, u8 *data)
{
	struct l2cap_info_req *req = (struct l2cap_info_req *) data;
	u16 type;

	type = __le16_to_cpu(req->type);

	BT_DBG("type 0x%4.4x", type);

3094 3095
	if (type == L2CAP_IT_FEAT_MASK) {
		u8 buf[8];
3096
		u32 feat_mask = l2cap_feat_mask;
3097 3098 3099
		struct l2cap_info_rsp *rsp = (struct l2cap_info_rsp *) buf;
		rsp->type   = cpu_to_le16(L2CAP_IT_FEAT_MASK);
		rsp->result = cpu_to_le16(L2CAP_IR_SUCCESS);
3100
		if (!disable_ertm)
3101 3102
			feat_mask |= L2CAP_FEAT_ERTM | L2CAP_FEAT_STREAMING
							 | L2CAP_FEAT_FCS;
3103
		if (enable_hs)
3104 3105
			feat_mask |= L2CAP_FEAT_EXT_FLOW
						| L2CAP_FEAT_EXT_WINDOW;
3106

3107
		put_unaligned_le32(feat_mask, rsp->data);
3108 3109
		l2cap_send_cmd(conn, cmd->ident,
					L2CAP_INFO_RSP, sizeof(buf), buf);
3110 3111 3112
	} else if (type == L2CAP_IT_FIXED_CHAN) {
		u8 buf[12];
		struct l2cap_info_rsp *rsp = (struct l2cap_info_rsp *) buf;
3113 3114 3115 3116 3117 3118

		if (enable_hs)
			l2cap_fixed_chan[0] |= L2CAP_FC_A2MP;
		else
			l2cap_fixed_chan[0] &= ~L2CAP_FC_A2MP;

3119 3120
		rsp->type   = cpu_to_le16(L2CAP_IT_FIXED_CHAN);
		rsp->result = cpu_to_le16(L2CAP_IR_SUCCESS);
3121
		memcpy(rsp->data, l2cap_fixed_chan, sizeof(l2cap_fixed_chan));
3122 3123
		l2cap_send_cmd(conn, cmd->ident,
					L2CAP_INFO_RSP, sizeof(buf), buf);
3124 3125 3126 3127 3128 3129 3130
	} else {
		struct l2cap_info_rsp rsp;
		rsp.type   = cpu_to_le16(type);
		rsp.result = cpu_to_le16(L2CAP_IR_NOTSUPP);
		l2cap_send_cmd(conn, cmd->ident,
					L2CAP_INFO_RSP, sizeof(rsp), &rsp);
	}
L
Linus Torvalds 已提交
3131 3132 3133 3134 3135 3136 3137 3138 3139 3140 3141 3142 3143 3144

	return 0;
}

static inline int l2cap_information_rsp(struct l2cap_conn *conn, struct l2cap_cmd_hdr *cmd, u8 *data)
{
	struct l2cap_info_rsp *rsp = (struct l2cap_info_rsp *) data;
	u16 type, result;

	type   = __le16_to_cpu(rsp->type);
	result = __le16_to_cpu(rsp->result);

	BT_DBG("type 0x%4.4x result 0x%2.2x", type, result);

3145 3146 3147 3148 3149
	/* L2CAP Info req/rsp are unbound to channels, add extra checks */
	if (cmd->ident != conn->info_ident ||
			conn->info_state & L2CAP_INFO_FEAT_MASK_REQ_DONE)
		return 0;

3150
	cancel_delayed_work(&conn->info_timer);
3151

3152 3153 3154 3155 3156 3157 3158 3159 3160
	if (result != L2CAP_IR_SUCCESS) {
		conn->info_state |= L2CAP_INFO_FEAT_MASK_REQ_DONE;
		conn->info_ident = 0;

		l2cap_conn_start(conn);

		return 0;
	}

3161
	if (type == L2CAP_IT_FEAT_MASK) {
3162
		conn->feat_mask = get_unaligned_le32(rsp->data);
3163

3164
		if (conn->feat_mask & L2CAP_FEAT_FIXED_CHAN) {
3165 3166 3167 3168 3169 3170 3171 3172 3173 3174 3175 3176 3177 3178
			struct l2cap_info_req req;
			req.type = cpu_to_le16(L2CAP_IT_FIXED_CHAN);

			conn->info_ident = l2cap_get_ident(conn);

			l2cap_send_cmd(conn, conn->info_ident,
					L2CAP_INFO_REQ, sizeof(req), &req);
		} else {
			conn->info_state |= L2CAP_INFO_FEAT_MASK_REQ_DONE;
			conn->info_ident = 0;

			l2cap_conn_start(conn);
		}
	} else if (type == L2CAP_IT_FIXED_CHAN) {
3179
		conn->info_state |= L2CAP_INFO_FEAT_MASK_REQ_DONE;
3180
		conn->info_ident = 0;
3181 3182 3183

		l2cap_conn_start(conn);
	}
3184

L
Linus Torvalds 已提交
3185 3186 3187
	return 0;
}

3188 3189 3190 3191 3192 3193 3194 3195 3196 3197 3198 3199 3200 3201 3202 3203 3204 3205 3206 3207 3208 3209 3210 3211 3212 3213 3214 3215 3216 3217 3218 3219 3220 3221 3222 3223 3224 3225 3226
static inline int l2cap_create_channel_req(struct l2cap_conn *conn,
					struct l2cap_cmd_hdr *cmd, u16 cmd_len,
					void *data)
{
	struct l2cap_create_chan_req *req = data;
	struct l2cap_create_chan_rsp rsp;
	u16 psm, scid;

	if (cmd_len != sizeof(*req))
		return -EPROTO;

	if (!enable_hs)
		return -EINVAL;

	psm = le16_to_cpu(req->psm);
	scid = le16_to_cpu(req->scid);

	BT_DBG("psm %d, scid %d, amp_id %d", psm, scid, req->amp_id);

	/* Placeholder: Always reject */
	rsp.dcid = 0;
	rsp.scid = cpu_to_le16(scid);
	rsp.result = L2CAP_CR_NO_MEM;
	rsp.status = L2CAP_CS_NO_INFO;

	l2cap_send_cmd(conn, cmd->ident, L2CAP_CREATE_CHAN_RSP,
		       sizeof(rsp), &rsp);

	return 0;
}

static inline int l2cap_create_channel_rsp(struct l2cap_conn *conn,
					struct l2cap_cmd_hdr *cmd, void *data)
{
	BT_DBG("conn %p", conn);

	return l2cap_connect_rsp(conn, cmd, data);
}

3227 3228 3229 3230 3231 3232 3233 3234 3235 3236 3237 3238 3239 3240 3241 3242 3243 3244 3245 3246 3247 3248 3249 3250 3251 3252 3253 3254 3255 3256 3257 3258 3259 3260 3261 3262 3263 3264 3265 3266 3267 3268 3269 3270 3271 3272 3273 3274 3275 3276 3277 3278 3279 3280 3281 3282 3283 3284 3285 3286 3287 3288 3289 3290 3291 3292 3293 3294 3295 3296 3297 3298 3299 3300 3301 3302 3303 3304 3305 3306 3307 3308 3309 3310 3311 3312 3313 3314 3315 3316 3317 3318 3319 3320 3321 3322 3323 3324 3325 3326 3327 3328 3329 3330 3331 3332 3333 3334 3335 3336 3337 3338 3339 3340 3341 3342 3343 3344 3345 3346
static void l2cap_send_move_chan_rsp(struct l2cap_conn *conn, u8 ident,
							u16 icid, u16 result)
{
	struct l2cap_move_chan_rsp rsp;

	BT_DBG("icid %d, result %d", icid, result);

	rsp.icid = cpu_to_le16(icid);
	rsp.result = cpu_to_le16(result);

	l2cap_send_cmd(conn, ident, L2CAP_MOVE_CHAN_RSP, sizeof(rsp), &rsp);
}

static void l2cap_send_move_chan_cfm(struct l2cap_conn *conn,
				struct l2cap_chan *chan, u16 icid, u16 result)
{
	struct l2cap_move_chan_cfm cfm;
	u8 ident;

	BT_DBG("icid %d, result %d", icid, result);

	ident = l2cap_get_ident(conn);
	if (chan)
		chan->ident = ident;

	cfm.icid = cpu_to_le16(icid);
	cfm.result = cpu_to_le16(result);

	l2cap_send_cmd(conn, ident, L2CAP_MOVE_CHAN_CFM, sizeof(cfm), &cfm);
}

static void l2cap_send_move_chan_cfm_rsp(struct l2cap_conn *conn, u8 ident,
								u16 icid)
{
	struct l2cap_move_chan_cfm_rsp rsp;

	BT_DBG("icid %d", icid);

	rsp.icid = cpu_to_le16(icid);
	l2cap_send_cmd(conn, ident, L2CAP_MOVE_CHAN_CFM_RSP, sizeof(rsp), &rsp);
}

static inline int l2cap_move_channel_req(struct l2cap_conn *conn,
			struct l2cap_cmd_hdr *cmd, u16 cmd_len, void *data)
{
	struct l2cap_move_chan_req *req = data;
	u16 icid = 0;
	u16 result = L2CAP_MR_NOT_ALLOWED;

	if (cmd_len != sizeof(*req))
		return -EPROTO;

	icid = le16_to_cpu(req->icid);

	BT_DBG("icid %d, dest_amp_id %d", icid, req->dest_amp_id);

	if (!enable_hs)
		return -EINVAL;

	/* Placeholder: Always refuse */
	l2cap_send_move_chan_rsp(conn, cmd->ident, icid, result);

	return 0;
}

static inline int l2cap_move_channel_rsp(struct l2cap_conn *conn,
			struct l2cap_cmd_hdr *cmd, u16 cmd_len, void *data)
{
	struct l2cap_move_chan_rsp *rsp = data;
	u16 icid, result;

	if (cmd_len != sizeof(*rsp))
		return -EPROTO;

	icid = le16_to_cpu(rsp->icid);
	result = le16_to_cpu(rsp->result);

	BT_DBG("icid %d, result %d", icid, result);

	/* Placeholder: Always unconfirmed */
	l2cap_send_move_chan_cfm(conn, NULL, icid, L2CAP_MC_UNCONFIRMED);

	return 0;
}

static inline int l2cap_move_channel_confirm(struct l2cap_conn *conn,
			struct l2cap_cmd_hdr *cmd, u16 cmd_len, void *data)
{
	struct l2cap_move_chan_cfm *cfm = data;
	u16 icid, result;

	if (cmd_len != sizeof(*cfm))
		return -EPROTO;

	icid = le16_to_cpu(cfm->icid);
	result = le16_to_cpu(cfm->result);

	BT_DBG("icid %d, result %d", icid, result);

	l2cap_send_move_chan_cfm_rsp(conn, cmd->ident, icid);

	return 0;
}

static inline int l2cap_move_channel_confirm_rsp(struct l2cap_conn *conn,
			struct l2cap_cmd_hdr *cmd, u16 cmd_len, void *data)
{
	struct l2cap_move_chan_cfm_rsp *rsp = data;
	u16 icid;

	if (cmd_len != sizeof(*rsp))
		return -EPROTO;

	icid = le16_to_cpu(rsp->icid);

	BT_DBG("icid %d", icid);

	return 0;
}

3347
static inline int l2cap_check_conn_param(u16 min, u16 max, u16 latency,
3348 3349 3350 3351 3352 3353 3354 3355 3356 3357 3358 3359 3360 3361 3362 3363 3364 3365 3366 3367 3368 3369 3370 3371 3372 3373 3374
							u16 to_multiplier)
{
	u16 max_latency;

	if (min > max || min < 6 || max > 3200)
		return -EINVAL;

	if (to_multiplier < 10 || to_multiplier > 3200)
		return -EINVAL;

	if (max >= to_multiplier * 8)
		return -EINVAL;

	max_latency = (to_multiplier * 8 / max) - 1;
	if (latency > 499 || latency > max_latency)
		return -EINVAL;

	return 0;
}

static inline int l2cap_conn_param_update_req(struct l2cap_conn *conn,
					struct l2cap_cmd_hdr *cmd, u8 *data)
{
	struct hci_conn *hcon = conn->hcon;
	struct l2cap_conn_param_update_req *req;
	struct l2cap_conn_param_update_rsp rsp;
	u16 min, max, latency, to_multiplier, cmd_len;
3375
	int err;
3376 3377 3378 3379 3380 3381 3382 3383 3384

	if (!(hcon->link_mode & HCI_LM_MASTER))
		return -EINVAL;

	cmd_len = __le16_to_cpu(cmd->len);
	if (cmd_len != sizeof(struct l2cap_conn_param_update_req))
		return -EPROTO;

	req = (struct l2cap_conn_param_update_req *) data;
3385 3386
	min		= __le16_to_cpu(req->min);
	max		= __le16_to_cpu(req->max);
3387 3388 3389 3390 3391 3392 3393
	latency		= __le16_to_cpu(req->latency);
	to_multiplier	= __le16_to_cpu(req->to_multiplier);

	BT_DBG("min 0x%4.4x max 0x%4.4x latency: 0x%4.4x Timeout: 0x%4.4x",
						min, max, latency, to_multiplier);

	memset(&rsp, 0, sizeof(rsp));
3394 3395 3396

	err = l2cap_check_conn_param(min, max, latency, to_multiplier);
	if (err)
3397 3398 3399 3400 3401 3402 3403
		rsp.result = cpu_to_le16(L2CAP_CONN_PARAM_REJECTED);
	else
		rsp.result = cpu_to_le16(L2CAP_CONN_PARAM_ACCEPTED);

	l2cap_send_cmd(conn, cmd->ident, L2CAP_CONN_PARAM_UPDATE_RSP,
							sizeof(rsp), &rsp);

3404 3405 3406
	if (!err)
		hci_le_conn_update(hcon, min, max, latency, to_multiplier);

3407 3408 3409
	return 0;
}

3410 3411 3412 3413 3414 3415 3416 3417 3418 3419 3420 3421 3422 3423 3424 3425 3426 3427 3428 3429 3430 3431 3432 3433 3434 3435 3436 3437 3438 3439 3440 3441 3442 3443 3444 3445 3446 3447 3448 3449 3450 3451 3452 3453 3454 3455 3456 3457 3458
static inline int l2cap_bredr_sig_cmd(struct l2cap_conn *conn,
			struct l2cap_cmd_hdr *cmd, u16 cmd_len, u8 *data)
{
	int err = 0;

	switch (cmd->code) {
	case L2CAP_COMMAND_REJ:
		l2cap_command_rej(conn, cmd, data);
		break;

	case L2CAP_CONN_REQ:
		err = l2cap_connect_req(conn, cmd, data);
		break;

	case L2CAP_CONN_RSP:
		err = l2cap_connect_rsp(conn, cmd, data);
		break;

	case L2CAP_CONF_REQ:
		err = l2cap_config_req(conn, cmd, cmd_len, data);
		break;

	case L2CAP_CONF_RSP:
		err = l2cap_config_rsp(conn, cmd, data);
		break;

	case L2CAP_DISCONN_REQ:
		err = l2cap_disconnect_req(conn, cmd, data);
		break;

	case L2CAP_DISCONN_RSP:
		err = l2cap_disconnect_rsp(conn, cmd, data);
		break;

	case L2CAP_ECHO_REQ:
		l2cap_send_cmd(conn, cmd->ident, L2CAP_ECHO_RSP, cmd_len, data);
		break;

	case L2CAP_ECHO_RSP:
		break;

	case L2CAP_INFO_REQ:
		err = l2cap_information_req(conn, cmd, data);
		break;

	case L2CAP_INFO_RSP:
		err = l2cap_information_rsp(conn, cmd, data);
		break;

3459 3460 3461 3462 3463 3464 3465 3466
	case L2CAP_CREATE_CHAN_REQ:
		err = l2cap_create_channel_req(conn, cmd, cmd_len, data);
		break;

	case L2CAP_CREATE_CHAN_RSP:
		err = l2cap_create_channel_rsp(conn, cmd, data);
		break;

3467 3468 3469 3470 3471 3472 3473 3474 3475 3476 3477 3478 3479 3480 3481 3482
	case L2CAP_MOVE_CHAN_REQ:
		err = l2cap_move_channel_req(conn, cmd, cmd_len, data);
		break;

	case L2CAP_MOVE_CHAN_RSP:
		err = l2cap_move_channel_rsp(conn, cmd, cmd_len, data);
		break;

	case L2CAP_MOVE_CHAN_CFM:
		err = l2cap_move_channel_confirm(conn, cmd, cmd_len, data);
		break;

	case L2CAP_MOVE_CHAN_CFM_RSP:
		err = l2cap_move_channel_confirm_rsp(conn, cmd, cmd_len, data);
		break;

3483 3484 3485 3486 3487 3488 3489 3490 3491 3492 3493 3494 3495 3496 3497 3498 3499
	default:
		BT_ERR("Unknown BR/EDR signaling command 0x%2.2x", cmd->code);
		err = -EINVAL;
		break;
	}

	return err;
}

static inline int l2cap_le_sig_cmd(struct l2cap_conn *conn,
					struct l2cap_cmd_hdr *cmd, u8 *data)
{
	switch (cmd->code) {
	case L2CAP_COMMAND_REJ:
		return 0;

	case L2CAP_CONN_PARAM_UPDATE_REQ:
3500
		return l2cap_conn_param_update_req(conn, cmd, data);
3501 3502 3503 3504 3505 3506 3507 3508 3509 3510 3511 3512

	case L2CAP_CONN_PARAM_UPDATE_RSP:
		return 0;

	default:
		BT_ERR("Unknown LE signaling command 0x%2.2x", cmd->code);
		return -EINVAL;
	}
}

static inline void l2cap_sig_channel(struct l2cap_conn *conn,
							struct sk_buff *skb)
L
Linus Torvalds 已提交
3513 3514 3515 3516
{
	u8 *data = skb->data;
	int len = skb->len;
	struct l2cap_cmd_hdr cmd;
3517
	int err;
L
Linus Torvalds 已提交
3518 3519 3520 3521

	l2cap_raw_recv(conn, skb);

	while (len >= L2CAP_CMD_HDR_SIZE) {
3522
		u16 cmd_len;
L
Linus Torvalds 已提交
3523 3524 3525 3526
		memcpy(&cmd, data, L2CAP_CMD_HDR_SIZE);
		data += L2CAP_CMD_HDR_SIZE;
		len  -= L2CAP_CMD_HDR_SIZE;

3527
		cmd_len = le16_to_cpu(cmd.len);
L
Linus Torvalds 已提交
3528

3529
		BT_DBG("code 0x%2.2x len %d id 0x%2.2x", cmd.code, cmd_len, cmd.ident);
L
Linus Torvalds 已提交
3530

3531
		if (cmd_len > len || !cmd.ident) {
L
Linus Torvalds 已提交
3532 3533 3534 3535
			BT_DBG("corrupted command");
			break;
		}

3536 3537 3538 3539
		if (conn->hcon->type == LE_LINK)
			err = l2cap_le_sig_cmd(conn, &cmd, data);
		else
			err = l2cap_bredr_sig_cmd(conn, &cmd, cmd_len, data);
L
Linus Torvalds 已提交
3540 3541

		if (err) {
3542
			struct l2cap_cmd_rej_unk rej;
3543 3544

			BT_ERR("Wrong link type (%d)", err);
L
Linus Torvalds 已提交
3545 3546

			/* FIXME: Map err to a valid reason */
3547
			rej.reason = cpu_to_le16(L2CAP_REJ_NOT_UNDERSTOOD);
L
Linus Torvalds 已提交
3548 3549 3550
			l2cap_send_cmd(conn, cmd.ident, L2CAP_COMMAND_REJ, sizeof(rej), &rej);
		}

3551 3552
		data += cmd_len;
		len  -= cmd_len;
L
Linus Torvalds 已提交
3553 3554 3555 3556 3557
	}

	kfree_skb(skb);
}

3558
static int l2cap_check_fcs(struct l2cap_chan *chan,  struct sk_buff *skb)
3559 3560
{
	u16 our_fcs, rcv_fcs;
3561 3562 3563 3564 3565 3566
	int hdr_size;

	if (test_bit(FLAG_EXT_CTRL, &chan->flags))
		hdr_size = L2CAP_EXT_HDR_SIZE;
	else
		hdr_size = L2CAP_ENH_HDR_SIZE;
3567

3568
	if (chan->fcs == L2CAP_FCS_CRC16) {
3569
		skb_trim(skb, skb->len - L2CAP_FCS_SIZE);
3570 3571 3572 3573
		rcv_fcs = get_unaligned_le16(skb->data + skb->len);
		our_fcs = crc16(0, skb->data - hdr_size, skb->len + hdr_size);

		if (our_fcs != rcv_fcs)
3574
			return -EBADMSG;
3575 3576 3577 3578
	}
	return 0;
}

3579
static inline void l2cap_send_i_or_rr_or_rnr(struct l2cap_chan *chan)
3580
{
3581
	u32 control = 0;
3582

3583
	chan->frames_sent = 0;
3584

3585
	control |= __set_reqseq(chan, chan->buffer_seq);
3586

3587
	if (test_bit(CONN_LOCAL_BUSY, &chan->conn_state)) {
3588
		control |= __set_ctrl_super(chan, L2CAP_SUPER_RNR);
3589
		l2cap_send_sframe(chan, control);
3590
		set_bit(CONN_RNR_SENT, &chan->conn_state);
3591 3592
	}

3593
	if (test_bit(CONN_REMOTE_BUSY, &chan->conn_state))
3594
		l2cap_retransmit_frames(chan);
3595

3596
	l2cap_ertm_send(chan);
3597

3598
	if (!test_bit(CONN_LOCAL_BUSY, &chan->conn_state) &&
3599
			chan->frames_sent == 0) {
3600
		control |= __set_ctrl_super(chan, L2CAP_SUPER_RR);
3601
		l2cap_send_sframe(chan, control);
3602 3603 3604
	}
}

3605
static int l2cap_add_to_srej_queue(struct l2cap_chan *chan, struct sk_buff *skb, u16 tx_seq, u8 sar)
3606 3607
{
	struct sk_buff *next_skb;
3608
	int tx_seq_offset, next_tx_seq_offset;
3609 3610 3611 3612

	bt_cb(skb)->tx_seq = tx_seq;
	bt_cb(skb)->sar = sar;

3613
	next_skb = skb_peek(&chan->srej_q);
3614

3615
	tx_seq_offset = __seq_offset(chan, tx_seq, chan->buffer_seq);
3616

3617
	while (next_skb) {
3618 3619 3620
		if (bt_cb(next_skb)->tx_seq == tx_seq)
			return -EINVAL;

3621 3622
		next_tx_seq_offset = __seq_offset(chan,
				bt_cb(next_skb)->tx_seq, chan->buffer_seq);
3623 3624

		if (next_tx_seq_offset > tx_seq_offset) {
3625
			__skb_queue_before(&chan->srej_q, next_skb, skb);
3626
			return 0;
3627 3628
		}

3629
		if (skb_queue_is_last(&chan->srej_q, next_skb))
3630 3631 3632 3633
			next_skb = NULL;
		else
			next_skb = skb_queue_next(&chan->srej_q, next_skb);
	}
3634

3635
	__skb_queue_tail(&chan->srej_q, skb);
3636 3637

	return 0;
3638 3639
}

3640 3641
static void append_skb_frag(struct sk_buff *skb,
			struct sk_buff *new_frag, struct sk_buff **last_frag)
3642
{
3643 3644 3645 3646 3647 3648 3649 3650 3651 3652 3653 3654 3655 3656 3657 3658
	/* skb->len reflects data in skb as well as all fragments
	 * skb->data_len reflects only data in fragments
	 */
	if (!skb_has_frag_list(skb))
		skb_shinfo(skb)->frag_list = new_frag;

	new_frag->next = NULL;

	(*last_frag)->next = new_frag;
	*last_frag = new_frag;

	skb->len += new_frag->len;
	skb->data_len += new_frag->len;
	skb->truesize += new_frag->truesize;
}

3659
static int l2cap_reassemble_sdu(struct l2cap_chan *chan, struct sk_buff *skb, u32 control)
3660 3661
{
	int err = -EINVAL;
3662

3663 3664
	switch (__get_ctrl_sar(chan, control)) {
	case L2CAP_SAR_UNSEGMENTED:
3665 3666
		if (chan->sdu)
			break;
3667

3668 3669
		err = chan->ops->recv(chan->data, skb);
		break;
3670

3671
	case L2CAP_SAR_START:
3672 3673
		if (chan->sdu)
			break;
3674

3675
		chan->sdu_len = get_unaligned_le16(skb->data);
3676
		skb_pull(skb, L2CAP_SDULEN_SIZE);
3677

3678 3679 3680 3681
		if (chan->sdu_len > chan->imtu) {
			err = -EMSGSIZE;
			break;
		}
3682

3683 3684
		if (skb->len >= chan->sdu_len)
			break;
3685

3686 3687
		chan->sdu = skb;
		chan->sdu_last_frag = skb;
3688

3689 3690
		skb = NULL;
		err = 0;
3691 3692
		break;

3693
	case L2CAP_SAR_CONTINUE:
3694
		if (!chan->sdu)
3695
			break;
3696

3697 3698 3699
		append_skb_frag(chan->sdu, skb,
				&chan->sdu_last_frag);
		skb = NULL;
3700

3701 3702
		if (chan->sdu->len >= chan->sdu_len)
			break;
3703

3704
		err = 0;
3705 3706
		break;

3707
	case L2CAP_SAR_END:
3708
		if (!chan->sdu)
3709
			break;
3710

3711 3712 3713
		append_skb_frag(chan->sdu, skb,
				&chan->sdu_last_frag);
		skb = NULL;
3714

3715 3716
		if (chan->sdu->len != chan->sdu_len)
			break;
3717

3718
		err = chan->ops->recv(chan->data, chan->sdu);
3719

3720 3721 3722 3723 3724
		if (!err) {
			/* Reassembly complete */
			chan->sdu = NULL;
			chan->sdu_last_frag = NULL;
			chan->sdu_len = 0;
3725
		}
3726 3727 3728
		break;
	}

3729 3730 3731 3732 3733 3734 3735
	if (err) {
		kfree_skb(skb);
		kfree_skb(chan->sdu);
		chan->sdu = NULL;
		chan->sdu_last_frag = NULL;
		chan->sdu_len = 0;
	}
3736

3737
	return err;
3738 3739
}

3740
static void l2cap_ertm_enter_local_busy(struct l2cap_chan *chan)
3741
{
3742
	BT_DBG("chan %p, Enter local busy", chan);
3743

3744 3745
	set_bit(CONN_LOCAL_BUSY, &chan->conn_state);

3746
	__set_ack_timer(chan);
3747 3748 3749 3750
}

static void l2cap_ertm_exit_local_busy(struct l2cap_chan *chan)
{
3751
	u32 control;
3752

3753
	if (!test_bit(CONN_RNR_SENT, &chan->conn_state))
3754 3755
		goto done;

3756
	control = __set_reqseq(chan, chan->buffer_seq);
3757
	control |= __set_ctrl_poll(chan);
3758
	control |= __set_ctrl_super(chan, L2CAP_SUPER_RR);
3759
	l2cap_send_sframe(chan, control);
3760
	chan->retry_count = 1;
3761

3762 3763
	__clear_retrans_timer(chan);
	__set_monitor_timer(chan);
3764

3765
	set_bit(CONN_WAIT_F, &chan->conn_state);
3766 3767

done:
3768 3769
	clear_bit(CONN_LOCAL_BUSY, &chan->conn_state);
	clear_bit(CONN_RNR_SENT, &chan->conn_state);
3770

3771
	BT_DBG("chan %p, Exit local busy", chan);
3772 3773
}

3774
void l2cap_chan_busy(struct l2cap_chan *chan, int busy)
3775
{
3776 3777 3778 3779 3780
	if (chan->mode == L2CAP_MODE_ERTM) {
		if (busy)
			l2cap_ertm_enter_local_busy(chan);
		else
			l2cap_ertm_exit_local_busy(chan);
3781 3782 3783
	}
}

3784
static void l2cap_check_srej_gap(struct l2cap_chan *chan, u16 tx_seq)
3785 3786
{
	struct sk_buff *skb;
3787
	u32 control;
3788

3789 3790 3791 3792
	while ((skb = skb_peek(&chan->srej_q)) &&
			!test_bit(CONN_LOCAL_BUSY, &chan->conn_state)) {
		int err;

3793 3794 3795
		if (bt_cb(skb)->tx_seq != tx_seq)
			break;

3796
		skb = skb_dequeue(&chan->srej_q);
3797
		control = __set_ctrl_sar(chan, bt_cb(skb)->sar);
3798
		err = l2cap_reassemble_sdu(chan, skb, control);
3799 3800 3801 3802 3803 3804

		if (err < 0) {
			l2cap_send_disconn_req(chan->conn, chan, ECONNRESET);
			break;
		}

3805 3806
		chan->buffer_seq_srej = __next_seq(chan, chan->buffer_seq_srej);
		tx_seq = __next_seq(chan, tx_seq);
3807 3808 3809
	}
}

3810
static void l2cap_resend_srejframe(struct l2cap_chan *chan, u16 tx_seq)
3811 3812
{
	struct srej_list *l, *tmp;
3813
	u32 control;
3814

3815
	list_for_each_entry_safe(l, tmp, &chan->srej_l, list) {
3816 3817 3818 3819 3820
		if (l->tx_seq == tx_seq) {
			list_del(&l->list);
			kfree(l);
			return;
		}
3821
		control = __set_ctrl_super(chan, L2CAP_SUPER_SREJ);
3822
		control |= __set_reqseq(chan, l->tx_seq);
3823
		l2cap_send_sframe(chan, control);
3824
		list_del(&l->list);
3825
		list_add_tail(&l->list, &chan->srej_l);
3826 3827 3828
	}
}

3829
static int l2cap_send_srejframe(struct l2cap_chan *chan, u16 tx_seq)
3830 3831
{
	struct srej_list *new;
3832
	u32 control;
3833

3834
	while (tx_seq != chan->expected_tx_seq) {
3835
		control = __set_ctrl_super(chan, L2CAP_SUPER_SREJ);
3836
		control |= __set_reqseq(chan, chan->expected_tx_seq);
3837
		l2cap_send_sframe(chan, control);
3838 3839

		new = kzalloc(sizeof(struct srej_list), GFP_ATOMIC);
3840 3841 3842
		if (!new)
			return -ENOMEM;

3843
		new->tx_seq = chan->expected_tx_seq;
3844 3845 3846

		chan->expected_tx_seq = __next_seq(chan, chan->expected_tx_seq);

3847
		list_add_tail(&new->list, &chan->srej_l);
3848
	}
3849 3850

	chan->expected_tx_seq = __next_seq(chan, chan->expected_tx_seq);
3851 3852

	return 0;
3853 3854
}

3855
static inline int l2cap_data_channel_iframe(struct l2cap_chan *chan, u32 rx_control, struct sk_buff *skb)
3856
{
3857
	u16 tx_seq = __get_txseq(chan, rx_control);
3858
	u16 req_seq = __get_reqseq(chan, rx_control);
3859
	u8 sar = __get_ctrl_sar(chan, rx_control);
3860
	int tx_seq_offset, expected_tx_seq_offset;
3861
	int num_to_ack = (chan->tx_win/6) + 1;
3862 3863
	int err = 0;

3864
	BT_DBG("chan %p len %d tx_seq %d rx_control 0x%8.8x", chan, skb->len,
3865
							tx_seq, rx_control);
3866

3867
	if (__is_ctrl_final(chan, rx_control) &&
3868
			test_bit(CONN_WAIT_F, &chan->conn_state)) {
3869
		__clear_monitor_timer(chan);
3870
		if (chan->unacked_frames > 0)
3871
			__set_retrans_timer(chan);
3872
		clear_bit(CONN_WAIT_F, &chan->conn_state);
3873 3874
	}

3875 3876
	chan->expected_ack_seq = req_seq;
	l2cap_drop_acked_frames(chan);
3877

3878
	tx_seq_offset = __seq_offset(chan, tx_seq, chan->buffer_seq);
3879 3880

	/* invalid tx_seq */
3881
	if (tx_seq_offset >= chan->tx_win) {
3882
		l2cap_send_disconn_req(chan->conn, chan, ECONNRESET);
3883 3884 3885
		goto drop;
	}

3886 3887 3888
	if (test_bit(CONN_LOCAL_BUSY, &chan->conn_state)) {
		if (!test_bit(CONN_RNR_SENT, &chan->conn_state))
			l2cap_send_ack(chan);
3889
		goto drop;
3890
	}
3891

3892 3893 3894
	if (tx_seq == chan->expected_tx_seq)
		goto expected;

3895
	if (test_bit(CONN_SREJ_SENT, &chan->conn_state)) {
3896
		struct srej_list *first;
3897

3898
		first = list_first_entry(&chan->srej_l,
3899 3900
				struct srej_list, list);
		if (tx_seq == first->tx_seq) {
3901
			l2cap_add_to_srej_queue(chan, skb, tx_seq, sar);
3902
			l2cap_check_srej_gap(chan, tx_seq);
3903 3904 3905 3906

			list_del(&first->list);
			kfree(first);

3907
			if (list_empty(&chan->srej_l)) {
3908
				chan->buffer_seq = chan->buffer_seq_srej;
3909
				clear_bit(CONN_SREJ_SENT, &chan->conn_state);
3910
				l2cap_send_ack(chan);
3911
				BT_DBG("chan %p, Exit SREJ_SENT", chan);
3912 3913 3914
			}
		} else {
			struct srej_list *l;
3915 3916

			/* duplicated tx_seq */
3917
			if (l2cap_add_to_srej_queue(chan, skb, tx_seq, sar) < 0)
3918
				goto drop;
3919

3920
			list_for_each_entry(l, &chan->srej_l, list) {
3921
				if (l->tx_seq == tx_seq) {
3922
					l2cap_resend_srejframe(chan, tx_seq);
3923 3924 3925
					return 0;
				}
			}
3926 3927 3928 3929 3930 3931

			err = l2cap_send_srejframe(chan, tx_seq);
			if (err < 0) {
				l2cap_send_disconn_req(chan->conn, chan, -err);
				return err;
			}
3932 3933
		}
	} else {
3934 3935
		expected_tx_seq_offset = __seq_offset(chan,
				chan->expected_tx_seq, chan->buffer_seq);
3936 3937 3938 3939 3940

		/* duplicated tx_seq */
		if (tx_seq_offset < expected_tx_seq_offset)
			goto drop;

3941
		set_bit(CONN_SREJ_SENT, &chan->conn_state);
3942

3943
		BT_DBG("chan %p, Enter SREJ", chan);
3944

3945
		INIT_LIST_HEAD(&chan->srej_l);
3946
		chan->buffer_seq_srej = chan->buffer_seq;
3947

3948
		__skb_queue_head_init(&chan->srej_q);
3949
		l2cap_add_to_srej_queue(chan, skb, tx_seq, sar);
3950

3951 3952 3953
		/* Set P-bit only if there are some I-frames to ack. */
		if (__clear_ack_timer(chan))
			set_bit(CONN_SEND_PBIT, &chan->conn_state);
3954

3955 3956 3957 3958 3959
		err = l2cap_send_srejframe(chan, tx_seq);
		if (err < 0) {
			l2cap_send_disconn_req(chan->conn, chan, -err);
			return err;
		}
3960
	}
3961 3962
	return 0;

3963
expected:
3964
	chan->expected_tx_seq = __next_seq(chan, chan->expected_tx_seq);
3965

3966
	if (test_bit(CONN_SREJ_SENT, &chan->conn_state)) {
3967 3968
		bt_cb(skb)->tx_seq = tx_seq;
		bt_cb(skb)->sar = sar;
3969
		__skb_queue_tail(&chan->srej_q, skb);
3970 3971 3972
		return 0;
	}

3973
	err = l2cap_reassemble_sdu(chan, skb, rx_control);
3974 3975
	chan->buffer_seq = __next_seq(chan, chan->buffer_seq);

3976 3977 3978 3979
	if (err < 0) {
		l2cap_send_disconn_req(chan->conn, chan, ECONNRESET);
		return err;
	}
3980

3981
	if (__is_ctrl_final(chan, rx_control)) {
3982
		if (!test_and_clear_bit(CONN_REJ_ACT, &chan->conn_state))
3983
			l2cap_retransmit_frames(chan);
3984 3985
	}

3986

3987 3988
	chan->num_acked = (chan->num_acked + 1) % num_to_ack;
	if (chan->num_acked == num_to_ack - 1)
3989
		l2cap_send_ack(chan);
3990 3991
	else
		__set_ack_timer(chan);
3992

3993
	return 0;
3994 3995 3996 3997

drop:
	kfree_skb(skb);
	return 0;
3998 3999
}

4000
static inline void l2cap_data_channel_rrframe(struct l2cap_chan *chan, u32 rx_control)
4001
{
4002
	BT_DBG("chan %p, req_seq %d ctrl 0x%8.8x", chan,
4003
				__get_reqseq(chan, rx_control), rx_control);
4004

4005
	chan->expected_ack_seq = __get_reqseq(chan, rx_control);
4006
	l2cap_drop_acked_frames(chan);
4007

4008
	if (__is_ctrl_poll(chan, rx_control)) {
4009 4010 4011
		set_bit(CONN_SEND_FBIT, &chan->conn_state);
		if (test_bit(CONN_SREJ_SENT, &chan->conn_state)) {
			if (test_bit(CONN_REMOTE_BUSY, &chan->conn_state) &&
4012
					(chan->unacked_frames > 0))
4013
				__set_retrans_timer(chan);
4014

4015
			clear_bit(CONN_REMOTE_BUSY, &chan->conn_state);
4016
			l2cap_send_srejtail(chan);
4017
		} else {
4018
			l2cap_send_i_or_rr_or_rnr(chan);
4019
		}
4020

4021
	} else if (__is_ctrl_final(chan, rx_control)) {
4022
		clear_bit(CONN_REMOTE_BUSY, &chan->conn_state);
4023

4024
		if (!test_and_clear_bit(CONN_REJ_ACT, &chan->conn_state))
4025
			l2cap_retransmit_frames(chan);
4026

4027
	} else {
4028
		if (test_bit(CONN_REMOTE_BUSY, &chan->conn_state) &&
4029
				(chan->unacked_frames > 0))
4030
			__set_retrans_timer(chan);
4031

4032 4033
		clear_bit(CONN_REMOTE_BUSY, &chan->conn_state);
		if (test_bit(CONN_SREJ_SENT, &chan->conn_state))
4034
			l2cap_send_ack(chan);
4035
		else
4036
			l2cap_ertm_send(chan);
4037 4038
	}
}
4039

4040
static inline void l2cap_data_channel_rejframe(struct l2cap_chan *chan, u32 rx_control)
4041
{
4042
	u16 tx_seq = __get_reqseq(chan, rx_control);
4043

4044
	BT_DBG("chan %p, req_seq %d ctrl 0x%8.8x", chan, tx_seq, rx_control);
4045

4046
	clear_bit(CONN_REMOTE_BUSY, &chan->conn_state);
4047

4048 4049
	chan->expected_ack_seq = tx_seq;
	l2cap_drop_acked_frames(chan);
4050

4051
	if (__is_ctrl_final(chan, rx_control)) {
4052
		if (!test_and_clear_bit(CONN_REJ_ACT, &chan->conn_state))
4053
			l2cap_retransmit_frames(chan);
4054
	} else {
4055
		l2cap_retransmit_frames(chan);
4056

4057 4058
		if (test_bit(CONN_WAIT_F, &chan->conn_state))
			set_bit(CONN_REJ_ACT, &chan->conn_state);
4059 4060
	}
}
4061
static inline void l2cap_data_channel_srejframe(struct l2cap_chan *chan, u32 rx_control)
4062
{
4063
	u16 tx_seq = __get_reqseq(chan, rx_control);
4064

4065
	BT_DBG("chan %p, req_seq %d ctrl 0x%8.8x", chan, tx_seq, rx_control);
4066

4067
	clear_bit(CONN_REMOTE_BUSY, &chan->conn_state);
4068

4069
	if (__is_ctrl_poll(chan, rx_control)) {
4070 4071
		chan->expected_ack_seq = tx_seq;
		l2cap_drop_acked_frames(chan);
4072

4073
		set_bit(CONN_SEND_FBIT, &chan->conn_state);
4074
		l2cap_retransmit_one_frame(chan, tx_seq);
4075

4076
		l2cap_ertm_send(chan);
4077

4078
		if (test_bit(CONN_WAIT_F, &chan->conn_state)) {
4079
			chan->srej_save_reqseq = tx_seq;
4080
			set_bit(CONN_SREJ_ACT, &chan->conn_state);
4081
		}
4082
	} else if (__is_ctrl_final(chan, rx_control)) {
4083
		if (test_bit(CONN_SREJ_ACT, &chan->conn_state) &&
4084
				chan->srej_save_reqseq == tx_seq)
4085
			clear_bit(CONN_SREJ_ACT, &chan->conn_state);
4086
		else
4087
			l2cap_retransmit_one_frame(chan, tx_seq);
4088
	} else {
4089
		l2cap_retransmit_one_frame(chan, tx_seq);
4090
		if (test_bit(CONN_WAIT_F, &chan->conn_state)) {
4091
			chan->srej_save_reqseq = tx_seq;
4092
			set_bit(CONN_SREJ_ACT, &chan->conn_state);
4093
		}
4094 4095 4096
	}
}

4097
static inline void l2cap_data_channel_rnrframe(struct l2cap_chan *chan, u32 rx_control)
4098
{
4099
	u16 tx_seq = __get_reqseq(chan, rx_control);
4100

4101
	BT_DBG("chan %p, req_seq %d ctrl 0x%8.8x", chan, tx_seq, rx_control);
4102

4103
	set_bit(CONN_REMOTE_BUSY, &chan->conn_state);
4104 4105
	chan->expected_ack_seq = tx_seq;
	l2cap_drop_acked_frames(chan);
4106

4107
	if (__is_ctrl_poll(chan, rx_control))
4108
		set_bit(CONN_SEND_FBIT, &chan->conn_state);
4109

4110
	if (!test_bit(CONN_SREJ_SENT, &chan->conn_state)) {
4111
		__clear_retrans_timer(chan);
4112
		if (__is_ctrl_poll(chan, rx_control))
4113
			l2cap_send_rr_or_rnr(chan, L2CAP_CTRL_FINAL);
4114
		return;
4115
	}
4116

4117
	if (__is_ctrl_poll(chan, rx_control)) {
4118
		l2cap_send_srejtail(chan);
4119 4120 4121 4122
	} else {
		rx_control = __set_ctrl_super(chan, L2CAP_SUPER_RR);
		l2cap_send_sframe(chan, rx_control);
	}
4123 4124
}

4125
static inline int l2cap_data_channel_sframe(struct l2cap_chan *chan, u32 rx_control, struct sk_buff *skb)
4126
{
4127
	BT_DBG("chan %p rx_control 0x%8.8x len %d", chan, rx_control, skb->len);
4128

4129
	if (__is_ctrl_final(chan, rx_control) &&
4130
			test_bit(CONN_WAIT_F, &chan->conn_state)) {
4131
		__clear_monitor_timer(chan);
4132
		if (chan->unacked_frames > 0)
4133
			__set_retrans_timer(chan);
4134
		clear_bit(CONN_WAIT_F, &chan->conn_state);
4135 4136
	}

4137 4138
	switch (__get_ctrl_super(chan, rx_control)) {
	case L2CAP_SUPER_RR:
4139
		l2cap_data_channel_rrframe(chan, rx_control);
4140 4141
		break;

4142
	case L2CAP_SUPER_REJ:
4143
		l2cap_data_channel_rejframe(chan, rx_control);
4144
		break;
4145

4146
	case L2CAP_SUPER_SREJ:
4147
		l2cap_data_channel_srejframe(chan, rx_control);
4148 4149
		break;

4150
	case L2CAP_SUPER_RNR:
4151
		l2cap_data_channel_rnrframe(chan, rx_control);
4152 4153 4154
		break;
	}

4155
	kfree_skb(skb);
4156 4157 4158
	return 0;
}

4159
static int l2cap_ertm_data_rcv(struct l2cap_chan *chan, struct sk_buff *skb)
4160
{
4161
	u32 control;
4162
	u16 req_seq;
4163 4164
	int len, next_tx_seq_offset, req_seq_offset;

4165 4166
	control = __get_control(chan, skb->data);
	skb_pull(skb, __ctrl_size(chan));
4167 4168 4169 4170 4171 4172 4173
	len = skb->len;

	/*
	 * We can just drop the corrupted I-frame here.
	 * Receiver will miss it and start proper recovery
	 * procedures and ask retransmission.
	 */
4174
	if (l2cap_check_fcs(chan, skb))
4175 4176
		goto drop;

4177
	if (__is_sar_start(chan, control) && !__is_sframe(chan, control))
4178
		len -= L2CAP_SDULEN_SIZE;
4179

4180
	if (chan->fcs == L2CAP_FCS_CRC16)
4181
		len -= L2CAP_FCS_SIZE;
4182

4183
	if (len > chan->mps) {
4184
		l2cap_send_disconn_req(chan->conn, chan, ECONNRESET);
4185 4186 4187
		goto drop;
	}

4188
	req_seq = __get_reqseq(chan, control);
4189

4190 4191 4192 4193
	req_seq_offset = __seq_offset(chan, req_seq, chan->expected_ack_seq);

	next_tx_seq_offset = __seq_offset(chan, chan->next_tx_seq,
						chan->expected_ack_seq);
4194 4195 4196

	/* check for invalid req-seq */
	if (req_seq_offset > next_tx_seq_offset) {
4197
		l2cap_send_disconn_req(chan->conn, chan, ECONNRESET);
4198 4199 4200
		goto drop;
	}

4201
	if (!__is_sframe(chan, control)) {
4202
		if (len < 0) {
4203
			l2cap_send_disconn_req(chan->conn, chan, ECONNRESET);
4204 4205 4206
			goto drop;
		}

4207
		l2cap_data_channel_iframe(chan, control, skb);
4208 4209 4210
	} else {
		if (len != 0) {
			BT_ERR("%d", len);
4211
			l2cap_send_disconn_req(chan->conn, chan, ECONNRESET);
4212 4213 4214
			goto drop;
		}

4215
		l2cap_data_channel_sframe(chan, control, skb);
4216 4217 4218 4219 4220 4221 4222 4223 4224
	}

	return 0;

drop:
	kfree_skb(skb);
	return 0;
}

L
Linus Torvalds 已提交
4225 4226
static inline int l2cap_data_channel(struct l2cap_conn *conn, u16 cid, struct sk_buff *skb)
{
4227
	struct l2cap_chan *chan;
4228
	struct sock *sk = NULL;
4229
	u32 control;
4230
	u16 tx_seq;
4231
	int len;
L
Linus Torvalds 已提交
4232

4233
	chan = l2cap_get_chan_by_scid(conn, cid);
4234
	if (!chan) {
L
Linus Torvalds 已提交
4235 4236 4237 4238
		BT_DBG("unknown cid 0x%4.4x", cid);
		goto drop;
	}

4239
	sk = chan->sk;
4240
	lock_sock(sk);
4241

4242
	BT_DBG("chan %p, len %d", chan, skb->len);
L
Linus Torvalds 已提交
4243

4244
	if (chan->state != BT_CONNECTED)
L
Linus Torvalds 已提交
4245 4246
		goto drop;

4247
	switch (chan->mode) {
4248 4249 4250 4251 4252
	case L2CAP_MODE_BASIC:
		/* If socket recv buffers overflows we drop data here
		 * which is *bad* because L2CAP has to be reliable.
		 * But we don't have any other choice. L2CAP doesn't
		 * provide flow control mechanism. */
L
Linus Torvalds 已提交
4253

4254
		if (chan->imtu < skb->len)
4255
			goto drop;
L
Linus Torvalds 已提交
4256

4257
		if (!chan->ops->recv(chan->data, skb))
4258 4259 4260 4261
			goto done;
		break;

	case L2CAP_MODE_ERTM:
4262
		l2cap_ertm_data_rcv(chan, skb);
4263

4264
		goto done;
4265

4266
	case L2CAP_MODE_STREAMING:
4267 4268
		control = __get_control(chan, skb->data);
		skb_pull(skb, __ctrl_size(chan));
4269 4270
		len = skb->len;

4271
		if (l2cap_check_fcs(chan, skb))
4272 4273
			goto drop;

4274
		if (__is_sar_start(chan, control))
4275
			len -= L2CAP_SDULEN_SIZE;
4276

4277
		if (chan->fcs == L2CAP_FCS_CRC16)
4278
			len -= L2CAP_FCS_SIZE;
4279

4280
		if (len > chan->mps || len < 0 || __is_sframe(chan, control))
4281 4282
			goto drop;

4283
		tx_seq = __get_txseq(chan, control);
4284

4285 4286 4287 4288 4289 4290
		if (chan->expected_tx_seq != tx_seq) {
			/* Frame(s) missing - must discard partial SDU */
			kfree_skb(chan->sdu);
			chan->sdu = NULL;
			chan->sdu_last_frag = NULL;
			chan->sdu_len = 0;
4291

4292 4293 4294
			/* TODO: Notify userland of missing data */
		}

4295
		chan->expected_tx_seq = __next_seq(chan, tx_seq);
4296 4297 4298

		if (l2cap_reassemble_sdu(chan, skb, control) == -EMSGSIZE)
			l2cap_send_disconn_req(chan->conn, chan, ECONNRESET);
4299 4300 4301

		goto done;

4302
	default:
4303
		BT_DBG("chan %p: bad mode 0x%2.2x", chan, chan->mode);
4304 4305
		break;
	}
L
Linus Torvalds 已提交
4306 4307 4308 4309 4310

drop:
	kfree_skb(skb);

done:
4311
	if (sk)
4312
		release_sock(sk);
4313

L
Linus Torvalds 已提交
4314 4315 4316
	return 0;
}

4317
static inline int l2cap_conless_channel(struct l2cap_conn *conn, __le16 psm, struct sk_buff *skb)
L
Linus Torvalds 已提交
4318
{
4319
	struct sock *sk = NULL;
4320
	struct l2cap_chan *chan;
L
Linus Torvalds 已提交
4321

4322 4323
	chan = l2cap_global_chan_by_psm(0, psm, conn->src);
	if (!chan)
L
Linus Torvalds 已提交
4324 4325
		goto drop;

4326 4327
	sk = chan->sk;

4328
	lock_sock(sk);
4329

L
Linus Torvalds 已提交
4330 4331
	BT_DBG("sk %p, len %d", sk, skb->len);

4332
	if (chan->state != BT_BOUND && chan->state != BT_CONNECTED)
L
Linus Torvalds 已提交
4333 4334
		goto drop;

4335
	if (chan->imtu < skb->len)
L
Linus Torvalds 已提交
4336 4337
		goto drop;

4338
	if (!chan->ops->recv(chan->data, skb))
L
Linus Torvalds 已提交
4339 4340 4341 4342 4343 4344
		goto done;

drop:
	kfree_skb(skb);

done:
4345
	if (sk)
4346
		release_sock(sk);
L
Linus Torvalds 已提交
4347 4348 4349
	return 0;
}

4350 4351
static inline int l2cap_att_channel(struct l2cap_conn *conn, __le16 cid, struct sk_buff *skb)
{
4352
	struct sock *sk = NULL;
4353
	struct l2cap_chan *chan;
4354

4355 4356
	chan = l2cap_global_chan_by_scid(0, cid, conn->src);
	if (!chan)
4357 4358
		goto drop;

4359 4360
	sk = chan->sk;

4361
	lock_sock(sk);
4362 4363 4364

	BT_DBG("sk %p, len %d", sk, skb->len);

4365
	if (chan->state != BT_BOUND && chan->state != BT_CONNECTED)
4366 4367
		goto drop;

4368
	if (chan->imtu < skb->len)
4369 4370
		goto drop;

4371
	if (!chan->ops->recv(chan->data, skb))
4372 4373 4374 4375 4376 4377 4378
		goto done;

drop:
	kfree_skb(skb);

done:
	if (sk)
4379
		release_sock(sk);
4380 4381 4382
	return 0;
}

L
Linus Torvalds 已提交
4383 4384 4385
static void l2cap_recv_frame(struct l2cap_conn *conn, struct sk_buff *skb)
{
	struct l2cap_hdr *lh = (void *) skb->data;
4386 4387
	u16 cid, len;
	__le16 psm;
L
Linus Torvalds 已提交
4388 4389 4390 4391 4392

	skb_pull(skb, L2CAP_HDR_SIZE);
	cid = __le16_to_cpu(lh->cid);
	len = __le16_to_cpu(lh->len);

4393 4394 4395 4396 4397
	if (len != skb->len) {
		kfree_skb(skb);
		return;
	}

L
Linus Torvalds 已提交
4398 4399 4400
	BT_DBG("len %d, cid 0x%4.4x", len, cid);

	switch (cid) {
4401
	case L2CAP_CID_LE_SIGNALING:
4402
	case L2CAP_CID_SIGNALING:
L
Linus Torvalds 已提交
4403 4404 4405
		l2cap_sig_channel(conn, skb);
		break;

4406
	case L2CAP_CID_CONN_LESS:
4407
		psm = get_unaligned_le16(skb->data);
L
Linus Torvalds 已提交
4408 4409 4410 4411
		skb_pull(skb, 2);
		l2cap_conless_channel(conn, psm, skb);
		break;

4412 4413 4414 4415
	case L2CAP_CID_LE_DATA:
		l2cap_att_channel(conn, cid, skb);
		break;

4416 4417 4418 4419 4420
	case L2CAP_CID_SMP:
		if (smp_sig_channel(conn, skb))
			l2cap_conn_del(conn->hcon, EACCES);
		break;

L
Linus Torvalds 已提交
4421 4422 4423 4424 4425 4426 4427 4428
	default:
		l2cap_data_channel(conn, cid, skb);
		break;
	}
}

/* ---- L2CAP interface with lower layer (HCI) ---- */

4429
int l2cap_connect_ind(struct hci_dev *hdev, bdaddr_t *bdaddr)
L
Linus Torvalds 已提交
4430 4431
{
	int exact = 0, lm1 = 0, lm2 = 0;
4432
	struct l2cap_chan *c;
L
Linus Torvalds 已提交
4433 4434 4435 4436

	BT_DBG("hdev %s, bdaddr %s", hdev->name, batostr(bdaddr));

	/* Find listening sockets and check their link_mode */
4437 4438 4439
	read_lock(&chan_list_lock);
	list_for_each_entry(c, &chan_list, global_l) {
		struct sock *sk = c->sk;
4440

4441
		if (c->state != BT_LISTEN)
L
Linus Torvalds 已提交
4442 4443 4444
			continue;

		if (!bacmp(&bt_sk(sk)->src, &hdev->bdaddr)) {
4445
			lm1 |= HCI_LM_ACCEPT;
4446
			if (test_bit(FLAG_ROLE_SWITCH, &c->flags))
4447
				lm1 |= HCI_LM_MASTER;
L
Linus Torvalds 已提交
4448
			exact++;
4449 4450
		} else if (!bacmp(&bt_sk(sk)->src, BDADDR_ANY)) {
			lm2 |= HCI_LM_ACCEPT;
4451
			if (test_bit(FLAG_ROLE_SWITCH, &c->flags))
4452 4453
				lm2 |= HCI_LM_MASTER;
		}
L
Linus Torvalds 已提交
4454
	}
4455
	read_unlock(&chan_list_lock);
L
Linus Torvalds 已提交
4456 4457 4458 4459

	return exact ? lm1 : lm2;
}

4460
int l2cap_connect_cfm(struct hci_conn *hcon, u8 status)
L
Linus Torvalds 已提交
4461
{
4462 4463
	struct l2cap_conn *conn;

L
Linus Torvalds 已提交
4464 4465 4466 4467 4468 4469
	BT_DBG("hcon %p bdaddr %s status %d", hcon, batostr(&hcon->dst), status);

	if (!status) {
		conn = l2cap_conn_add(hcon, status);
		if (conn)
			l2cap_conn_ready(conn);
4470
	} else
4471
		l2cap_conn_del(hcon, bt_to_errno(status));
L
Linus Torvalds 已提交
4472 4473 4474 4475

	return 0;
}

4476
int l2cap_disconn_ind(struct hci_conn *hcon)
4477 4478 4479 4480 4481
{
	struct l2cap_conn *conn = hcon->l2cap_data;

	BT_DBG("hcon %p", hcon);

4482
	if (!conn)
4483
		return HCI_ERROR_REMOTE_USER_TERM;
4484 4485 4486
	return conn->disc_reason;
}

4487
int l2cap_disconn_cfm(struct hci_conn *hcon, u8 reason)
L
Linus Torvalds 已提交
4488 4489 4490
{
	BT_DBG("hcon %p reason %d", hcon, reason);

4491
	l2cap_conn_del(hcon, bt_to_errno(reason));
L
Linus Torvalds 已提交
4492 4493 4494
	return 0;
}

4495
static inline void l2cap_check_encryption(struct l2cap_chan *chan, u8 encrypt)
4496
{
4497
	if (chan->chan_type != L2CAP_CHAN_CONN_ORIENTED)
4498 4499
		return;

4500
	if (encrypt == 0x00) {
4501
		if (chan->sec_level == BT_SECURITY_MEDIUM) {
4502
			__clear_chan_timer(chan);
4503 4504
			__set_chan_timer(chan,
					msecs_to_jiffies(L2CAP_ENC_TIMEOUT));
4505
		} else if (chan->sec_level == BT_SECURITY_HIGH)
4506
			l2cap_chan_close(chan, ECONNREFUSED);
4507
	} else {
4508
		if (chan->sec_level == BT_SECURITY_MEDIUM)
4509
			__clear_chan_timer(chan);
4510 4511 4512
	}
}

4513
int l2cap_security_cfm(struct hci_conn *hcon, u8 status, u8 encrypt)
L
Linus Torvalds 已提交
4514
{
4515
	struct l2cap_conn *conn = hcon->l2cap_data;
4516
	struct l2cap_chan *chan;
L
Linus Torvalds 已提交
4517

4518
	if (!conn)
L
Linus Torvalds 已提交
4519
		return 0;
4520

L
Linus Torvalds 已提交
4521 4522
	BT_DBG("conn %p", conn);

4523 4524
	if (hcon->type == LE_LINK) {
		smp_distribute_keys(conn, 0);
4525
		cancel_delayed_work(&conn->security_timer);
4526 4527
	}

4528
	mutex_lock(&conn->chan_lock);
L
Linus Torvalds 已提交
4529

4530
	list_for_each_entry(chan, &conn->chan_l, list) {
4531
		struct sock *sk = chan->sk;
4532

L
Linus Torvalds 已提交
4533 4534
		bh_lock_sock(sk);

4535 4536 4537 4538 4539
		BT_DBG("chan->scid %d", chan->scid);

		if (chan->scid == L2CAP_CID_LE_DATA) {
			if (!status && encrypt) {
				chan->sec_level = hcon->sec_level;
4540
				l2cap_chan_ready(chan);
4541 4542 4543 4544 4545 4546
			}

			bh_unlock_sock(sk);
			continue;
		}

4547
		if (test_bit(CONF_CONNECT_PEND, &chan->conf_state)) {
4548 4549 4550 4551
			bh_unlock_sock(sk);
			continue;
		}

4552 4553
		if (!status && (chan->state == BT_CONNECTED ||
						chan->state == BT_CONFIG)) {
4554
			l2cap_check_encryption(chan, encrypt);
4555 4556 4557 4558
			bh_unlock_sock(sk);
			continue;
		}

4559
		if (chan->state == BT_CONNECT) {
4560 4561
			if (!status) {
				struct l2cap_conn_req req;
4562 4563
				req.scid = cpu_to_le16(chan->scid);
				req.psm  = chan->psm;
L
Linus Torvalds 已提交
4564

4565
				chan->ident = l2cap_get_ident(conn);
4566
				set_bit(CONF_CONNECT_PEND, &chan->conf_state);
L
Linus Torvalds 已提交
4567

4568
				l2cap_send_cmd(conn, chan->ident,
4569 4570
					L2CAP_CONN_REQ, sizeof(req), &req);
			} else {
4571
				__clear_chan_timer(chan);
4572 4573
				__set_chan_timer(chan,
					msecs_to_jiffies(L2CAP_DISC_TIMEOUT));
4574
			}
4575
		} else if (chan->state == BT_CONNECT2) {
4576
			struct l2cap_conn_rsp rsp;
4577
			__u16 res, stat;
L
Linus Torvalds 已提交
4578

4579
			if (!status) {
4580 4581 4582 4583
				if (bt_sk(sk)->defer_setup) {
					struct sock *parent = bt_sk(sk)->parent;
					res = L2CAP_CR_PEND;
					stat = L2CAP_CS_AUTHOR_PEND;
4584 4585
					if (parent)
						parent->sk_data_ready(parent, 0);
4586
				} else {
4587
					l2cap_state_change(chan, BT_CONFIG);
4588 4589 4590
					res = L2CAP_CR_SUCCESS;
					stat = L2CAP_CS_NO_INFO;
				}
4591
			} else {
4592
				l2cap_state_change(chan, BT_DISCONN);
4593 4594
				__set_chan_timer(chan,
					msecs_to_jiffies(L2CAP_DISC_TIMEOUT));
4595 4596
				res = L2CAP_CR_SEC_BLOCK;
				stat = L2CAP_CS_NO_INFO;
4597 4598
			}

4599 4600
			rsp.scid   = cpu_to_le16(chan->dcid);
			rsp.dcid   = cpu_to_le16(chan->scid);
4601 4602
			rsp.result = cpu_to_le16(res);
			rsp.status = cpu_to_le16(stat);
4603 4604
			l2cap_send_cmd(conn, chan->ident, L2CAP_CONN_RSP,
							sizeof(rsp), &rsp);
4605
		}
L
Linus Torvalds 已提交
4606 4607 4608 4609

		bh_unlock_sock(sk);
	}

4610
	mutex_unlock(&conn->chan_lock);
4611

L
Linus Torvalds 已提交
4612 4613 4614
	return 0;
}

4615
int l2cap_recv_acldata(struct hci_conn *hcon, struct sk_buff *skb, u16 flags)
L
Linus Torvalds 已提交
4616 4617 4618
{
	struct l2cap_conn *conn = hcon->l2cap_data;

4619 4620 4621 4622
	if (!conn)
		conn = l2cap_conn_add(hcon, 0);

	if (!conn)
L
Linus Torvalds 已提交
4623 4624 4625 4626
		goto drop;

	BT_DBG("conn %p len %d flags 0x%x", conn, skb->len, flags);

4627
	if (!(flags & ACL_CONT)) {
L
Linus Torvalds 已提交
4628
		struct l2cap_hdr *hdr;
4629
		struct l2cap_chan *chan;
4630
		u16 cid;
L
Linus Torvalds 已提交
4631 4632 4633 4634 4635 4636 4637 4638 4639 4640
		int len;

		if (conn->rx_len) {
			BT_ERR("Unexpected start frame (len %d)", skb->len);
			kfree_skb(conn->rx_skb);
			conn->rx_skb = NULL;
			conn->rx_len = 0;
			l2cap_conn_unreliable(conn, ECOMM);
		}

4641 4642
		/* Start fragment always begin with Basic L2CAP header */
		if (skb->len < L2CAP_HDR_SIZE) {
L
Linus Torvalds 已提交
4643 4644 4645 4646 4647 4648 4649
			BT_ERR("Frame is too short (len %d)", skb->len);
			l2cap_conn_unreliable(conn, ECOMM);
			goto drop;
		}

		hdr = (struct l2cap_hdr *) skb->data;
		len = __le16_to_cpu(hdr->len) + L2CAP_HDR_SIZE;
4650
		cid = __le16_to_cpu(hdr->cid);
L
Linus Torvalds 已提交
4651 4652 4653 4654 4655 4656 4657 4658 4659 4660 4661 4662 4663 4664 4665 4666

		if (len == skb->len) {
			/* Complete frame received */
			l2cap_recv_frame(conn, skb);
			return 0;
		}

		BT_DBG("Start: total len %d, frag len %d", len, skb->len);

		if (skb->len > len) {
			BT_ERR("Frame is too long (len %d, expected len %d)",
				skb->len, len);
			l2cap_conn_unreliable(conn, ECOMM);
			goto drop;
		}

4667
		chan = l2cap_get_chan_by_scid(conn, cid);
4668

4669 4670
		if (chan && chan->sk) {
			struct sock *sk = chan->sk;
4671
			lock_sock(sk);
4672

4673
			if (chan->imtu < len - L2CAP_HDR_SIZE) {
4674 4675
				BT_ERR("Frame exceeding recv MTU (len %d, "
							"MTU %d)", len,
4676
							chan->imtu);
4677
				release_sock(sk);
4678 4679 4680
				l2cap_conn_unreliable(conn, ECOMM);
				goto drop;
			}
4681
			release_sock(sk);
4682
		}
4683

L
Linus Torvalds 已提交
4684
		/* Allocate skb for the complete frame (with header) */
4685 4686
		conn->rx_skb = bt_skb_alloc(len, GFP_ATOMIC);
		if (!conn->rx_skb)
L
Linus Torvalds 已提交
4687 4688
			goto drop;

4689
		skb_copy_from_linear_data(skb, skb_put(conn->rx_skb, skb->len),
4690
								skb->len);
L
Linus Torvalds 已提交
4691 4692 4693 4694 4695 4696 4697 4698 4699 4700 4701 4702 4703 4704 4705 4706 4707 4708 4709 4710
		conn->rx_len = len - skb->len;
	} else {
		BT_DBG("Cont: frag len %d (expecting %d)", skb->len, conn->rx_len);

		if (!conn->rx_len) {
			BT_ERR("Unexpected continuation frame (len %d)", skb->len);
			l2cap_conn_unreliable(conn, ECOMM);
			goto drop;
		}

		if (skb->len > conn->rx_len) {
			BT_ERR("Fragment is too long (len %d, expected %d)",
					skb->len, conn->rx_len);
			kfree_skb(conn->rx_skb);
			conn->rx_skb = NULL;
			conn->rx_len = 0;
			l2cap_conn_unreliable(conn, ECOMM);
			goto drop;
		}

4711
		skb_copy_from_linear_data(skb, skb_put(conn->rx_skb, skb->len),
4712
								skb->len);
L
Linus Torvalds 已提交
4713 4714 4715 4716 4717 4718 4719 4720 4721 4722 4723 4724 4725 4726
		conn->rx_len -= skb->len;

		if (!conn->rx_len) {
			/* Complete frame received */
			l2cap_recv_frame(conn, conn->rx_skb);
			conn->rx_skb = NULL;
		}
	}

drop:
	kfree_skb(skb);
	return 0;
}

4727
static int l2cap_debugfs_show(struct seq_file *f, void *p)
L
Linus Torvalds 已提交
4728
{
4729
	struct l2cap_chan *c;
L
Linus Torvalds 已提交
4730

4731
	read_lock(&chan_list_lock);
L
Linus Torvalds 已提交
4732

4733 4734
	list_for_each_entry(c, &chan_list, global_l) {
		struct sock *sk = c->sk;
4735

4736
		seq_printf(f, "%s %s %d %d 0x%4.4x 0x%4.4x %d %d %d %d\n",
4737 4738
					batostr(&bt_sk(sk)->src),
					batostr(&bt_sk(sk)->dst),
4739
					c->state, __le16_to_cpu(c->psm),
4740 4741
					c->scid, c->dcid, c->imtu, c->omtu,
					c->sec_level, c->mode);
4742
	}
L
Linus Torvalds 已提交
4743

4744
	read_unlock(&chan_list_lock);
L
Linus Torvalds 已提交
4745

4746
	return 0;
L
Linus Torvalds 已提交
4747 4748
}

4749 4750 4751 4752 4753 4754 4755 4756 4757 4758 4759 4760 4761
static int l2cap_debugfs_open(struct inode *inode, struct file *file)
{
	return single_open(file, l2cap_debugfs_show, inode->i_private);
}

static const struct file_operations l2cap_debugfs_fops = {
	.open		= l2cap_debugfs_open,
	.read		= seq_read,
	.llseek		= seq_lseek,
	.release	= single_release,
};

static struct dentry *l2cap_debugfs;
L
Linus Torvalds 已提交
4762

4763
int __init l2cap_init(void)
L
Linus Torvalds 已提交
4764 4765
{
	int err;
4766

4767
	err = l2cap_init_sockets();
L
Linus Torvalds 已提交
4768 4769 4770
	if (err < 0)
		return err;

4771 4772 4773 4774 4775 4776
	if (bt_debugfs) {
		l2cap_debugfs = debugfs_create_file("l2cap", 0444,
					bt_debugfs, NULL, &l2cap_debugfs_fops);
		if (!l2cap_debugfs)
			BT_ERR("Failed to create L2CAP debug file");
	}
L
Linus Torvalds 已提交
4777 4778 4779 4780

	return 0;
}

4781
void l2cap_exit(void)
L
Linus Torvalds 已提交
4782
{
4783
	debugfs_remove(l2cap_debugfs);
4784
	l2cap_cleanup_sockets();
L
Linus Torvalds 已提交
4785 4786
}

4787 4788
module_param(disable_ertm, bool, 0644);
MODULE_PARM_DESC(disable_ertm, "Disable enhanced retransmission mode");