Received: by 10.223.185.116 with SMTP id b49csp6156788wrg; Thu, 8 Mar 2018 02:48:14 -0800 (PST) X-Google-Smtp-Source: AG47ELtpdZuR7FjPXphow2a2Ui9mbz5qzqbIn6xDaAcJb8pTIr/eyN3ZY6rTzXuq+IDvZTmza/sR X-Received: by 10.99.120.138 with SMTP id t132mr20604231pgc.54.1520506094748; Thu, 08 Mar 2018 02:48:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1520506094; cv=none; d=google.com; s=arc-20160816; b=sx6X3qH4gM/w+B4IEuQKts5iKz+A0FbuwlL7+NS0I1yht+gahujaFZJT8HmWNpwQBK pjCenxU1n5lPbYb4e+QSlXwYLPAmw+vA5CrsbNx0YTjhGCWqa5jKJ5giwvDM37xxh75l 3U7BwSCmjuBQtJ8VrxmljusNuTcc7dcwqPyg5PMbZLF2UZmyr+M4oGbkx0iwSTdCPJ7p nonZ5446pL1G/TxQAgmb2VJNkWhE/MB/xSjodiBNrXBlNZ8YDlrDlZ5tZZmZTOVNxvya QSchgsWmaCadV8RoaMJ5AAAVwvwBPtKcA6Tn9NbX5NS2rDVD4nDbQWdiotbGVpMOA7Ml 718g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from:arc-authentication-results; bh=eYqz6hMenCJ2AkkROX+FZw4+ej1OCNm0wlTDBj6ldDQ=; b=bIJeHn2GvNBqz9hTuqKaxSpm7fhnpLxvfS8mEYIsIoEFm3RVdjcrq9ppuOze3mIJNL nnqc6ogHZ9fZute7fW3nG8wcFp8COAlLegqImmTrr4H0N7nw3Cn3WdwKbj9y3uk9gj31 bTi98tN7ErmYmM8QHFh9/kXlqP23JGFNXOGbTQRuSN40rfMwoLH9c4k02kS1Srf9FHJ5 AskhEI78ODNiOqdrGw/9tFitjnS6XuIikxTXEFcyafkrBswD3gstKwyn6+7DnEO25uoy ipLdnVvPFQAaOLIzCVwzdDTPvSMxff73KcXoCTxjgt+8Nj2yWhTSKCSc0D1D8RTMgHYB 4bVA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t21-v6si15057849plj.269.2018.03.08.02.48.00; Thu, 08 Mar 2018 02:48:14 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S965592AbeCHKrE (ORCPT + 99 others); Thu, 8 Mar 2018 05:47:04 -0500 Received: from mx08-00178001.pphosted.com ([91.207.212.93]:14654 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S934574AbeCHKrC (ORCPT ); Thu, 8 Mar 2018 05:47:02 -0500 Received: from pps.filterd (m0046660.ppops.net [127.0.0.1]) by mx08-.pphosted.com (8.16.0.21/8.16.0.21) with SMTP id w28Ai01p001251; Thu, 8 Mar 2018 11:46:38 +0100 Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx08-00178001.pphosted.com with ESMTP id 2gjwa7syw5-1 (version=TLSv1 cipher=ECDHE-RSA-AES256-SHA bits=256 verify=NOT); Thu, 08 Mar 2018 11:46:38 +0100 Received: from zeta.dmz-eu.st.com (zeta.dmz-eu.st.com [164.129.230.9]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id 4EED134; Thu, 8 Mar 2018 10:46:37 +0000 (GMT) Received: from Webmail-eu.st.com (Safex1hubcas24.st.com [10.75.90.94]) by zeta.dmz-eu.st.com (STMicroelectronics) with ESMTP id 276472BBB; Thu, 8 Mar 2018 10:46:37 +0000 (GMT) Received: from SAFEX1HUBCAS21.st.com (10.75.90.44) by Safex1hubcas24.st.com (10.75.90.94) with Microsoft SMTP Server (TLS) id 14.3.361.1; Thu, 8 Mar 2018 11:46:37 +0100 Received: from localhost (10.201.23.73) by Webmail-ga.st.com (10.75.90.48) with Microsoft SMTP Server (TLS) id 14.3.361.1; Thu, 8 Mar 2018 11:46:36 +0100 From: Hugues Fruchet To: Maxime Coquelin , Alexandre Torgue , Mauro Carvalho Chehab , "Hans Verkuil" CC: , , , Benjamin Gaignard , Yannick Fertre , Hugues Fruchet Subject: [PATCH v2] media: stm32-dcmi: rework overrun/error case Date: Thu, 8 Mar 2018 11:46:23 +0100 Message-ID: <1520505983-29242-1-git-send-email-hugues.fruchet@st.com> X-Mailer: git-send-email 1.9.1 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.201.23.73] X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2018-03-08_06:,, signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Do not stop/restart dma on overrun or errors. Dma will be restarted on current frame transfer completion. Frame transfer completion is ensured even if overrun or error occurs by DCMI continuous capture mode which restarts data transfer at next frame sync. Do no warn on overrun while in irq thread, this slows down system and lead to more overrun errors. Use a counter instead and log errors at stop streaming. Signed-off-by: Hugues Fruchet --- version 2: - typo: remove blank line at the end of stop_streaming() drivers/media/platform/stm32/stm32-dcmi.c | 29 +++++++++++------------------ 1 file changed, 11 insertions(+), 18 deletions(-) diff --git a/drivers/media/platform/stm32/stm32-dcmi.c b/drivers/media/platform/stm32/stm32-dcmi.c index 37d82d3..95ace0f 100644 --- a/drivers/media/platform/stm32/stm32-dcmi.c +++ b/drivers/media/platform/stm32/stm32-dcmi.c @@ -160,6 +160,7 @@ struct stm32_dcmi { dma_cookie_t dma_cookie; u32 misr; int errors_count; + int overrun_count; int buffers_count; }; @@ -373,23 +374,9 @@ static irqreturn_t dcmi_irq_thread(int irq, void *arg) } if ((dcmi->misr & IT_OVR) || (dcmi->misr & IT_ERR)) { - /* - * An overflow or an error has been detected, - * stop current DMA transfert & restart it - */ - dev_warn(dcmi->dev, "%s: Overflow or error detected\n", - __func__); - dcmi->errors_count++; - dev_dbg(dcmi->dev, "Restarting capture after DCMI error\n"); - - spin_unlock_irq(&dcmi->irqlock); - dmaengine_terminate_all(dcmi->dma_chan); - - if (dcmi_start_capture(dcmi)) - dev_err(dcmi->dev, "%s: Cannot restart capture on overflow or error\n", - __func__); - return IRQ_HANDLED; + if (dcmi->misr & IT_OVR) + dcmi->overrun_count++; } spin_unlock_irq(&dcmi->irqlock); @@ -572,6 +559,7 @@ static int dcmi_start_streaming(struct vb2_queue *vq, unsigned int count) dcmi->sequence = 0; dcmi->errors_count = 0; + dcmi->overrun_count = 0; dcmi->buffers_count = 0; dcmi->active = NULL; @@ -682,8 +670,13 @@ static void dcmi_stop_streaming(struct vb2_queue *vq) clk_disable(dcmi->mclk); - dev_dbg(dcmi->dev, "Stop streaming, errors=%d buffers=%d\n", - dcmi->errors_count, dcmi->buffers_count); + if (dcmi->errors_count) + dev_warn(dcmi->dev, "Some errors found while streaming: errors=%d (overrun=%d), buffers=%d\n", + dcmi->errors_count, dcmi->overrun_count, + dcmi->buffers_count); + dev_dbg(dcmi->dev, "Stop streaming, errors=%d (overrun=%d), buffers=%d\n", + dcmi->errors_count, dcmi->overrun_count, + dcmi->buffers_count); } static const struct vb2_ops dcmi_video_qops = { -- 1.9.1