diff options
author | Guennadi Liakhovetski <g.liakhovetski@gmx.de> | 2010-02-03 09:44:12 -0500 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2010-02-07 19:40:24 -0500 |
commit | 623b4ac4bf9e767991c66e29b47dd4b19458fb42 (patch) | |
tree | 9cf9c5ef8ac1ab714a35db1baf627fb701a98287 /arch/sh/include/cpu-sh3 | |
parent | fc4618575f79eea062cdc51715040e40cd35b71c (diff) |
sh: fix Transfer Size calculation in both DMA drivers
Both the original arch/sh/drivers/dma/dma-sh.c and the new SH dmaengine drivers
do not take into account bits 3:2 of the Transfer Size field in the CHCR
register, besides, bit-field defines set bit 2, but the mask only passes bits
1:0 through. TS_16BLK and TS_32BLK macros are bogus too. This patch fixes all
these issues for sh7722 and sh7724, other CPUs stay unchanged and might need to
be fixed too.
Signed-off-by: Guennadi Liakhovetski <g.liakhovetski@gmx.de>
Acked-by: Dan Williams <dan.j.williams@intel.com>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh/include/cpu-sh3')
-rw-r--r-- | arch/sh/include/cpu-sh3/cpu/dma.h | 20 |
1 files changed, 12 insertions, 8 deletions
diff --git a/arch/sh/include/cpu-sh3/cpu/dma.h b/arch/sh/include/cpu-sh3/cpu/dma.h index 0ea15f3f2363..207811a7a650 100644 --- a/arch/sh/include/cpu-sh3/cpu/dma.h +++ b/arch/sh/include/cpu-sh3/cpu/dma.h | |||
@@ -20,8 +20,10 @@ | |||
20 | #define TS_32 0x00000010 | 20 | #define TS_32 0x00000010 |
21 | #define TS_128 0x00000018 | 21 | #define TS_128 0x00000018 |
22 | 22 | ||
23 | #define CHCR_TS_MASK 0x18 | 23 | #define CHCR_TS_LOW_MASK 0x18 |
24 | #define CHCR_TS_SHIFT 3 | 24 | #define CHCR_TS_LOW_SHIFT 3 |
25 | #define CHCR_TS_HIGH_MASK 0 | ||
26 | #define CHCR_TS_HIGH_SHIFT 0 | ||
25 | 27 | ||
26 | #define DMAOR_INIT DMAOR_DME | 28 | #define DMAOR_INIT DMAOR_DME |
27 | 29 | ||
@@ -36,11 +38,13 @@ enum { | |||
36 | XMIT_SZ_128BIT, | 38 | XMIT_SZ_128BIT, |
37 | }; | 39 | }; |
38 | 40 | ||
39 | static unsigned int ts_shift[] __maybe_unused = { | 41 | #define TS_SHIFT { \ |
40 | [XMIT_SZ_8BIT] = 0, | 42 | [XMIT_SZ_8BIT] = 0, \ |
41 | [XMIT_SZ_16BIT] = 1, | 43 | [XMIT_SZ_16BIT] = 1, \ |
42 | [XMIT_SZ_32BIT] = 2, | 44 | [XMIT_SZ_32BIT] = 2, \ |
43 | [XMIT_SZ_128BIT] = 4, | 45 | [XMIT_SZ_128BIT] = 4, \ |
44 | }; | 46 | } |
47 | |||
48 | #define TS_INDEX2VAL(i) (((i) & 3) << CHCR_TS_LOW_SHIFT) | ||
45 | 49 | ||
46 | #endif /* __ASM_CPU_SH3_DMA_H */ | 50 | #endif /* __ASM_CPU_SH3_DMA_H */ |