diff options
Diffstat (limited to 'net/irda/irlap_event.c')
-rw-r--r-- | net/irda/irlap_event.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/net/irda/irlap_event.c b/net/irda/irlap_event.c index 6d3aff862dc2..6af86eba7463 100644 --- a/net/irda/irlap_event.c +++ b/net/irda/irlap_event.c | |||
@@ -1199,6 +1199,19 @@ static int irlap_state_nrm_p(struct irlap_cb *self, IRLAP_EVENT event, | |||
1199 | 1199 | ||
1200 | switch (event) { | 1200 | switch (event) { |
1201 | case RECV_I_RSP: /* Optimize for the common case */ | 1201 | case RECV_I_RSP: /* Optimize for the common case */ |
1202 | if (unlikely(skb->len <= LAP_ADDR_HEADER + LAP_CTRL_HEADER)) { | ||
1203 | /* | ||
1204 | * Input validation check: a stir4200/mcp2150 | ||
1205 | * combination sometimes results in an empty i:rsp. | ||
1206 | * This makes no sense; we can just ignore the frame | ||
1207 | * and send an rr:cmd immediately. This happens before | ||
1208 | * changing nr or ns so triggers a retransmit | ||
1209 | */ | ||
1210 | irlap_wait_min_turn_around(self, &self->qos_tx); | ||
1211 | irlap_send_rr_frame(self, CMD_FRAME); | ||
1212 | /* Keep state */ | ||
1213 | break; | ||
1214 | } | ||
1202 | /* FIXME: must check for remote_busy below */ | 1215 | /* FIXME: must check for remote_busy below */ |
1203 | #ifdef CONFIG_IRDA_FAST_RR | 1216 | #ifdef CONFIG_IRDA_FAST_RR |
1204 | /* | 1217 | /* |