dma.h 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. #ifndef __ASM_CPU_SH3_DMA_H
  2. #define __ASM_CPU_SH3_DMA_H
  3. #if defined(CONFIG_CPU_SUBTYPE_SH7720) || \
  4. defined(CONFIG_CPU_SUBTYPE_SH7721) || \
  5. defined(CONFIG_CPU_SUBTYPE_SH7710) || \
  6. defined(CONFIG_CPU_SUBTYPE_SH7712)
  7. #define SH_DMAC_BASE0 0xa4010020
  8. #else /* SH7705/06/07/09 */
  9. #define SH_DMAC_BASE0 0xa4000020
  10. #endif
  11. #define DMTE0_IRQ 48
  12. #define DMTE4_IRQ 76
  13. /* Definitions for the SuperH DMAC */
  14. #define TM_BURST 0x00000020
  15. #define TS_8 0x00000000
  16. #define TS_16 0x00000008
  17. #define TS_32 0x00000010
  18. #define TS_128 0x00000018
  19. #define CHCR_TS_LOW_MASK 0x18
  20. #define CHCR_TS_LOW_SHIFT 3
  21. #define CHCR_TS_HIGH_MASK 0
  22. #define CHCR_TS_HIGH_SHIFT 0
  23. #define DMAOR_INIT DMAOR_DME
  24. /*
  25. * The SuperH DMAC supports a number of transmit sizes, we list them here,
  26. * with their respective values as they appear in the CHCR registers.
  27. */
  28. enum {
  29. XMIT_SZ_8BIT,
  30. XMIT_SZ_16BIT,
  31. XMIT_SZ_32BIT,
  32. XMIT_SZ_128BIT,
  33. };
  34. #define TS_SHIFT { \
  35. [XMIT_SZ_8BIT] = 0, \
  36. [XMIT_SZ_16BIT] = 1, \
  37. [XMIT_SZ_32BIT] = 2, \
  38. [XMIT_SZ_128BIT] = 4, \
  39. }
  40. #define TS_INDEX2VAL(i) (((i) & 3) << CHCR_TS_LOW_SHIFT)
  41. #endif /* __ASM_CPU_SH3_DMA_H */