[PATCH] v4l: 864: improved isoc error detection
authorMauro Carvalho Chehab <mchehab@brturbo.com.br>
Wed, 9 Nov 2005 05:38:16 +0000 (21:38 -0800)
committerLinus Torvalds <torvalds@g5.osdl.org>
Wed, 9 Nov 2005 15:56:26 +0000 (07:56 -0800)
- Improved isoc error detection.

Signed-off-by: Mauro Carvalho Chehab <mchehab@brturbo.com.br>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
drivers/media/video/em28xx/em28xx-core.c

index 263b6c91adb5201545a80c61e1dac1d8aa19f749..442d50d7f320af6c04d9f50c239275c9682d8196 100644 (file)
@@ -573,8 +573,16 @@ static inline void em2820_isoc_video_copy(struct em2820 *dev,
 
        if ((*f)->fieldbytesused + len > dev->field_size)
                len =dev->field_size - (*f)->fieldbytesused;
+
+       if (buf[0] != 0x88 && buf[0] != 0x22) {
+               em2820_isocdbg("frame is not complete\n");
+               startread = buf;
+               len+=4;
+       } else
+               startread = buf + 4;
+
        remain = len;
-       startread = buf + 4;
+
        if ((*f)->top_field)
                fieldstart = (*f)->bufmem;
        else
@@ -653,7 +661,8 @@ void em2820_isocIrq(struct urb *urb, struct pt_regs *regs)
                                em2820_isocdbg("data error: [%d] len=%d, status=%d", i,
                                        urb->iso_frame_desc[i].actual_length,
                                        urb->iso_frame_desc[i].status);
-                               continue;
+                               if (urb->iso_frame_desc[i].status != -EPROTO)
+                                       continue;
                        }
                        if (urb->iso_frame_desc[i].actual_length <= 0) {
                                em2820_isocdbg("packet %d is empty",i);