Commit 3c8fcf77 authored by David Brownell's avatar David Brownell Committed by Kevin Hilman

EDMA TC selection updates

Minor tweaks:

  - Bugfix handling of EVENTQ_DEFAULT ... recognize it, and
    implement as EVENTQ_1 instead of reserved/illegal value

  - Use the defined enum type internally

  - Have MMC use TC1, as appropriate for "longer, nonreal-time
    sensitive transfers" (per docs) ... instead of using TC0,
    as for "urgent, small, real-time sensitive transfers".

Arguably, TC0 priority should be increased (to 0) to be
higher priority than the ARM ... matching "urgent" etc.

The added TCs on DM646x chips are still not recognized.
Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
parent 9df2a6b8
...@@ -281,10 +281,14 @@ queue_priority_mapping[DAVINCI_EDMA_NUM_EVQUE + 1][2] = { ...@@ -281,10 +281,14 @@ queue_priority_mapping[DAVINCI_EDMA_NUM_EVQUE + 1][2] = {
/*****************************************************************************/ /*****************************************************************************/
static void map_dmach_queue(int ch_no, int queue_no) static void map_dmach_queue(unsigned ch_no, enum dma_event_q queue_no)
{ {
int bit = (ch_no & 0x7) * 4; int bit = (ch_no & 0x7) * 4;
/* default to low priority queue */
if (queue_no == EVENTQ_DEFAULT)
queue_no = EVENTQ_1;
queue_no &= 7; queue_no &= 7;
edma_modify_array(EDMA_DMAQNUM, (ch_no >> 3), edma_modify_array(EDMA_DMAQNUM, (ch_no >> 3),
~(0x7 << bit), queue_no << bit); ~(0x7 << bit), queue_no << bit);
...@@ -547,7 +551,7 @@ static int __init davinci_dma_init(void) ...@@ -547,7 +551,7 @@ static int __init davinci_dma_init(void)
* started by the codec engine will not cause audio defects. * started by the codec engine will not cause audio defects.
*/ */
for (i = 0; i < DAVINCI_EDMA_NUM_DMACH; i++) for (i = 0; i < DAVINCI_EDMA_NUM_DMACH; i++)
map_dmach_queue(i, 1); map_dmach_queue(i, EVENTQ_1);
i = 0; i = 0;
/* Event queue to TC mapping */ /* Event queue to TC mapping */
...@@ -581,7 +585,8 @@ arch_initcall(davinci_dma_init); ...@@ -581,7 +585,8 @@ arch_initcall(davinci_dma_init);
* @callback: optional; to be issued on DMA completion or errors * @callback: optional; to be issued on DMA completion or errors
* @data: passed to callback * @data: passed to callback
* @eventq_no: an EVENTQ_* constant, used to choose which Transfer * @eventq_no: an EVENTQ_* constant, used to choose which Transfer
* Controller (TC) executes requests using this channel * Controller (TC) executes requests using this channel. Use
* EVENTQ_DEFAULT unless you really need a high priority queue.
* *
* This allocates a DMA channel and its associated parameter RAM slot. * This allocates a DMA channel and its associated parameter RAM slot.
* The parameter RAM is initialized to hold a dummy transfer. * The parameter RAM is initialized to hold a dummy transfer.
......
...@@ -581,7 +581,8 @@ static int __init davinci_acquire_dma_channels(struct mmc_davinci_host *host) ...@@ -581,7 +581,8 @@ static int __init davinci_acquire_dma_channels(struct mmc_davinci_host *host)
int r; int r;
/* Acquire master DMA write channel */ /* Acquire master DMA write channel */
r = edma_alloc_channel(host->txdma, mmc_davinci_dma_cb, host, EVENTQ_0); r = edma_alloc_channel(host->txdma, mmc_davinci_dma_cb, host,
EVENTQ_DEFAULT);
if (r < 0) { if (r < 0) {
dev_warn(mmc_dev(host->mmc), "alloc %s channel err %d\n", dev_warn(mmc_dev(host->mmc), "alloc %s channel err %d\n",
"tx", r); "tx", r);
...@@ -590,7 +591,8 @@ static int __init davinci_acquire_dma_channels(struct mmc_davinci_host *host) ...@@ -590,7 +591,8 @@ static int __init davinci_acquire_dma_channels(struct mmc_davinci_host *host)
mmc_davinci_dma_setup(host, true, &host->tx_template); mmc_davinci_dma_setup(host, true, &host->tx_template);
/* Acquire master DMA read channel */ /* Acquire master DMA read channel */
r = edma_alloc_channel(host->rxdma, mmc_davinci_dma_cb, host, EVENTQ_0); r = edma_alloc_channel(host->rxdma, mmc_davinci_dma_cb, host,
EVENTQ_DEFAULT);
if (r < 0) { if (r < 0) {
dev_warn(mmc_dev(host->mmc), "alloc %s channel err %d\n", dev_warn(mmc_dev(host->mmc), "alloc %s channel err %d\n",
"rx", r); "rx", r);
......
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