summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorXiaochun Li <b41219@freescale.com>2012-08-07 18:11:02 +0800
committerJustin Waters <justin.waters@timesys.com>2012-09-12 16:50:00 -0400
commita444d8a409bfd084a83b33cffc9262b60ba2204f (patch)
treec831066835c56e0370c27e01dcc9636e18352e27
parent5e7187646d354802f062cf37683931c61b30a998 (diff)
ENGR00219342: edma: Updated edma driver and edma test driver
This patch is to update Edma driver after debugging on board. mainly, fixed the bug that resulting the request source of DMA1 overflow Signed-off-by: Xiaochun Li <b41219@freescale.com>
-rw-r--r--drivers/dma/Kconfig8
-rw-r--r--drivers/dma/Makefile4
-rw-r--r--drivers/dma/mvf_edma.c (renamed from drivers/dma/mcf_edma.c)11
-rw-r--r--drivers/dma/mvf_edma_test.c (renamed from drivers/dma/mcf_edma_test.c)79
4 files changed, 79 insertions, 23 deletions
diff --git a/drivers/dma/Kconfig b/drivers/dma/Kconfig
index cac205c9fbd9..5641f5b12e20 100644
--- a/drivers/dma/Kconfig
+++ b/drivers/dma/Kconfig
@@ -107,7 +107,7 @@ config FSL_DMA
The Elo is the DMA controller on some 82xx and 83xx parts, and the
Elo Plus is the DMA controller on 85xx and 86xx parts.
-config MCF_EDMA
+config MVF_EDMA
tristate "Faraday eDMA support"
default y
depends on ARCH_MVF
@@ -116,9 +116,9 @@ config MCF_EDMA
Enable support for Faraday eDMA controller. For example
used by Faraday SAI Audio device driver.
-config MCF_EDMA_TEST
- tristate "MCF eDMA simple test module"
- depends on MCF_EDMA
+config MVF_EDMA_TEST
+ tristate "MVF eDMA simple test module"
+ depends on MVF_EDMA
default m
help
This is simple eDMA test module.
diff --git a/drivers/dma/Makefile b/drivers/dma/Makefile
index 6a5eadee7b5e..33cbfe890f1d 100644
--- a/drivers/dma/Makefile
+++ b/drivers/dma/Makefile
@@ -8,8 +8,8 @@ obj-$(CONFIG_DMATEST) += dmatest.o
obj-$(CONFIG_INTEL_IOATDMA) += ioat/
obj-$(CONFIG_INTEL_IOP_ADMA) += iop-adma.o
obj-$(CONFIG_FSL_DMA) += fsldma.o
-obj-$(CONFIG_MCF_EDMA) += mcf_edma.o
-obj-$(CONFIG_MCF_EDMA_TEST) += mcf_edma_test.o
+obj-$(CONFIG_MVF_EDMA) += mvf_edma.o
+obj-$(CONFIG_MVF_EDMA_TEST) += mvf_edma_test.o
obj-$(CONFIG_MPC512X_DMA) += mpc512x_dma.o
obj-$(CONFIG_MV_XOR) += mv_xor.o
obj-$(CONFIG_DW_DMAC) += dw_dmac.o
diff --git a/drivers/dma/mcf_edma.c b/drivers/dma/mvf_edma.c
index c16079b6beec..bbdcb8297b58 100644
--- a/drivers/dma/mcf_edma.c
+++ b/drivers/dma/mvf_edma.c
@@ -731,7 +731,7 @@ mcf_edma_request_channel(int channel,
}
if (i >= 20)
return -EBUSY;
- channel = i >= 10 ? 64 + 54 + i : 54 + i;
+ channel = i >= 10 ? 64 + 54 + i - 10 : 54 + i;
}
if (channel >= 64) {
@@ -820,6 +820,8 @@ mcf_edma_request_channel(int channel,
ERR("Bad channel number!\n");
#elif defined(CONFIG_ARCH_MVF)
/* config the dma mux to route the source */
+ mcf_edma_devp->dma_interrupt_handlers[cfg_ch].slot = channel;
+
if (channel >= 64)
channel -= 64;
writeb(0x00, mcf_edma_devp->dmamux_base_addr[cfg_ch / 16] +
@@ -828,7 +830,6 @@ mcf_edma_request_channel(int channel,
writeb(DMAMUX_CHCFG_ENBL|DMAMUX_CHCFG_SOURCE(channel),
mcf_edma_devp->dmamux_base_addr[cfg_ch/16] +
DMAMUX_CHCFG(cfg_ch%16));
- mcf_edma_devp->dma_interrupt_handlers[cfg_ch].slot = channel;
return cfg_ch;
#endif
@@ -904,9 +905,9 @@ mcf_edma_free_channel(int channel, void *arg)
slot =
mcf_edma_devp->dma_interrupt_handlers[channel].slot;
if (slot >= 54 && slot < 64)
- mvf_dma_mux_pool[slot - 53] = 0;
- else if (slot >= 117 && slot < 128)
- mvf_dma_mux_pool[slot - 64 - 53] = 0;
+ mvf_dma_mux_pool[slot - 54] = 0;
+ else if (slot >= 118 && slot < 128)
+ mvf_dma_mux_pool[slot - 64 - 54 + 10] = 0;
#endif
}
diff --git a/drivers/dma/mcf_edma_test.c b/drivers/dma/mvf_edma_test.c
index 61bf0c24277c..cd3065eba950 100644
--- a/drivers/dma/mcf_edma_test.c
+++ b/drivers/dma/mvf_edma_test.c
@@ -1,9 +1,7 @@
/*
* Copyright 2012 Freescale Semiconductor, Inc.
*
- * Author: Andrey Butok
- *
- * Simple test/example module for Coldfire eDMA.
+ * Simple test/example module for Faraday eDMA.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
@@ -42,7 +40,7 @@
#define MCF_EDMA_TEST_DRIVER_AUTHOR \
"Freescale Semiconductor Inc, Andrey Butok"
#define MCF_EDMA_TEST_DRIVER_DESC \
- "Simple testing module for Coldfire eDMA "
+ "Simple testing module for Faraday eDMA "
#define MCF_EDMA_TEST_DRIVER_INFO \
MCF_EDMA_TEST_DRIVER_VERSION " " MCF_EDMA_TEST_DRIVER_DESC
#define MCF_EDMA_TEST_DRIVER_LICENSE "GPL"
@@ -53,6 +51,16 @@
#define FALSE 0
#endif
+/****************For testing options*************/
+#if 0
+#define ALWAYS_ENABLED_MODE 1 /* test edma always enabled mode */
+#define ROUTETO_DMA1 1 /* test Mux 1,2 sources (64 ~ 117) for dma1 */
+#define ROUTETO_DMA0 1 /* test Mux 0,3 sources (0 ~ 63) for dma0 */
+#endif
+#ifndef ALWAYS_ENABLED_MODE & ROUTETO_DMA1
+#define ROUTETO_DMA0
+#endif
+/*************************************************/
/* Global variable used to signal main process when interrupt is recognized */
static int mcf_edma_test_interrupt;
int *mcf_edma_test_interrupt_p = &mcf_edma_test_interrupt;
@@ -102,7 +110,8 @@ mcf_edma_test_run(void)
u8 *dest_address;
u32 test_data;
int channel;
- u32 allocated_channels = 0;
+ u32 allocated_channels_dma0 = 0;
+ u32 allocated_channels_dma1 = 0;
printk(KERN_INFO "\n===============================================\n");
printk(KERN_INFO "\nStarting eDMA transfer tests!\n");
@@ -129,10 +138,20 @@ mcf_edma_test_run(void)
/* Test all automatically allocated DMA channels. The test data is
* complemented at the end of the loop, so that the testData value
* isn't the same twice in a row */
- for (i = 0; i < 16; i++) {
+#ifdef ALWAYS_ENABLED_MODE
+ for (i = 0; i < 20; i++) {
+#elif ROUTETO_DMA1
+ for (i = 64; i < 96; i++) {
+#else
+ for (i = 0; i < 32; i++) {
+#endif
/* request eDMA channel */
channel = mcf_edma_request_channel(
- /* MCF_EDMA_CHANNEL_ANY*/i,
+#ifdef ALWAYS_ENABLED_MODE
+ MCF_EDMA_CHANNEL_ANY,
+#else
+ i,
+#endif
mcf_edma_test_handler,
NULL,
0x6,
@@ -142,8 +161,23 @@ mcf_edma_test_run(void)
if (channel < 0)
goto test_end;
-
- allocated_channels |= (1 << channel);
+#ifdef ALWAYS_ENABLED_MODE
+ if (i > 9 && i < 20)
+ printk(KERN_INFO "*****channel: %d ***** routed to : %d\n",
+ i + 118, channel);
+ else
+ printk(KERN_INFO "*****channel: %d ***** routed to : %d\n",
+ i + 54, channel);
+#else
+ printk(KERN_INFO "*****channel: %d ***** routed to : %d\n",
+ i, channel);
+#endif
+ if (channel >= 0 && channel < 16)
+ allocated_channels_dma0 |= (1 << channel);
+ else if (channel >= 48 && channel < 64)
+ allocated_channels_dma0 |= (1 << (channel - 48 + 16));
+ else if (channel >= 16 && channel < 48)
+ allocated_channels_dma1 |= (1 << channel - 16);
/* Initialize data for DMA to move */
for (j = 0; j < byte_count; j = j + 4)
@@ -154,13 +188,21 @@ mcf_edma_test_run(void)
mcf_edma_test_interrupt = FALSE;
/* Configure DMA Channel TCD */
+#ifdef ALWAYS_ENABLED_MODE
+ mcf_edma_set_tcd_params(channel, (u32) start_address,
+ (u32) dest_address,
+ (0 | MCF_EDMA_TCD_ATTR_SSIZE_32BIT |
+ MCF_EDMA_TCD_ATTR_DSIZE_32BIT), 0x04,
+ byte_count, 0x0, 1, 1, 0x04, 0x0, 0x1,
+ 0x1, 0x0);
+#else
mcf_edma_set_tcd_params(channel, (u32) start_address,
(u32) dest_address,
(0 | MCF_EDMA_TCD_ATTR_SSIZE_32BIT |
MCF_EDMA_TCD_ATTR_DSIZE_32BIT), 0x04,
byte_count, 0x0, 1, 1, 0x04, 0x0, 0x1,
0x0, 0x0);
-
+#endif
/* Start DMA. */
mcf_edma_start_transfer(channel);
@@ -187,9 +229,22 @@ mcf_edma_test_run(void)
test_end:
printk(KERN_INFO "All tests have completed\n\n");
- printk(KERN_INFO "Automatically allocated %d eDMA channels:\n", i);
+ printk(KERN_INFO "dma0: 0x%08x dma1: 0x%08x\n\n",
+ allocated_channels_dma0, allocated_channels_dma1);
+ printk(KERN_INFO "Automatically allocated eDMA channels:");
for (i = 0; i < MCF_EDMA_CHANNELS; i++) {
- if (allocated_channels & (1 << i)) {
+ if (i < 16 && allocated_channels_dma0 & (1 << i)) {
+ printk(KERN_INFO "%d,\n", i);
+ mcf_edma_free_channel(i, NULL);
+ }
+
+ if (i >= 48 && allocated_channels_dma0 & (1 << (i - 48 + 16))) {
+ printk(KERN_INFO "%d,\n", i);
+ mcf_edma_free_channel(i, NULL);
+ }
+
+ if (i >= 16 && i <= 47 &&
+ allocated_channels_dma1 & (1 << (i - 16))) {
printk(KERN_INFO "%d,\n", i);
mcf_edma_free_channel(i, NULL);
}