{
struct dcmi_buf *buf;
- spin_lock_irq(&dcmi->irqlock);
-
- if (dcmi->state != RUNNING) {
- spin_unlock_irq(&dcmi->irqlock);
+ if (dcmi->state != RUNNING)
return -EINVAL;
- }
/* Restart a new DMA transfer with next buffer */
if (list_empty(&dcmi->buffers)) {
dev_dbg(dcmi->dev, "Capture restart is deferred to next buffer queueing\n");
dcmi->state = WAIT_FOR_BUFFER;
- spin_unlock_irq(&dcmi->irqlock);
return 0;
}
buf = list_entry(dcmi->buffers.next, struct dcmi_buf, list);
dcmi->active = buf;
- spin_unlock_irq(&dcmi->irqlock);
-
return dcmi_start_capture(dcmi, buf);
}
* buffer payload.
*/
+ spin_unlock_irq(&dcmi->irqlock);
/* Drain DMA */
dmaengine_synchronize(dcmi->dma_chan);
+ spin_lock_irq(&dcmi->irqlock);
/* Get DMA residue to get JPEG size */
status = dmaengine_tx_status(dcmi->dma_chan, dcmi->dma_cookie, &state);
dcmi_buffer_done(dcmi, buf, 0, -EIO);
}
+ spin_unlock_irq(&dcmi->irqlock);
/* Abort DMA operation */
dmaengine_terminate_sync(dcmi->dma_chan);
+ spin_lock_irq(&dcmi->irqlock);
/* Restart capture */
if (dcmi_restart_capture(dcmi))
spin_unlock_irq(&dcmi->irqlock);
dmaengine_terminate_sync(dcmi->dma_chan);
+ spin_lock_irq(&dcmi->irqlock);
if (dcmi_restart_capture(dcmi))
dev_err(dcmi->dev, "%s: Cannot restart capture\n", __func__);
+ spin_unlock_irq(&dcmi->irqlock);
return IRQ_HANDLED;
}
if (dcmi->sd_format->fourcc == V4L2_PIX_FMT_JPEG &&
dcmi->misr & IT_FRAME) {
/* JPEG received */
- spin_unlock_irq(&dcmi->irqlock);
dcmi_process_jpeg(dcmi);
+ spin_unlock_irq(&dcmi->irqlock);
return IRQ_HANDLED;
}
dev_dbg(dcmi->dev, "Starting capture on buffer[%d] queued\n",
buf->vb.vb2_buf.index);
- spin_unlock_irq(&dcmi->irqlock);
if (dcmi_start_capture(dcmi, buf))
dev_err(dcmi->dev, "%s: Cannot restart capture on overflow or error\n",
__func__);
- return;
}
spin_unlock_irq(&dcmi->irqlock);
dev_dbg(dcmi->dev, "Start streaming, starting capture\n");
- spin_unlock_irq(&dcmi->irqlock);
ret = dcmi_start_capture(dcmi, buf);
if (ret) {
dev_err(dcmi->dev, "%s: Start streaming failed, cannot start capture\n",
__func__);
+ spin_unlock_irq(&dcmi->irqlock);
goto err_pipeline_stop;
}
else
reg_set(dcmi->regs, DCMI_IER, IT_OVR | IT_ERR);
+ spin_unlock_irq(&dcmi->irqlock);
+
return 0;
err_pipeline_stop: