diff options
author | Gustavo F. Padovan <padovan@profusion.mobi> | 2010-05-01 15:15:39 -0400 |
---|---|---|
committer | Marcel Holtmann <marcel@holtmann.org> | 2010-05-10 03:28:48 -0400 |
commit | 05fbd89dd4153341717b33d9e8ae8bd29db6c1c8 (patch) | |
tree | 7f0da4e17b3bf8e36f61d2ba748cffa6a2abc0d3 /net/bluetooth/l2cap.c | |
parent | 8abb52ee00c4b3f857269eb6b7145991bab869bf (diff) |
Bluetooth: Finish implementation for Rec RR (P=1) on ERTM
Now the code handles the case under SREJ_SENT state.
Signed-off-by: Gustavo F. Padovan <padovan@profusion.mobi>
Reviewed-by: João Paulo Rechi Vita <jprvita@profusion.mobi>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Diffstat (limited to 'net/bluetooth/l2cap.c')
-rw-r--r-- | net/bluetooth/l2cap.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/net/bluetooth/l2cap.c b/net/bluetooth/l2cap.c index e9ac9fb11917..f3869857ee9f 100644 --- a/net/bluetooth/l2cap.c +++ b/net/bluetooth/l2cap.c | |||
@@ -3499,8 +3499,17 @@ static inline void l2cap_data_channel_rrframe(struct sock *sk, u16 rx_control) | |||
3499 | l2cap_drop_acked_frames(sk); | 3499 | l2cap_drop_acked_frames(sk); |
3500 | 3500 | ||
3501 | if (rx_control & L2CAP_CTRL_POLL) { | 3501 | if (rx_control & L2CAP_CTRL_POLL) { |
3502 | l2cap_send_i_or_rr_or_rnr(sk); | 3502 | if (pi->conn_state & L2CAP_CONN_SREJ_SENT) { |
3503 | pi->conn_state &= ~L2CAP_CONN_REMOTE_BUSY; | 3503 | if ((pi->conn_state & L2CAP_CONN_REMOTE_BUSY) && |
3504 | (pi->unacked_frames > 0)) | ||
3505 | __mod_retrans_timer(); | ||
3506 | |||
3507 | pi->conn_state &= ~L2CAP_CONN_REMOTE_BUSY; | ||
3508 | l2cap_send_srejtail(sk); | ||
3509 | } else { | ||
3510 | l2cap_send_i_or_rr_or_rnr(sk); | ||
3511 | pi->conn_state &= ~L2CAP_CONN_REMOTE_BUSY; | ||
3512 | } | ||
3504 | 3513 | ||
3505 | } else if (rx_control & L2CAP_CTRL_FINAL) { | 3514 | } else if (rx_control & L2CAP_CTRL_FINAL) { |
3506 | pi->conn_state &= ~L2CAP_CONN_REMOTE_BUSY; | 3515 | pi->conn_state &= ~L2CAP_CONN_REMOTE_BUSY; |