提交 447f18f1 编写于 作者: S Sudhakar Rajashekhara 提交者: Kevin Hilman

davinci: Fix edma_alloc_channel api for EDMA_CHANNEL_ANY case

Though edma_alloc_channel api was looping through the available
channel controllers in EDMA_CHANNEL_ANY case, it was never
returning the channel for 2nd channel controller, if 1st
channel controller had no free channels. This issue has
been fixed with this patch.
Signed-off-by: NSudhakar Rajashekhara <sudhakar.raj@ti.com>
Signed-off-by: NKevin Hilman <khilman@deeprootsystems.com>
上级 2d517508
...@@ -595,7 +595,7 @@ int edma_alloc_channel(int channel, ...@@ -595,7 +595,7 @@ int edma_alloc_channel(int channel,
void *data, void *data,
enum dma_event_q eventq_no) enum dma_event_q eventq_no)
{ {
unsigned i, done, ctlr = 0; unsigned i, done = 0, ctlr = 0;
if (channel >= 0) { if (channel >= 0) {
ctlr = EDMA_CTLR(channel); ctlr = EDMA_CTLR(channel);
...@@ -611,7 +611,7 @@ int edma_alloc_channel(int channel, ...@@ -611,7 +611,7 @@ int edma_alloc_channel(int channel,
edma_info[i]->num_channels, edma_info[i]->num_channels,
channel); channel);
if (channel == edma_info[i]->num_channels) if (channel == edma_info[i]->num_channels)
return -ENOMEM; break;
if (!test_and_set_bit(channel, if (!test_and_set_bit(channel,
edma_info[i]->edma_inuse)) { edma_info[i]->edma_inuse)) {
done = 1; done = 1;
...@@ -623,6 +623,8 @@ int edma_alloc_channel(int channel, ...@@ -623,6 +623,8 @@ int edma_alloc_channel(int channel,
if (done) if (done)
break; break;
} }
if (!done)
return -ENOMEM;
} else if (channel >= edma_info[ctlr]->num_channels) { } else if (channel >= edma_info[ctlr]->num_channels) {
return -EINVAL; return -EINVAL;
} else if (test_and_set_bit(channel, edma_info[ctlr]->edma_inuse)) { } else if (test_and_set_bit(channel, edma_info[ctlr]->edma_inuse)) {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册