if (!test_bit(CF_SINGLE_BUFFER, &cam->flags)) {
                cam->frame_state.delivered++;
+               cam->vb_bufs[frame] = NULL;
                mcam_buffer_done(cam, frame, &buf->vb_buf);
        }
        mcam_set_contig_buffer(cam, frame);
                mcam_read_setup(cam);
 }
 
+static void mcam_vb_requeue_bufs(struct vb2_queue *vq,
+                                enum vb2_buffer_state state)
+{
+       struct mcam_camera *cam = vb2_get_drv_priv(vq);
+       struct mcam_vb_buffer *buf, *node;
+       unsigned long flags;
+       unsigned i;
+
+       spin_lock_irqsave(&cam->dev_lock, flags);
+       list_for_each_entry_safe(buf, node, &cam->buffers, queue) {
+               vb2_buffer_done(&buf->vb_buf, state);
+               list_del(&buf->queue);
+       }
+       for (i = 0; i < MAX_DMA_BUFS; i++) {
+               buf = cam->vb_bufs[i];
+
+               if (buf) {
+                       vb2_buffer_done(&buf->vb_buf, state);
+                       cam->vb_bufs[i] = NULL;
+               }
+       }
+       spin_unlock_irqrestore(&cam->dev_lock, flags);
+}
+
 /*
  * These need to be called with the mutex held from vb2
  */
 {
        struct mcam_camera *cam = vb2_get_drv_priv(vq);
        unsigned int frame;
+       int ret;
 
        if (cam->state != S_IDLE) {
-               INIT_LIST_HEAD(&cam->buffers);
+               mcam_vb_requeue_bufs(vq, VB2_BUF_STATE_QUEUED);
                return -EINVAL;
        }
        cam->frame_state.frames = 0;
        for (frame = 0; frame < cam->nbufs; frame++)
                clear_bit(CF_FRAME_SOF0 + frame, &cam->flags);
 
-       return mcam_read_setup(cam);
+       ret = mcam_read_setup(cam);
+       if (ret)
+               mcam_vb_requeue_bufs(vq, VB2_BUF_STATE_QUEUED);
+       return ret;
 }
 
 static void mcam_vb_stop_streaming(struct vb2_queue *vq)
 {
        struct mcam_camera *cam = vb2_get_drv_priv(vq);
-       unsigned long flags;
 
        cam_dbg(cam, "stop_streaming: %d frames, %d singles, %d delivered\n",
                        cam->frame_state.frames, cam->frame_state.singles,
         * VB2 reclaims the buffers, so we need to forget
         * about them.
         */
-       spin_lock_irqsave(&cam->dev_lock, flags);
-       INIT_LIST_HEAD(&cam->buffers);
-       spin_unlock_irqrestore(&cam->dev_lock, flags);
+       mcam_vb_requeue_bufs(vq, VB2_BUF_STATE_ERROR);
 }
 
 
        mcam_set_config_needed(cam, 1);
        cam->pix_format = mcam_def_pix_format;
        cam->mbus_code = mcam_def_mbus_code;
-       INIT_LIST_HEAD(&cam->buffers);
        mcam_ctlr_init(cam);
 
        /*