提交 4d76bbed 编写于 作者: A Arnd Bergmann 提交者: Vinod Koul

dmaengine: coh901318: fix function return types build warnings

A recent patch that removed coh901318_control() replaced it
with a number of pointers to existing functions, but those
unfortunately have the wrong return  type and need to be
changed to return an 'int' with an error value rather than
a 'void' to avoid these build warnings:

drivers/dma/coh901318.c:2697:32: warning: assignment from incompatible pointer type
  base->dma_slave.device_config = coh901318_dma_set_runtimeconfig;
                                ^
drivers/dma/coh901318.c:2698:31: warning: assignment from incompatible pointer type
  base->dma_slave.device_pause = coh901318_pause;
                               ^
drivers/dma/coh901318.c:2699:32: warning: assignment from incompatible pointer type
  base->dma_slave.device_resume = coh901318_resume

The coh901318_base_init function has the correct return type
already, but needs to be marked 'static' to avoid a sparse
warning about a missing declaration.
Signed-off-by: NArnd Bergmann <arnd@arndb.de>
Fixes: 6782af11 ("dmaengine: coh901318: Split device_control")
Acked-by: NLinus Walleij <linus.walleij@linaro.org>
Signed-off-by: NVinod Koul <vinod.koul@intel.com>
上级 848e10bb
...@@ -1690,7 +1690,7 @@ static u32 coh901318_get_bytes_left(struct dma_chan *chan) ...@@ -1690,7 +1690,7 @@ static u32 coh901318_get_bytes_left(struct dma_chan *chan)
* Pauses a transfer without losing data. Enables power save. * Pauses a transfer without losing data. Enables power save.
* Use this function in conjunction with coh901318_resume. * Use this function in conjunction with coh901318_resume.
*/ */
static void coh901318_pause(struct dma_chan *chan) static int coh901318_pause(struct dma_chan *chan)
{ {
u32 val; u32 val;
unsigned long flags; unsigned long flags;
...@@ -1730,12 +1730,13 @@ static void coh901318_pause(struct dma_chan *chan) ...@@ -1730,12 +1730,13 @@ static void coh901318_pause(struct dma_chan *chan)
enable_powersave(cohc); enable_powersave(cohc);
spin_unlock_irqrestore(&cohc->lock, flags); spin_unlock_irqrestore(&cohc->lock, flags);
return 0;
} }
/* Resumes a transfer that has been stopped via 300_dma_stop(..). /* Resumes a transfer that has been stopped via 300_dma_stop(..).
Power save is handled. Power save is handled.
*/ */
static void coh901318_resume(struct dma_chan *chan) static int coh901318_resume(struct dma_chan *chan)
{ {
u32 val; u32 val;
unsigned long flags; unsigned long flags;
...@@ -1760,6 +1761,7 @@ static void coh901318_resume(struct dma_chan *chan) ...@@ -1760,6 +1761,7 @@ static void coh901318_resume(struct dma_chan *chan)
} }
spin_unlock_irqrestore(&cohc->lock, flags); spin_unlock_irqrestore(&cohc->lock, flags);
return 0;
} }
bool coh901318_filter_id(struct dma_chan *chan, void *chan_id) bool coh901318_filter_id(struct dma_chan *chan, void *chan_id)
...@@ -2512,7 +2514,7 @@ static const struct burst_table burst_sizes[] = { ...@@ -2512,7 +2514,7 @@ static const struct burst_table burst_sizes[] = {
}, },
}; };
static void coh901318_dma_set_runtimeconfig(struct dma_chan *chan, static int coh901318_dma_set_runtimeconfig(struct dma_chan *chan,
struct dma_slave_config *config) struct dma_slave_config *config)
{ {
struct coh901318_chan *cohc = to_coh901318_chan(chan); struct coh901318_chan *cohc = to_coh901318_chan(chan);
...@@ -2533,7 +2535,7 @@ static void coh901318_dma_set_runtimeconfig(struct dma_chan *chan, ...@@ -2533,7 +2535,7 @@ static void coh901318_dma_set_runtimeconfig(struct dma_chan *chan,
maxburst = config->dst_maxburst; maxburst = config->dst_maxburst;
} else { } else {
dev_err(COHC_2_DEV(cohc), "illegal channel mode\n"); dev_err(COHC_2_DEV(cohc), "illegal channel mode\n");
return; return -EINVAL;
} }
dev_dbg(COHC_2_DEV(cohc), "configure channel for %d byte transfers\n", dev_dbg(COHC_2_DEV(cohc), "configure channel for %d byte transfers\n",
...@@ -2579,7 +2581,7 @@ static void coh901318_dma_set_runtimeconfig(struct dma_chan *chan, ...@@ -2579,7 +2581,7 @@ static void coh901318_dma_set_runtimeconfig(struct dma_chan *chan,
default: default:
dev_err(COHC_2_DEV(cohc), dev_err(COHC_2_DEV(cohc),
"bad runtimeconfig: alien address width\n"); "bad runtimeconfig: alien address width\n");
return; return -EINVAL;
} }
ctrl |= burst_sizes[i].reg; ctrl |= burst_sizes[i].reg;
...@@ -2589,9 +2591,11 @@ static void coh901318_dma_set_runtimeconfig(struct dma_chan *chan, ...@@ -2589,9 +2591,11 @@ static void coh901318_dma_set_runtimeconfig(struct dma_chan *chan,
cohc->addr = addr; cohc->addr = addr;
cohc->ctrl = ctrl; cohc->ctrl = ctrl;
return 0;
} }
void coh901318_base_init(struct dma_device *dma, const int *pick_chans, static void coh901318_base_init(struct dma_device *dma, const int *pick_chans,
struct coh901318_base *base) struct coh901318_base *base)
{ {
int chans_i; int chans_i;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册