diff options
author | Xiaochun Li <b41219@freescale.com> | 2012-08-07 18:11:02 +0800 |
---|---|---|
committer | Justin Waters <justin.waters@timesys.com> | 2012-09-12 16:50:00 -0400 |
commit | a444d8a409bfd084a83b33cffc9262b60ba2204f (patch) | |
tree | c831066835c56e0370c27e01dcc9636e18352e27 | |
parent | 5e7187646d354802f062cf37683931c61b30a998 (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/Kconfig | 8 | ||||
-rw-r--r-- | drivers/dma/Makefile | 4 | ||||
-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); } |