diff options
Diffstat (limited to 'net/irda/ircomm')
-rw-r--r-- | net/irda/ircomm/ircomm_core.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/net/irda/ircomm/ircomm_core.c b/net/irda/ircomm/ircomm_core.c index 2d63fa8e1556..b825399fc160 100644 --- a/net/irda/ircomm/ircomm_core.c +++ b/net/irda/ircomm/ircomm_core.c | |||
@@ -363,6 +363,18 @@ void ircomm_process_data(struct ircomm_cb *self, struct sk_buff *skb) | |||
363 | clen = skb->data[0]; | 363 | clen = skb->data[0]; |
364 | 364 | ||
365 | /* | 365 | /* |
366 | * Input validation check: a stir4200/mcp2150 combinations sometimes | ||
367 | * results in frames with clen > remaining packet size. These are | ||
368 | * illegal; if we throw away just this frame then it seems to carry on | ||
369 | * fine | ||
370 | */ | ||
371 | if (unlikely(skb->len < (clen + 1))) { | ||
372 | IRDA_DEBUG(2, "%s() throwing away illegal frame\n", | ||
373 | __FUNCTION__ ); | ||
374 | return; | ||
375 | } | ||
376 | |||
377 | /* | ||
366 | * If there are any data hiding in the control channel, we must | 378 | * If there are any data hiding in the control channel, we must |
367 | * deliver it first. The side effect is that the control channel | 379 | * deliver it first. The side effect is that the control channel |
368 | * will be removed from the skb | 380 | * will be removed from the skb |