Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp4437625imm; Mon, 8 Oct 2018 22:49:21 -0700 (PDT) X-Google-Smtp-Source: ACcGV63kFpe4lHS6GizG2psLr4tJprVVzByRILTi2DJzfM+M78rtaDLY3+cdW0HMtD4MEAOj2BTc X-Received: by 2002:a63:745e:: with SMTP id e30-v6mr24285954pgn.446.1539064161433; Mon, 08 Oct 2018 22:49:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539064161; cv=none; d=google.com; s=arc-20160816; b=Y6l7cpA4dR3ZRdyFfxzrkvl9Luuws/jueT/htQbtJZHkuZSX+CPLMUdZdwUxEbkJGc 9/Vl1tg4ih0Bs+2fBlaXbSIUlpCBhWXAq9jusQiz+6To1OuArcRDPFhVkUgK7Tx6eNUh ngl3JV+jtrEhL5BL0lS95lvzK/wJ591GKrcr+CDY8LUG3jYF35t45Qguw5dR+S7tLyNd homy9eiqLeZycLQO7tsNauFDsHcX27pz797UxwQOmfMMSg39lL/jHJ4C/VzVY+ibSO8D tTb2DcAXFJ77gi2i2y6ClGDHbMM5xtpIU35sXhXzF8NsuqN6WCSjjk1dx5IdH4pVGsCO +tpQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=HUriwkHyLvnR6PfOR/IGT3CTgX/2scA9IP2awmjlhNg=; b=oRLF6IvbBJgVt5cL6AQHlFUvj9g2EjcHbsR7e/0j5hISr2teV55h7MrdBCfpajHVIV UBI5d6H0K/mRZJbQPRYYsAPhjGKr/v25oywA7LKb+rukU1xfch1fFWtSniiXHIFQArvQ v5x49gCwpRz0n3JoK0f7kSLj/chNdx8Kbhjc6GOy/JCZ2cgEvOYtXB/z6Fh49ymj75yo 4tqHz3OkSackY8kAQzy9uQH4CmkLTdgA9ZIm4SvqSMJg6i5swO3lyYJfZ3x7qELulcXM ONRSLLnTh4uzYM4myE76pEBjR0NfM4vVf1+oZyevB0g0B6qElMGuBCqj+Dy/RYww+Vyr Ly3A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=uWYR81tW; 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 a71-v6si22169411pfa.109.2018.10.08.22.49.07; Mon, 08 Oct 2018 22:49:21 -0700 (PDT) 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; dkim=pass header.i=@joelfernandes.org header.s=google header.b=uWYR81tW; 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 S1726727AbeJIND1 (ORCPT + 99 others); Tue, 9 Oct 2018 09:03:27 -0400 Received: from mail-pl1-f193.google.com ([209.85.214.193]:33850 "EHLO mail-pl1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726582AbeJIND0 (ORCPT ); Tue, 9 Oct 2018 09:03:26 -0400 Received: by mail-pl1-f193.google.com with SMTP id f18-v6so254530plr.1 for ; Mon, 08 Oct 2018 22:48:14 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=joelfernandes.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=HUriwkHyLvnR6PfOR/IGT3CTgX/2scA9IP2awmjlhNg=; b=uWYR81tWObB0a4RNo9BrUcBqCzZcJgRPoeZCBXo/pWQZrEineujy7zUB3WTRaoN0Pj EOrEy1E/xrZvrfSnUtMVONVfcxl4TXW2LD4TWlUlV3aVzx7B0lyzmHBP03SeAo7SIBYb KDMqTVMPFocag8zgmVOUKZVQQmWu52QdUxb7c= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=HUriwkHyLvnR6PfOR/IGT3CTgX/2scA9IP2awmjlhNg=; b=ZzJo36SeN4M/sZVgs3DpJuxuVX6DSGO8pAplBnSXy4lk/dOi5pIMVsLuMVUJzChuAL 3Zi5mao8bl8BajSaNyNnFaKy+7q9yJTLP1xZ/JKUmFOTPiGmh7gr1wsROR++lS1gjEer kenZDsS1CCA/Pp1Q5c5iYeO9gICuVmEq0efwD5kwrx3sBm15OSkExTJaeGH5wzzkvbat D2SxdQT01Ey59LHcq1r2h6QqZV1YarxSnRyxm9CIF8nXZAysJUkuZTd18s4eaKwrTxs0 YNiBeEtovLuOVmwf8JVf8677o8l4wVLBNAdrso1p0A9oIVouBftJrRWpCGW7ebwpCYjk s1zQ== X-Gm-Message-State: ABuFfojh+iemYU91pkHWn47yFiNRFp4wP+S2GoOx3bc+c0puRJktqaYy +azAr6m3n1D85baE5paiAaHyQSJvzK4= X-Received: by 2002:a17:902:7109:: with SMTP id a9-v6mr26985609pll.310.1539064093897; Mon, 08 Oct 2018 22:48:13 -0700 (PDT) Received: from joelaf.mtv.corp.google.com ([2620:0:1000:1601:3aef:314f:b9ea:889f]) by smtp.gmail.com with ESMTPSA id a15-v6sm16886234pff.8.2018.10.08.22.48.12 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 08 Oct 2018 22:48:12 -0700 (PDT) From: "Joel Fernandes (Google)" To: stable@vger.kernel.org Cc: Pierre Yves MORDRET , Vinod Koul , gregkh@linuxfoundation.org, Alexandre Torgue , Dan Williams , dmaengine@vger.kernel.org, "Joel Fernandes (Google)" , linux-arm-kernel@lists.infradead.org (moderated list:ARM/STM32 ARCHITECTURE), linux-kernel@vger.kernel.org, Maxime Coquelin Subject: [PATCH 5/7] dmaengine: stm32-dma: fix DMA IRQ status handling Date: Mon, 8 Oct 2018 22:47:50 -0700 Message-Id: <20181009054752.145978-6-joel@joelfernandes.org> X-Mailer: git-send-email 2.19.0.605.g01d371f741-goog In-Reply-To: <20181009054752.145978-1-joel@joelfernandes.org> References: <20181009054752.145978-1-joel@joelfernandes.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Pierre Yves MORDRET Update the way Transfer Complete and Half Transfer Complete status are acknowledge. Even if HTI is not enabled its status is shown when reading registers, driver has to clear it gently and not raise an error. Signed-off-by: Pierre-Yves MORDRET Signed-off-by: Vinod Koul --- drivers/dma/stm32-dma.c | 29 +++++++++++++++++++++++++---- 1 file changed, 25 insertions(+), 4 deletions(-) diff --git a/drivers/dma/stm32-dma.c b/drivers/dma/stm32-dma.c index 21ad359a5a59..b40486454a2c 100644 --- a/drivers/dma/stm32-dma.c +++ b/drivers/dma/stm32-dma.c @@ -34,9 +34,14 @@ #define STM32_DMA_LIFCR 0x0008 /* DMA Low Int Flag Clear Reg */ #define STM32_DMA_HIFCR 0x000c /* DMA High Int Flag Clear Reg */ #define STM32_DMA_TCI BIT(5) /* Transfer Complete Interrupt */ +#define STM32_DMA_HTI BIT(4) /* Half Transfer Interrupt */ #define STM32_DMA_TEI BIT(3) /* Transfer Error Interrupt */ #define STM32_DMA_DMEI BIT(2) /* Direct Mode Error Interrupt */ #define STM32_DMA_FEI BIT(0) /* FIFO Error Interrupt */ +#define STM32_DMA_MASKI (STM32_DMA_TCI \ + | STM32_DMA_TEI \ + | STM32_DMA_DMEI \ + | STM32_DMA_FEI) /* DMA Stream x Configuration Register */ #define STM32_DMA_SCR(x) (0x0010 + 0x18 * (x)) /* x = 0..7 */ @@ -643,13 +648,29 @@ static irqreturn_t stm32_dma_chan_irq(int irq, void *devid) status = stm32_dma_irq_status(chan); scr = stm32_dma_read(dmadev, STM32_DMA_SCR(chan->id)); - if ((status & STM32_DMA_TCI) && (scr & STM32_DMA_SCR_TCIE)) { + if (status & STM32_DMA_TCI) { stm32_dma_irq_clear(chan, STM32_DMA_TCI); - stm32_dma_handle_chan_done(chan); - - } else { + if (scr & STM32_DMA_SCR_TCIE) + stm32_dma_handle_chan_done(chan); + status &= ~STM32_DMA_TCI; + } + if (status & STM32_DMA_HTI) { + stm32_dma_irq_clear(chan, STM32_DMA_HTI); + status &= ~STM32_DMA_HTI; + } + if (status & STM32_DMA_FEI) { + stm32_dma_irq_clear(chan, STM32_DMA_FEI); + status &= ~STM32_DMA_FEI; + if (!(scr & STM32_DMA_SCR_EN)) + dev_err(chan2dev(chan), "FIFO Error\n"); + else + dev_dbg(chan2dev(chan), "FIFO over/underrun\n"); + } + if (status) { stm32_dma_irq_clear(chan, status); dev_err(chan2dev(chan), "DMA error: status=0x%08x\n", status); + if (!(scr & STM32_DMA_SCR_EN)) + dev_err(chan2dev(chan), "chan disabled by HW\n"); } spin_unlock(&chan->vchan.lock); -- 2.19.0.605.g01d371f741-goog