Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 7c995023 authored by Sascha Hauer's avatar Sascha Hauer
Browse files

[ARM] MX1/MX2 DMA: add missing local_irq_restore()



This patch adds a missing call to local_irq_restore() and fixes some
compiler warnings about unused variables for MX1.

Signed-off-by: default avatarSascha Hauer <s.hauer@pengutronix.de>
parent b71edbe9
Loading
Loading
Loading
Loading
+5 −2
Original line number Diff line number Diff line
@@ -511,6 +511,7 @@ void imx_dma_disable(int channel)
}
EXPORT_SYMBOL(imx_dma_disable);

#ifdef CONFIG_ARCH_MX2
static void imx_dma_watchdog(unsigned long chno)
{
	struct imx_dma_channel *imxdma = &imx_dma_channels[chno];
@@ -522,6 +523,7 @@ static void imx_dma_watchdog(unsigned long chno)
	if (imxdma->err_handler)
		imxdma->err_handler(chno, imxdma->data, IMX_DMA_ERR_TIMEOUT);
}
#endif

static irqreturn_t dma_err_handler(int irq, void *dev_id)
{
@@ -674,7 +676,7 @@ int imx_dma_request(int channel, const char *name)
{
	struct imx_dma_channel *imxdma = &imx_dma_channels[channel];
	unsigned long flags;
	int ret;
	int ret = 0;

	/* basic sanity checks */
	if (!name)
@@ -696,6 +698,7 @@ int imx_dma_request(int channel, const char *name)
	ret = request_irq(MXC_INT_DMACH0 + channel, dma_irq_handler, 0, "DMA",
			NULL);
	if (ret) {
		local_irq_restore(flags);
		printk(KERN_CRIT "Can't register IRQ %d for DMA channel %d\n",
				MXC_INT_DMACH0 + channel, channel);
		return ret;
@@ -712,7 +715,7 @@ int imx_dma_request(int channel, const char *name)
	imxdma->sg = NULL;

	local_irq_restore(flags);
	return 0;
	return ret;
}
EXPORT_SYMBOL(imx_dma_request);