Commit 8f1cc233 authored by Mike Frysinger's avatar Mike Frysinger Committed by Bryan Wu

Blackfin arch: set_dma_callback: do not store .irq

set_dma_callback: do not store .irq if request_irq() failed so we dont
turn around and attempt to free_irq() it later on in free_dma()
Signed-off-by: default avatarMike Frysinger <vapier.adi@gmail.com>
Signed-off-by: default avatarBryan Wu <cooloney@kernel.org>
parent 9b011407
...@@ -157,18 +157,16 @@ int set_dma_callback(unsigned int channel, irq_handler_t callback, void *data) ...@@ -157,18 +157,16 @@ int set_dma_callback(unsigned int channel, irq_handler_t callback, void *data)
&& channel < MAX_DMA_CHANNELS)); && channel < MAX_DMA_CHANNELS));
if (callback != NULL) { if (callback != NULL) {
int ret_val; int ret;
dma_ch[channel].irq = channel2irq(channel); unsigned int irq = channel2irq(channel);
dma_ch[channel].data = data;
ret_val = ret = request_irq(irq, callback, IRQF_DISABLED,
request_irq(dma_ch[channel].irq, callback, IRQF_DISABLED, dma_ch[channel].device_id, data);
dma_ch[channel].device_id, data); if (ret)
if (ret_val) { return ret;
printk(KERN_NOTICE
"Request irq in DMA engine failed.\n"); dma_ch[channel].irq = irq;
return -EPERM; dma_ch[channel].data = data;
}
} }
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment