aboutsummaryrefslogtreecommitdiffstats
path: root/net/bluetooth/l2cap.c
diff options
context:
space:
mode:
authorGustavo F. Padovan <gustavo@las.ic.unicamp.br>2009-08-26 03:04:01 -0400
committerMarcel Holtmann <marcel@holtmann.org>2009-08-26 03:12:20 -0400
commitca42a613c92d131ff02d5714419d58c36c3459f3 (patch)
treeb40e2f5855260ab5eafb6f15517ba327db489b0b /net/bluetooth/l2cap.c
parentcbe86b98a6aceefe943ada1471eb52fd9ac4c504 (diff)
Bluetooth: Acknowledge L2CAP packets when receiving RR-frames (F-bit=1)
Implement the Recv ReqSeqAndFBit event when a RR frame with F bit set is received. Signed-off-by: Gustavo F. Padovan <gustavo@las.ic.unicamp.br> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Diffstat (limited to 'net/bluetooth/l2cap.c')
-rw-r--r--net/bluetooth/l2cap.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/net/bluetooth/l2cap.c b/net/bluetooth/l2cap.c
index e5847c5849d7..0a36c61c011f 100644
--- a/net/bluetooth/l2cap.c
+++ b/net/bluetooth/l2cap.c
@@ -3348,9 +3348,13 @@ static inline int l2cap_data_channel_sframe(struct sock *sk, u16 rx_control, str
3348 case L2CAP_SUPER_RCV_READY: 3348 case L2CAP_SUPER_RCV_READY:
3349 if (rx_control & L2CAP_CTRL_POLL) { 3349 if (rx_control & L2CAP_CTRL_POLL) {
3350 u16 control = L2CAP_CTRL_FINAL; 3350 u16 control = L2CAP_CTRL_FINAL;
3351 control |= L2CAP_SUPER_RCV_READY; 3351 control |= L2CAP_SUPER_RCV_READY |
3352 (pi->buffer_seq << L2CAP_CTRL_REQSEQ_SHIFT);
3352 l2cap_send_sframe(l2cap_pi(sk), control); 3353 l2cap_send_sframe(l2cap_pi(sk), control);
3353 } else if (rx_control & L2CAP_CTRL_FINAL) { 3354 } else if (rx_control & L2CAP_CTRL_FINAL) {
3355 pi->expected_ack_seq = tx_seq;
3356 l2cap_drop_acked_frames(sk);
3357
3354 if (!(pi->conn_state & L2CAP_CONN_WAIT_F)) 3358 if (!(pi->conn_state & L2CAP_CONN_WAIT_F))
3355 break; 3359 break;
3356 3360