diff options
-rw-r--r-- | include/net/bluetooth/l2cap.h | 1 | ||||
-rw-r--r-- | net/bluetooth/l2cap.c | 8 |
2 files changed, 6 insertions, 3 deletions
diff --git a/include/net/bluetooth/l2cap.h b/include/net/bluetooth/l2cap.h index 9516f4b4a3c2..327eb57dab51 100644 --- a/include/net/bluetooth/l2cap.h +++ b/include/net/bluetooth/l2cap.h | |||
@@ -324,7 +324,6 @@ struct l2cap_pinfo { | |||
324 | 324 | ||
325 | __u8 next_tx_seq; | 325 | __u8 next_tx_seq; |
326 | __u8 expected_ack_seq; | 326 | __u8 expected_ack_seq; |
327 | __u8 req_seq; | ||
328 | __u8 expected_tx_seq; | 327 | __u8 expected_tx_seq; |
329 | __u8 buffer_seq; | 328 | __u8 buffer_seq; |
330 | __u8 buffer_seq_srej; | 329 | __u8 buffer_seq_srej; |
diff --git a/net/bluetooth/l2cap.c b/net/bluetooth/l2cap.c index 2d5d37545b10..78ab8811e5ef 100644 --- a/net/bluetooth/l2cap.c +++ b/net/bluetooth/l2cap.c | |||
@@ -1333,7 +1333,7 @@ static int l2cap_retransmit_frame(struct sock *sk, u8 tx_seq) | |||
1333 | tx_skb = skb_clone(skb, GFP_ATOMIC); | 1333 | tx_skb = skb_clone(skb, GFP_ATOMIC); |
1334 | bt_cb(skb)->retries++; | 1334 | bt_cb(skb)->retries++; |
1335 | control = get_unaligned_le16(tx_skb->data + L2CAP_HDR_SIZE); | 1335 | control = get_unaligned_le16(tx_skb->data + L2CAP_HDR_SIZE); |
1336 | control |= (pi->req_seq << L2CAP_CTRL_REQSEQ_SHIFT) | 1336 | control |= (pi->buffer_seq << L2CAP_CTRL_REQSEQ_SHIFT) |
1337 | | (tx_seq << L2CAP_CTRL_TXSEQ_SHIFT); | 1337 | | (tx_seq << L2CAP_CTRL_TXSEQ_SHIFT); |
1338 | put_unaligned_le16(control, tx_skb->data + L2CAP_HDR_SIZE); | 1338 | put_unaligned_le16(control, tx_skb->data + L2CAP_HDR_SIZE); |
1339 | 1339 | ||
@@ -1375,7 +1375,7 @@ static int l2cap_ertm_send(struct sock *sk) | |||
1375 | bt_cb(skb)->retries++; | 1375 | bt_cb(skb)->retries++; |
1376 | 1376 | ||
1377 | control = get_unaligned_le16(tx_skb->data + L2CAP_HDR_SIZE); | 1377 | control = get_unaligned_le16(tx_skb->data + L2CAP_HDR_SIZE); |
1378 | control |= (pi->req_seq << L2CAP_CTRL_REQSEQ_SHIFT) | 1378 | control |= (pi->buffer_seq << L2CAP_CTRL_REQSEQ_SHIFT) |
1379 | | (pi->next_tx_seq << L2CAP_CTRL_TXSEQ_SHIFT); | 1379 | | (pi->next_tx_seq << L2CAP_CTRL_TXSEQ_SHIFT); |
1380 | put_unaligned_le16(control, tx_skb->data + L2CAP_HDR_SIZE); | 1380 | put_unaligned_le16(control, tx_skb->data + L2CAP_HDR_SIZE); |
1381 | 1381 | ||
@@ -3298,12 +3298,16 @@ static inline int l2cap_data_channel_iframe(struct sock *sk, u16 rx_control, str | |||
3298 | { | 3298 | { |
3299 | struct l2cap_pinfo *pi = l2cap_pi(sk); | 3299 | struct l2cap_pinfo *pi = l2cap_pi(sk); |
3300 | u8 tx_seq = __get_txseq(rx_control); | 3300 | u8 tx_seq = __get_txseq(rx_control); |
3301 | u8 req_seq = __get_reqseq(rx_control); | ||
3301 | u16 tx_control = 0; | 3302 | u16 tx_control = 0; |
3302 | u8 sar = rx_control >> L2CAP_CTRL_SAR_SHIFT; | 3303 | u8 sar = rx_control >> L2CAP_CTRL_SAR_SHIFT; |
3303 | int err = 0; | 3304 | int err = 0; |
3304 | 3305 | ||
3305 | BT_DBG("sk %p rx_control 0x%4.4x len %d", sk, rx_control, skb->len); | 3306 | BT_DBG("sk %p rx_control 0x%4.4x len %d", sk, rx_control, skb->len); |
3306 | 3307 | ||
3308 | pi->expected_ack_seq = req_seq; | ||
3309 | l2cap_drop_acked_frames(sk); | ||
3310 | |||
3307 | if (tx_seq == pi->expected_tx_seq) | 3311 | if (tx_seq == pi->expected_tx_seq) |
3308 | goto expected; | 3312 | goto expected; |
3309 | 3313 | ||