diff options
Diffstat (limited to 'arch/arm/mach-omap2/dma.c')
-rw-r--r-- | arch/arm/mach-omap2/dma.c | 14 |
1 files changed, 5 insertions, 9 deletions
diff --git a/arch/arm/mach-omap2/dma.c b/arch/arm/mach-omap2/dma.c index 81c2d3383bc5..e4ac7ac9a228 100644 --- a/arch/arm/mach-omap2/dma.c +++ b/arch/arm/mach-omap2/dma.c | |||
@@ -38,11 +38,10 @@ | |||
38 | #define OMAP2_DMA_STRIDE 0x60 | 38 | #define OMAP2_DMA_STRIDE 0x60 |
39 | 39 | ||
40 | static u32 errata; | 40 | static u32 errata; |
41 | static u8 dma_stride; | ||
42 | 41 | ||
43 | static struct omap_dma_dev_attr *d; | 42 | static struct omap_dma_dev_attr *d; |
44 | 43 | ||
45 | static enum omap_reg_offsets dma_common_ch_start, dma_common_ch_end; | 44 | static enum omap_reg_offsets dma_common_ch_end; |
46 | 45 | ||
47 | static u16 reg_map[] = { | 46 | static u16 reg_map[] = { |
48 | [REVISION] = 0x00, | 47 | [REVISION] = 0x00, |
@@ -96,7 +95,7 @@ static inline void dma_write(u32 val, int reg, int lch) | |||
96 | u8 stride; | 95 | u8 stride; |
97 | u32 offset; | 96 | u32 offset; |
98 | 97 | ||
99 | stride = (reg >= dma_common_ch_start) ? dma_stride : 0; | 98 | stride = (reg >= CSDP) ? OMAP2_DMA_STRIDE : 0; |
100 | offset = reg_map[reg] + (stride * lch); | 99 | offset = reg_map[reg] + (stride * lch); |
101 | __raw_writel(val, dma_base + offset); | 100 | __raw_writel(val, dma_base + offset); |
102 | } | 101 | } |
@@ -106,7 +105,7 @@ static inline u32 dma_read(int reg, int lch) | |||
106 | u8 stride; | 105 | u8 stride; |
107 | u32 offset, val; | 106 | u32 offset, val; |
108 | 107 | ||
109 | stride = (reg >= dma_common_ch_start) ? dma_stride : 0; | 108 | stride = (reg >= CSDP) ? OMAP2_DMA_STRIDE : 0; |
110 | offset = reg_map[reg] + (stride * lch); | 109 | offset = reg_map[reg] + (stride * lch); |
111 | val = __raw_readl(dma_base + offset); | 110 | val = __raw_readl(dma_base + offset); |
112 | return val; | 111 | return val; |
@@ -114,9 +113,9 @@ static inline u32 dma_read(int reg, int lch) | |||
114 | 113 | ||
115 | static void omap2_clear_dma(int lch) | 114 | static void omap2_clear_dma(int lch) |
116 | { | 115 | { |
117 | int i = dma_common_ch_start; | 116 | int i; |
118 | 117 | ||
119 | for (; i <= dma_common_ch_end; i += 1) | 118 | for (i = CSDP; i <= dma_common_ch_end; i += 1) |
120 | dma_write(0, i, lch); | 119 | dma_write(0, i, lch); |
121 | } | 120 | } |
122 | 121 | ||
@@ -219,9 +218,6 @@ static int __init omap2_system_dma_init_dev(struct omap_hwmod *oh, void *unused) | |||
219 | struct resource *mem; | 218 | struct resource *mem; |
220 | char *name = "omap_dma_system"; | 219 | char *name = "omap_dma_system"; |
221 | 220 | ||
222 | dma_stride = OMAP2_DMA_STRIDE; | ||
223 | dma_common_ch_start = CSDP; | ||
224 | |||
225 | p = kzalloc(sizeof(struct omap_system_dma_plat_info), GFP_KERNEL); | 221 | p = kzalloc(sizeof(struct omap_system_dma_plat_info), GFP_KERNEL); |
226 | if (!p) { | 222 | if (!p) { |
227 | pr_err("%s: Unable to allocate pdata for %s:%s\n", | 223 | pr_err("%s: Unable to allocate pdata for %s:%s\n", |