Commit 6d97b53e authored by Robie Basak's avatar Robie Basak Committed by David S. Miller

[IrDA]: Resend frames on timeout.

When final timer expires, it might also mean that the i:cmd wasn't
received properly. If we have rejected frames, we can try to resend them.
Signed-off-by: default avatarRobie Basak <rb-oss-1@justgohome.co.uk>
Signed-off-by: default avatarSamuel Ortiz <samuel@sortiz.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 775516bf
...@@ -1514,9 +1514,15 @@ static int irlap_state_nrm_p(struct irlap_cb *self, IRLAP_EVENT event, ...@@ -1514,9 +1514,15 @@ static int irlap_state_nrm_p(struct irlap_cb *self, IRLAP_EVENT event,
/* N2 is the disconnect timer. Until we reach it, we retry */ /* N2 is the disconnect timer. Until we reach it, we retry */
if (self->retry_count < self->N2) { if (self->retry_count < self->N2) {
/* Retry sending the pf bit to the secondary */ if (skb_peek(&self->wx_list) == NULL) {
irlap_wait_min_turn_around(self, &self->qos_tx); /* Retry sending the pf bit to the secondary */
irlap_send_rr_frame(self, CMD_FRAME); IRDA_DEBUG(4, "nrm_p: resending rr");
irlap_wait_min_turn_around(self, &self->qos_tx);
irlap_send_rr_frame(self, CMD_FRAME);
} else {
IRDA_DEBUG(4, "nrm_p: resend frames");
irlap_resend_rejected_frames(self, CMD_FRAME);
}
irlap_start_final_timer(self, self->final_timeout); irlap_start_final_timer(self, self->final_timeout);
self->retry_count++; self->retry_count++;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment