struct em28xx_fh *fh = filp->private_data;
        struct em28xx *dev = fh->dev;
 
+       /* FIXME: read() is not prepared to allow changing the video
+          resolution while streaming. Seems a bug at em28xx_set_fmt
+        */
 
        if (unlikely(res_get(fh) < 0))
                return -EBUSY;
                        mutex_unlock(&dev->lock);
                        return -ENODEV;
                }
+               dev->video_bytesread = 0;
        }
 
        f = list_entry(dev->outqueue.prev, struct em28xx_frame_t, frame);
 
-       spin_lock_irqsave(&dev->queue_lock, lock_flags);
-       list_for_each_entry(i, &dev->outqueue, frame)
-           i->state = F_UNUSED;
-       INIT_LIST_HEAD(&dev->outqueue);
-       spin_unlock_irqrestore(&dev->queue_lock, lock_flags);
-
        em28xx_queue_unusedframes(dev);
 
        if (count > f->buf.length)
                count = f->buf.length;
 
-       if (copy_to_user(buf, f->bufmem, count)) {
-               mutex_unlock(&dev->lock);
+       if ((dev->video_bytesread + count) > dev->frame_size)
+               count = dev->frame_size - dev->video_bytesread;
+
+       if (copy_to_user(buf, f->bufmem+dev->video_bytesread, count)) {
+               em28xx_err("Error while copying to user\n");
                return -EFAULT;
        }
+       dev->video_bytesread += count;
+
+       if (dev->video_bytesread == dev->frame_size) {
+               spin_lock_irqsave(&dev->queue_lock, lock_flags);
+               list_for_each_entry(i, &dev->outqueue, frame)
+                                   i->state = F_UNUSED;
+               INIT_LIST_HEAD(&dev->outqueue);
+               spin_unlock_irqrestore(&dev->queue_lock, lock_flags);
+
+               em28xx_queue_unusedframes(dev);
+               dev->video_bytesread = 0;
+       }
+
        *f_pos += count;
 
        mutex_unlock(&dev->lock);
 
        int vscale;             /* vertical scale factor (see datasheet) */
        int interlaced;         /* 1=interlace fileds, 0=just top fileds */
        int type;
+       unsigned int video_bytesread;   /* Number of bytes read */
 
        unsigned long hash;     /* eeprom hash - for boards with generic ID */
        unsigned long i2c_hash; /* i2c devicelist hash - for boards with generic ID */
        enum em28xx_dev_state state;
        enum em28xx_stream_state stream;
        enum em28xx_io_method io;
+
        /* locks */
        struct mutex lock;
        spinlock_t queue_lock;